homeserver initial commit
- ansible - docker-compose - Kubernetes_deployments
This commit is contained in:
		| @ -0,0 +1,49 @@ | ||||
| apiVersion: apps/v1 | ||||
| kind: Deployment | ||||
| metadata: | ||||
|   name: {{ .Values.name }} | ||||
|   namespace: {{ .Values.namespace }} | ||||
| spec: | ||||
|   replicas: {{ .Values.deployment.replicas }} | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       app: {{ .Values.name }} | ||||
|   template: | ||||
|     metadata: | ||||
|       labels: | ||||
|         app: {{ .Values.name }} | ||||
|     spec: | ||||
|       containers: | ||||
|         - name: {{ .Values.name }} | ||||
|           image: {{ .Values.deployment.image }} | ||||
|           ports: | ||||
|             - containerPort: {{ .Values.deployment.containerPort }} | ||||
|           env: | ||||
|             - name: REGISTRY_AUTH | ||||
|               value: "htpasswd" | ||||
|             - name: REGISTRY_AUTH_HTPASSWD_REALM | ||||
|               value: "Registry Realm" | ||||
|             - name: REGISTRY_AUTH_HTPASSWD_PATH | ||||
|               value: "/auth/registry-passwords" | ||||
|             - name: REGISTRY_AUTH_HTPASSWD_FILE | ||||
|               value: "/auth/registry-passwords" | ||||
|             - name: REGISTRY_HTTP_HEADERS | ||||
|               value: | | ||||
|                 Access-Control-Allow-Origin: ['{{ .Values.uiDomain }}'] | ||||
|                 Access-Control-Allow-Methods: ['HEAD', 'GET', 'OPTIONS', 'DELETE', 'POST', 'PUT'] | ||||
|                 Access-Control-Allow-Headers: ['Authorization', 'Accept', 'Content-Type', 'X-Requested-With', 'Cache-Control'] | ||||
|                 Access-Control-Max-Age: [1728000] | ||||
|                 Access-Control-Allow-Credentials: [true] | ||||
|                 Access-Control-Expose-Headers: ['Docker-Content-Digest'] | ||||
|           volumeMounts: | ||||
|             - name: {{ .Values.deployment.registryStorageVolumeName }} | ||||
|               mountPath: /var/lib/registry | ||||
|             - name: {{ .Values.deployment.authStorageVolumeName }} | ||||
|               mountPath: /auth | ||||
|       volumes: | ||||
|         - name: {{ .Values.deployment.registryStorageVolumeName }} | ||||
|           persistentVolumeClaim: | ||||
|             claimName: {{ .Values.pvc.claimName }} | ||||
|         - name: {{ .Values.deployment.authStorageVolumeName }} | ||||
|           secret: | ||||
|             secretName: {{ .Values.credentialSecret.name }} | ||||
| @ -0,0 +1,29 @@ | ||||
| {{- if .Values.ingress.enabled }} | ||||
| apiVersion: networking.k8s.io/v1 | ||||
| kind: Ingress | ||||
| metadata: | ||||
|   name: {{ .Values.name }}-ingress | ||||
|   namespace: {{ .Values.namespace }} | ||||
|   annotations: | ||||
|   {{- range $key, $value := .Values.ingress.annotations }} | ||||
|     {{ $key }}: {{ $value | quote }} | ||||
|   {{- end }} | ||||
| spec: | ||||
|   rules: | ||||
|     - host: "{{ .Values.host }}" | ||||
|       http: | ||||
|         paths: | ||||
|           - path: / | ||||
|             pathType: Prefix | ||||
|             backend: | ||||
|               service: | ||||
|                 name: {{ .Values.name }}-service | ||||
|                 port: | ||||
|                   number: 5000 | ||||
|   {{- if .Values.ingress.tls.enabled }} | ||||
|   tls: | ||||
|     - hosts: | ||||
|         - "{{ .Values.ingress.tls.host }}" | ||||
|       secretName: {{ .Values.ingress.tls.secretName }} | ||||
|   {{- end }} | ||||
| {{- end }} | ||||
| @ -0,0 +1,11 @@ | ||||
| apiVersion: v1 | ||||
| kind: PersistentVolumeClaim | ||||
| metadata: | ||||
|   name: {{ .Values.pvc.claimName }} | ||||
|   namespace: {{ .Values.namespace }} | ||||
| spec: | ||||
|   accessModes: | ||||
|     - {{  .Values.pvc.accessMode }} | ||||
|   resources: | ||||
|     requests: | ||||
|       storage: {{ .Values.pvc.size }} | ||||
| @ -0,0 +1,13 @@ | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   name: {{ .Values.name }}-service | ||||
|   namespace: {{ .Values.namespace }} | ||||
| spec: | ||||
|   selector: | ||||
|     app: {{ .Values.name }} | ||||
|   ports: | ||||
|     - protocol: TCP | ||||
|       port: {{ .Values.service.port }} | ||||
|       targetPort: {{ .Values.deployment.containerPort }} | ||||
|   type: {{  .Values.service.type }} | ||||
		Reference in New Issue
	
	Block a user