通过编写k8s的资源清单yaml文件部署gitlab服务

本文涉及的产品
PolarClaw,2核4GB
简介: 通过编写k8s的资源清单yaml文件部署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即可完成注册并登陆

                                登陆之后显示如下:

                                相关实践学习
                                深入解析Docker容器化技术
                                Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
                                相关文章
                                |
                                6月前
                                |
                                Kubernetes 安全 网络协议
                                Kubernetes实用指令:通过dry-run生成部署与服务的YAML配置
                                总结起来, 使用 ` -- dry—run = client `- o yam l' 参数能够帮助用户预览 Kubernetes 资源定义并且确保它们符合预期效果且没有立即影响现有集群断层结构. 这种做法对于新手学习 K8s 资源规范、测试新策略或者审核现有策略都非常有效率与安全.
                                563 4
                                |
                                7月前
                                |
                                Java 测试技术 数据安全/隐私保护
                                通过yaml文件配置自动化测试程序
                                通过yaml文件可以将自动化测试环境,测试数据和测试行为分开,请看一下案例
                                305 4
                                |
                                存储 Kubernetes 对象存储
                                部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
                                借助阿里云ACK One注册集群,充分利用阿里云强大ACS GPU算力,实现DeepSeek推理模型高效部署。
                                |
                                10月前
                                |
                                Ubuntu 安全 数据安全/隐私保护
                                在Docker容器中部署GitLab服务器的步骤(面向Ubuntu 16.04)
                                现在,你已经成功地在Docker上部署了GitLab。这就是我们在星际中的壮举,轻松如同土豆一样简单!星际旅行结束,靠岸,打开舱门,迎接全新的代码时代。Prepare to code, astronaut!
                                651 12
                                |
                                9月前
                                |
                                运维 Kubernetes 持续交付
                                ACK One GitOps:让全球化游戏服务持续交付更简单
                                ACK One GitOps 致力于提供开箱即用的多集群 GitOps 持续交付能力,简化游戏等服务的多集群/多地域统一部署,让您更加专注于业务开发。
                                |
                                存储 Kubernetes 对象存储
                                部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
                                部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
                                428 3
                                |
                                Kubernetes 持续交付 数据库
                                阿里云ACK+GitLab企业级部署实战教程
                                GitLab 是一个功能强大的基于 Web 的 DevOps 生命周期平台,整合了源代码管理、持续集成/持续部署(CI/CD)、项目管理等多种工具。其一体化设计使得开发团队能够在同一平台上进行代码协作、自动化构建与部署及全面的项目监控,极大提升了开发效率和项目透明度。 GitLab 的优势在于其作为一体化平台减少了工具切换,高度可定制以满足不同项目需求,并拥有活跃的开源社区和企业级功能,如高级权限管理和专业的技术支持。借助这些优势,GitLab 成为许多开发团队首选的 DevOps 工具,实现从代码编写到生产部署的全流程自动化和优化。
                                |
                                弹性计算 运维 Kubernetes
                                使用ACK Edge统一管理多地域的ECS资源
                                本文介绍如何使用ACK Edge来管理分布在多个地域的ECS资源。
                                |
                                弹性计算 运维 Kubernetes
                                使用ACK Edge统一管理多地域的ECS资源
                                使用ACK Edge统一管理多地域的ECS资源
                                290 0

                                推荐镜像

                                更多