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

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 通过编写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即可完成注册并登陆

                                登陆之后显示如下:

                                相关实践学习
                                容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
                                通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
                                云原生实践公开课
                                课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务&nbsp;ACK 容器服务&nbsp;Kubernetes&nbsp;版(简称&nbsp;ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情:&nbsp;https://www.aliyun.com/product/kubernetes
                                相关文章
                                |
                                28天前
                                |
                                运维 Kubernetes 监控
                                揭秘高效运维:如何用kubectl top命令实时监控K8s资源使用情况?
                                揭秘高效运维:如何用kubectl top命令实时监控K8s资源使用情况?
                                46 0
                                |
                                1月前
                                |
                                存储 Kubernetes 负载均衡
                                Kubernetes的“厨房”:架构是菜谱,组件是厨具,资源对象是食材(下)
                                本文深入探讨了Kubernetes(K8s)的架构、核心组件以及资源对象。Kubernetes作为一个开源的容器编排系统,通过其独特的架构设计和丰富的组件,实现了对容器化应用程序的高效管理和扩展。通过本文的介绍,读者可以深入了解Kubernetes的架构、核心组件以及资源对象,从而更好地应用和管理容器化应用程序。Kubernetes的灵活性和可扩展性使得它成为容器编排领域的领先者,为企业提供了强大的容器运行环境。
                                |
                                2月前
                                |
                                数据可视化 Shell Linux
                                shell+crontab+gitlab实现ecs服务器文件的web展示
                                本文通过把ecs服务器上的文件定时上传至gitlab,实现文件的页面可视化和修改历史。技术点:shell、crontab、gitlab。
                                52 3
                                |
                                2月前
                                |
                                Prometheus 监控 Kubernetes
                                如何用 Prometheus Operator 监控 K8s 集群外服务?
                                如何用 Prometheus Operator 监控 K8s 集群外服务?
                                |
                                18天前
                                |
                                JSON Kubernetes Go
                                IDEA使用Kubernetes插件编写YAML
                                IDEA使用Kubernetes插件编写YAML
                                30 0
                                IDEA使用Kubernetes插件编写YAML
                                |
                                28天前
                                |
                                消息中间件 Kubernetes Kafka
                                Terraform阿里云创建资源1分钟创建集群一键发布应用Terraform 创建 Kubernetes 集群
                                Terraform阿里云创建资源1分钟创建集群一键发布应用Terraform 创建 Kubernetes 集群
                                19 0
                                |
                                29天前
                                |
                                Kubernetes 应用服务中间件 nginx
                                K8S部署Metrics-Server服务
                                K8S部署Metrics-Server服务
                                20 1
                                |
                                1月前
                                |
                                人工智能 监控 Serverless
                                如何基于ACK Serverless快速部署AI推理服务
                                通过上述步骤,可以在ACK Serverless上快速部署AI推理服务,实现高可用、弹性扩展的服务架构。
                                22 1
                                |
                                1月前
                                |
                                Kubernetes 网络协议 应用服务中间件
                                K8S管理核心资源的三种基本方法
                                K8S管理核心资源的三种基本方法
                                27 0
                                |
                                1月前
                                |
                                Kubernetes 应用服务中间件 nginx
                                K8S(05)核心插件-ingress(服务暴露)控制器-traefik
                                K8S(05)核心插件-ingress(服务暴露)控制器-traefik
                                30 0

                                推荐镜像

                                更多