kubernetes部署gitlab

kubernetes部署gitlab

apiVersion: v1
kind: Namespace
metadata:
  name: gitlab
  labels:
    app: gitlab
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  # gitlab数据存储
  name: gitlab-data
  namespace: gitlab
spec:
  # 注意更换自己的storageClass
  storageClassName: directpv-min-io
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 5Gi
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  # gitlab日志存储
  name: gitlab-log
  namespace: gitlab
spec:
  # 注意更换自己的storageClass
  storageClassName: directpv-min-io
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 4Gi
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  # gitlab配置存储
  name: gitlab-conf
  namespace: gitlab
spec:
  # 注意更换自己的storageClass
  storageClassName: directpv-min-io
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 1Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: gitlab
  namespace: gitlab
  labels:
    app: gitlab
spec:
  replicas: 1
  selector:
    matchLabels:
      app: gitlab
  template:
    metadata:
      labels:
        app: gitlab
    spec:
      containers:
        - name: gitlab
          image: gitlab/gitlab-ce:15.11.8-ce.0
          imagePullPolicy: IfNotPresent
          ports:
            - containerPort: 80
              name: http
          env:
            - name: TZ
              value: Asia/Shanghai
            - name: GITLAB_HOST
              value: gitlab.ialso.cn
            - name: GITLAB_PORT
              value: "80"
              # 配置gitlab root账户的密码
            - name: GITLAB_ROOT_PASSWORD
              value: admin123456
              # 配置gitlab root账户的email
            - name: GITLAB_ROOT_EMAIL
              value: [email protected]
          volumeMounts:
            - name: gitlab-data
              mountPath: /var/opt/gitlab
            - name: gitlab-log
              mountPath: /var/log/gitlab
            - name: gitlab-conf
              mountPath: /etc/gitlab
          securityContext:
            privileged: true
            allowPrivilegeEscalation: true
      volumes:
        - name: gitlab-data
          persistentVolumeClaim:
            claimName: gitlab-data
        - name: gitlab-log
          persistentVolumeClaim:
            claimName: gitlab-log
        - name: gitlab-conf
          persistentVolumeClaim:
            claimName: gitlab-conf
---
apiVersion: v1
kind: Service
metadata:
  name: gitlab
  namespace: gitlab
spec:
  selector:
    app: gitlab
  ports:
    - name: http
      port: 80
      targetPort: 80
  type: ClusterIP
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: gitlab
  namespace: gitlab
  annotations:
    kubernetes.io/ingress.class: "nginx"
spec:
  rules:
      # 注意切换为自己的域名
    - host: gitlab.ialso.cn
      http:
        paths:
          - pathType: Prefix
            path: /
            backend:
              service:
                name: gitlab
                port:
                  number: 80

你可能感兴趣的:(kubernetes,gitlab)