通过helm部署gitlab服务

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: 通过helm部署gitlab服务

搭建nfs服务器

1.为什么搭建nfs服务器?

因为我们要使用nfs作为持久化存储,创建的pv后端存储时需要nfs,所以需要搭建nfs服务。

2.安装nfs服务

选择自己的任意一台机器,我选择k8s的master1节点,对应的机器ip是192.168.0.6,在192.168.0.6上执行如下步骤,大家在自己环境找一台k8s节点的机器安装就可以了~

(1)yum安装nfs

yum install nfs-utils -y

systemctl start nfs

chkconfig nfs on

(2)在master1上创建一个nfs共享目录

mkdir  /data/v3   -p

mkdir  /data/v4

mkdir  /data/v5

cat  /etc/exports

/data/v3     192.168.0.0/24(rw,no_root_squash)

/data/v4     192.168.0.0/24(rw,no_root_squash)

/data/v5     192.168.0.0/24(rw,no_root_squash)

exportfs -arv   使配置文件生效

systemctl restart nfs

(3)k8s的各个node节点也需要安装nfs

yum install nfs-utils -y

systemctl start nfs

chkconfig nfs on

创建安装gitlab需要的pv和pvc

1.创建一个名称空间

kubectl create ns kube-ops

2.创建gitlab需要的pv和pvc

cat pv_pvc_gitlab.yaml

apiVersion: v1
kind: PersistentVolume
metadata:
  name: gitlabt
spec:
  capacity:
    storage: 10Gi
  accessModes:
  - ReadWriteMany
  persistentVolumeReclaimPolicy: Delete
  nfs:
    server: 192.168.0.6  #这个就是nfs服务端的机器ip,也就是k8s的master1节点ip
    path: /data/v5
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: gitlabt
  namespace: kube-ops
spec:
  accessModes:
    - ReadWriteMany
  resources:
    requests:
      storage: 10Gi

注意:

    nfs:  
    server: 192.168.0.6
    #这个就是nfs服务端的机器ip,也就是k8s的master1节点ip

    通过kubectl apply更新yaml文件

      kubectl apply -f pv_pvc_gitlab.yaml

      查看pv和pvc是否绑定

        kubectl get pvc -n kube-ops

        显示如下,说明绑定成功了

        NAME      STATUS   VOLUME    CAPACITY   ACCESS MODES   STORAGECLASS   AGE
        gitlabt   Bound    gitlabt   10Gi       RWX                           2m

        3.创建postsql的pv和pvc

        cat pv_pvc_postsql.yaml

        apiVersion: v1
        kind: PersistentVolume
        metadata:
          name: postsql
        spec:
          capacity:
            storage: 10Gi
          accessModes:
          - ReadWriteMany
          persistentVolumeReclaimPolicy: Delete
          nfs:
            server: 192.168.0.6
            path: /data/v4
        ---
        kind: PersistentVolumeClaim
        apiVersion: v1
        metadata:
          name: postsql
          namespace: kube-ops
        spec:
          accessModes:
            - ReadWriteMany
          resources:
            requests:
              storage: 10Gi

        通过kubectl apply更新yaml文件

          kubectl apply -f  pv_pvc_postsql.yaml

          查看pv和pvc是否绑定

            kubectl get pvc -n kube-ops

            显示如下,说明postsql的pvc和pv绑定成功了

            NAME      STATUS   VOLUME    CAPACITY   ACCESS MODES   STORAGECLASS   AGE
            gitlabt   Bound    gitlabt   10Gi       RWX                           5m6s
            postsql   Bound    postsql   10Gi       RWX                           2s

            4.创建redis的pv和pvc

            cat  pv_pvc_redis.yaml

            apiVersion: v1
            kind: PersistentVolume
            metadata:
              name: data
            spec:
              capacity:
                storage: 20Gi
              accessModes:
              - ReadWriteMany
              persistentVolumeReclaimPolicy: Delete
              nfs:
                server: 192.168.0.6
                path: /data/v3
            ---
            kind: PersistentVolumeClaim
            apiVersion: v1
            metadata:
              name: data
              namespace: kube-ops
            spec:
              accessModes:
                - ReadWriteMany
              resources:
                requests:
                  storage: 20Gi

            通过kubectl apply更新yaml文件

              kubectl apply -f  pv_pvc_redis.yaml

              查看pv和pvc是否绑定

                kubectl get pvc -n kube-ops

                显示如下,说明gitlab的pvc和pv绑定成功了

                NAME      STATUS   VOLUME    CAPACITY   ACCESS MODES   STORAGECLASS   AGE
                data      Bound    data      20Gi       RWX                           5s
                gitlabt   Bound    gitlabt   10Gi       RWX                           7m7s
                postsql   Bound    postsql   10Gi       RWX                           2m3s

                安装postgresql服务

                cat  gitlab-postgresql.yaml

                apiVersion: apps/v1
                kind: Deployment
                metadata:
                  name: postgresql
                  namespace: kube-ops
                  labels:
                    name: postgresql
                spec:
                  selector:
                    matchLabels:
                       name: postgresql
                  template:
                    metadata:
                      name: postgresql
                      labels:
                        name: postgresql
                    spec:
                      containers:
                      - name: postgresql
                        image: sameersbn/postgresql:10
                        imagePullPolicy: IfNotPresent
                        env:
                        - name: DB_USER
                          value: gitlab
                        - name: DB_PASS
                          value: passw0rd
                        - name: DB_NAME
                          value: gitlab_production
                        - name: DB_EXTENSION
                          value: pg_trgm
                        ports:
                        - name: postgres
                          containerPort: 5432
                        volumeMounts:
                        - mountPath: /var/lib/postgresql
                          name: data
                        livenessProbe:
                          exec:
                            command:
                            - pg_isready
                            - -h
                            - localhost
                            - -U
                            - postgres
                          initialDelaySeconds: 30
                          timeoutSeconds: 5
                        readinessProbe:
                          exec:
                            command:
                            - pg_isready
                            - -h
                            - localhost
                            - -U
                            - postgres
                          initialDelaySeconds: 5
                          timeoutSeconds: 1
                      volumes:
                      - name: data
                        persistentVolumeClaim:
                          claimName: postsql
                ---
                apiVersion: v1
                kind: Service
                metadata:
                  name: postgresql
                  namespace: kube-ops
                  labels:
                    name: postgresql
                spec:
                  ports:
                    - name: postgres
                      port: 5432
                      targetPort: postgres
                  selector:
                    name: postgresql

                通过kubectl apply更新yaml文件

                  kubectl apply -f gitlab-postgresql.yaml

                  查看postgresql是否部署成功

                    kubectl get pods -n kube-ops

                    显示如下,说明postgresql部署成功

                    NAME                          READY   STATUS    RESTARTS   AGE
                    postgresql-79f85cdfb4-r64q5   1/1     Running   0          68s

                    安装gitlab需要的redis服务

                    cat  gitlab-redis.yaml

                    apiVersion: apps/v1
                    kind: Deployment
                    metadata:
                      name: redis
                      namespace: kube-ops
                      labels:
                        name: redis
                    spec:
                      selector:
                        matchLabels:
                          name: redis
                      template:
                        metadata:
                          name: redis
                          labels:
                            name: redis
                        spec:
                          containers:
                          - name: redis
                            image: sameersbn/redis
                            imagePullPolicy: IfNotPresent
                            ports:
                            - name: redis
                              containerPort: 6379
                            volumeMounts:
                            - mountPath: /var/lib/redis
                              name: data
                            livenessProbe:
                              exec:
                                command:
                                - redis-cli
                                - ping
                              initialDelaySeconds: 30
                              timeoutSeconds: 5
                            readinessProbe:
                              exec:
                                command:
                                - redis-cli
                                - ping
                              initialDelaySeconds: 5
                              timeoutSeconds: 1
                          volumes:
                          - name: data
                            persistentVolumeClaim:
                              claimName: data
                    ---
                    apiVersion: v1
                    kind: Service
                    metadata:
                      name: redis
                      namespace: kube-ops
                      labels:
                        name: redis
                    spec:
                      ports:
                        - name: redis
                          port: 6379
                          targetPort: redis
                      selector:
                        name: redis

                    通过kubectl apply更新yaml文件

                      kubectl apply -f gitlab-redis.yaml

                      查看postgresql是否部署成功

                        kubectl get pods -n kube-ops

                        显示如下,说明redis部署成功

                        NAME                          READY   STATUS    RESTARTS   AGE
                        postgresql-79f85cdfb4-r64q5   1/1     Running   0          4m30s
                        redis-56c8dc76cd-q4q75        1/1     Running   0          65s

                        安装gitlab服务

                        cat  gitlab.yaml

                        apiVersion: apps/v1
                        kind: Deployment
                        metadata:
                          name: gitlab
                          namespace: kube-ops
                          labels:
                            name: gitlab
                        spec:
                          selector:
                            matchLabels:
                                name: gitlab
                          template:
                            metadata:
                              name: gitlab
                              labels:
                                name: gitlab
                            spec:
                              containers:
                              - name: gitlab
                                image: sameersbn/gitlab:11.8.1
                                imagePullPolicy: IfNotPresent
                                env:
                                - name: TZ
                                  value: Asia/Shanghai
                                - name: GITLAB_TIMEZONE
                                  value: Beijing
                                - name: GITLAB_SECRETS_DB_KEY_BASE
                                  value: long-and-random-alpha-numeric-string
                                - name: GITLAB_SECRETS_SECRET_KEY_BASE
                                  value: long-and-RANDOM-ALPHA-NUMERIc-string
                                - name: GITLAB_SECRETS_OTP_KEY_BASE
                                  value: long-and-random-alpha-numeric-string
                                - name: GITLAB_ROOT_PASSWORD
                                  value: admin321
                                - name: GITLAB_ROOT_EMAIL
                                  value: 19xxxxxxxx@qq.com
                                - name: GITLAB_HOST
                                  value: 192.168.0.6
                                - name: GITLAB_PORT
                                  value: "30852"
                                - name: GITLAB_SSH_PORT
                                  value: "32353"
                                - name: GITLAB_NOTIFY_ON_BROKEN_BUILDS
                                  value: "true"
                                - name: GITLAB_NOTIFY_PUSHER
                                  value: "false"
                                - name: GITLAB_BACKUP_SCHEDULE
                                  value: daily
                                - name: GITLAB_BACKUP_TIME
                                  value: 01:00
                                - name: DB_TYPE
                                  value: postgres
                                - name: DB_HOST
                                  value: postgresql
                                - name: DB_PORT
                                  value: "5432"
                                - name: DB_USER
                                  value: gitlab
                                - name: DB_PASS
                                  value: passw0rd
                                - name: DB_NAME
                                  value: gitlab_production
                                - name: REDIS_HOST
                                  value: redis
                                - name: REDIS_PORT
                                  value: "6379"
                                ports:
                                - name: http
                                  containerPort: 80
                                - name: ssh
                                  containerPort: 22
                                volumeMounts:
                                - mountPath: /home/git/data
                                  name: data
                                livenessProbe:
                                  httpGet:
                                    path: /
                                    port: 80
                                  initialDelaySeconds: 180
                                  timeoutSeconds: 5
                                readinessProbe:
                                  httpGet:
                                    path: /
                                    port: 80
                                  initialDelaySeconds: 5
                                  timeoutSeconds: 1
                              volumes:
                              - name: data
                                persistentVolumeClaim:
                                  claimName: gitlabt
                        ---
                        apiVersion: v1
                        kind: Service
                        metadata:
                          name: gitlab
                          namespace: kube-ops
                          labels:
                            name: gitlab
                        spec:
                          ports:
                            - name: http
                              port: 80
                              targetPort: http
                              nodePort: 30852
                            - name: ssh
                              port: 22
                              nodePort: 32353
                              targetPort: ssh
                          selector:
                            name: gitlab
                          type: NodePort

                        注意:

                        上面文件里的GITLAB_ROOT_EMAIL应该设置成自己的邮箱地址,不要用我的,用我的你们后面注册gitlab账号会有问题

                          - name: GITLAB_ROOT_EMAIL
                          value: 19xxxxxxxx@qq.com

                          通过kubectl apply更新yaml文件

                            kubectl apply -f gitlab.yaml

                            查看postgresql是否部署成功

                              kubectl get pods -n kube-ops
                              NAME                          READY   STATUS    RESTARTS   AGE
                              gitlab-cdff65b5f-7kfxn        1/1     Running   0          2m26s
                              postgresql-79f85cdfb4-r64q5   1/1     Running   0          10m
                              redis-56c8dc76cd-q4q75        1/1     Running   0          6m42s

                              访问gitlab web界面

                              上面部署都没问题的话,我们开始访问gitlab的web ui界面,具体步骤如下

                              1.查看gitlab在宿主机暴露的端口

                                kubectl get svc -n kube-ops

                                显示如下:

                                  gitlab       NodePort    10.98.248.116    <none>        80:30852/TCP,22:32353/TCP   5m25s

                                  我们在浏览器访问k8s的master1节点的IP:30852即可访问到gitlab web界面,我访问的地址是192.168.0.6:30852,出现如下界面

                                  第一次登陆,我们需要点击注册Registry

                                  Full name:可以随便起名字,符合要求即可,也可和我的保持一致,如下
                                  gitlab-admin
                                  Username:可以随便起名字,符合要求即可,也可和我的保持一致,如下
                                  gitlab-admin
                                  Email: 这个写你们自己的邮箱,跟你们gitlab.yaml文件里的邮箱地址一致即可,我写的qq邮箱,如下
                                  198xxxxxxx@qq.com
                                  Email confirmation:  这个就是跟上面Email对应的值保持一致即可,如下
                                  198xxxxxxx@qq.com
                                  Password: 自己设置个密码,我设置的是admin123
                                  admin123

                                  上面写好之后点击最下面的Registry即可完成注册并登陆

                                  登陆之后显示如下:

                                  相关实践学习
                                  通过Ingress进行灰度发布
                                  本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
                                  容器应用与集群管理
                                  欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
                                  相关文章
                                  |
                                  2月前
                                  |
                                  Java Maven Docker
                                  gitlab-ci 集成 k3s 部署spring boot 应用
                                  gitlab-ci 集成 k3s 部署spring boot 应用
                                  |
                                  6月前
                                  |
                                  JavaScript Java 应用服务中间件
                                  用白薅来的gitlab自带的gitlab-runner部署一个vue项目
                                  用白薅来的gitlab自带的gitlab-runner部署一个vue项目
                                  167 2
                                  |
                                  2月前
                                  |
                                  运维 Linux 开发工具
                                  第22篇 如何部署gitLab进行开发版本控制
                                  第22篇 如何部署gitLab进行开发版本控制
                                  |
                                  4月前
                                  |
                                  jenkins 持续交付 数据安全/隐私保护
                                  GitLab——如何快速部署GitLab仓库
                                  GitLab——如何快速部署GitLab仓库
                                  42 0
                                  |
                                  4月前
                                  |
                                  Linux 开发工具 git
                                  [git]基于GitLab搭建本地Git服务
                                  [git]基于GitLab搭建本地Git服务
                                  |
                                  6月前
                                  |
                                  运维 Serverless 开发工具
                                  函数计算产品使用问题之通过GitLab仓库来部署代码,该如何配置GitLab仓库
                                  函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
                                  |
                                  7月前
                                  无缝构建与部署:GitLab CI/CD首秀的实战攻略
                                  无缝构建与部署:GitLab CI/CD首秀的实战攻略
                                  227 0
                                  无缝构建与部署:GitLab CI/CD首秀的实战攻略
                                  |
                                  6月前
                                  |
                                  Docker 容器
                                  docker 部署gitlab
                                  docker 部署gitlab
                                  103 0
                                  |
                                  4月前
                                  |
                                  Shell Docker 容器
                                  GitlabCI学习笔记之一:安装Gitlab和GitLabRunner
                                  GitlabCI学习笔记之一:安装Gitlab和GitLabRunner
                                  |
                                  3月前
                                  |
                                  Docker 容器
                                  Docker安装Gitlab和Gitlab-Runner并实现项目CICD
                                  Docker安装Gitlab和Gitlab-Runner并实现项目CICD
                                  下一篇
                                  DataWorks