重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
应用镜像
公司专注于为企业提供网站建设、成都网站设计、微信公众号开发、商城网站制作,小程序设计,软件按需求定制网站等一站式互联网企业服务。凭借多年丰富的经验,我们会仔细了解各客户的需求而做出多方面的分析、设计、整合,为客户设计出具风格及创意性的商业解决方案,创新互联更提供一系列网站制作和网站推广的服务。
应用镜像是chart包的核心,必须包含:镜像仓库地址、镜像名称、镜像版本,values.yaml字段规范如下:
repository: hub: docker.io image: gitlab/gitlab-ce tag: 11.1.4-ce.0 deployment中引用: image: {{ .Values.repository.hub }}/{{ .Values.repository.image }}:{{ .Values.repository.tag }}
探针
应用的探针用于检测该应用是否健康,是否准备好对外提供服务。健康状况是非常关键的属性,因此每个应用必须都明确表示如何进行健康检测。
values.yaml文件必须包含以下探针属性:
livenessProbe: # 存活探针 enabled: true path: / # 心跳检测的接口,默认都是httpGet请求 initialDelaySeconds: 30 # 容器启动后第一次执行探测是需要等待多少秒。 periodSeconds: 60 # 执行探测的频率。默认是10秒,最小1秒。 timeoutSeconds: 5 # 探测超时时间。默认1秒,最小1秒。 successThreshold: 1 # 探测失败后,最少连续探测成功多少次才被认定为成功。默认是1 failureThreshold: 5 # 探测成功后,最少连续探测失败多少次才被认定为失败。默认是3 readinessProbe: # 就绪探针 enabled: true path: / # 心跳检测的接口,默认都是httpGet请求 initialDelaySeconds: 10 periodSeconds: 10 timeoutSeconds: 5 successThreshold: 1 failureThreshold: 5
deployment.yaml文件引用探针如下:
{{- if .Values.livenessProbe.enabled }} livenessProbe: initialDelaySeconds: {{ .Values.livenessProbe.initialDelaySeconds }} periodSeconds: {{ .Values.livenessProbe.periodSeconds }} timeoutSeconds: {{ .Values.livenessProbe.timeoutSeconds }} successThreshold: {{ .Values.livenessProbe.successThreshold }} failureThreshold: {{ .Values.livenessProbe.failureThreshold }} httpGet: path: {{ .Values.livenessProbe.path }} port: http {{- end }} {{- if .Values.readinessProbe.enabled }} readinessProbe: initialDelaySeconds: {{ .Values.readinessProbe.initialDelaySeconds }} periodSeconds: {{ .Values.readinessProbe.periodSeconds }} timeoutSeconds: {{ .Values.readinessProbe.timeoutSeconds }} successThreshold: {{ .Values.readinessProbe.successThreshold }} failureThreshold: {{ .Values.readinessProbe.failureThreshold }} httpGet: path: {{.Values.readinessProbe.path }} port: http {{- end }}
资源限制
每个应用都需要使用到CPU和内存资源,如果不加以明确说明,则会导致资源的无畏浪费,并且在资源不足时第一时间就被回收。
因此应用都应当明确申明自己所需的资源大小。
values.yaml文件包含以下属性:
resources: requests: # 声明最少使用的资源,不够的话则应用无法启动成功 memory: 256Mi cpu: 100m limits: # 声明最大使用的资源,超过即重启应用pod memory: 256Mi cpu: 100m
持久化存储
应用如果不使用持久化存储,那么当应用重启的时候,之前保存的数据将会都清空。在web无状态应用中,这是保持环境干净很好的一种方式。
但是如果我们应用有数据需要持久保留的话,就需要使用到持久化存储了。以下是持久化存储规范:
values.yaml文件需包含以下属性:
persistence: enabled: true local: enabled: false # 是否启用本地存储 name: gitlab-pg # 对应本地存储名称 storageClass: "nfs-dynamic-class" # 集群共享存储 accessMode: ReadWriteOnce # 存储访问模式 size: 30Mi # 声明所需存储的大小 annotations: {}
templates目录下新建auto-pvc.yaml文件,这里之所以要加一个auto前缀就是为了保证安装时首先执行安装pvc,默认helm是安装文件名顺序来执行安装的。
内容如下:
{{- if and .Values.persistence.enabled (not .Values.persistence.existingClaim) }} kind: PersistentVolumeClaim apiVersion: v1 metadata: name: {{ .Release.Name }}-pvc {{- with .Values.persistence.annotations }} annotations: {{ toYaml . | indent 4 }} {{- end }} labels: app: {{ .Release.Name }} spec: {{- if .Values.persistence.local.enabled }} volumeName: "{{ .Values.persistence.local.name }}" {{- end }} accessModes: - {{ .Values.persistence.accessMode | quote }} resources: requests: storage: {{ .Values.persistence.size | quote }} {{- if .Values.persistence.storageClass }} {{- if (eq "-" .Values.persistence.storageClass) }} storageClassName: "" {{- else }} storageClassName: "{{ .Values.persistence.storageClass }}" {{- end }} {{- end }} {{- end }}
最后根据应用需要读写的路径,挂载到容器内,修改deployment.yaml文件,添加以下内容:
volumes: - name: data {{- if .Values.persistence.enabled }} persistentVolumeClaim: claimName: {{ .Release.Name }}-pvc {{- else }} emptyDir: {} {{- end }}
# containers子标签中添加
volumeMounts: - name: data mountPath: /mnt # 应用容器内需要读写的路径
本地存储
我们以后有很多应用都需要支持本地存储,本地存储修改内容如下:
values.yaml persistence: enabled: true local: enabled: true # 启用本地存储 name: gitlab-pg # 对应本地存储名称 accessMode: ReadWriteOnce size: 20Gi storageClass: "-" # 取消共享存储 annotations: {} nodeSelector: kubernetes.io/hostname: 10.160.144.72 # 对应本地运行主机
安全
设置Pod运行的用户,一般情况为了安全起见,容器内不建议使用root用户进行运行。但是如果需要使用本地存储,那么就必须要使用root用户运行了。
另外在使用共享存储时,可以将usePodSecurityContext设置为false。
设置以root运行,在values.yaml文件添加:
security: usePodSecurityContext: true runAsUser: 0 fsGroup: 0
在deployment.yaml文件中添加:
{{- if .Values.security.usePodSecurityContext }} securityContext: runAsUser: {{ default 0 .Values.security.runAsUser }} {{- if and (.Values.security.runAsUser) (.Values.security.fsGroup) }} fsGroup: {{ .Values.security.fsGroup }} {{- end }} {{- end }}