使用 helm 部署 gitlab

一、下载 Gitlab chart

  1. 进入 artifacthub 官网

  2. 选择你想要的版本(我选择的chart版本是 8.4.0 , gitlab 版本是17.4.0 )

  3. 进入到控制台,添加helm仓库

  4. 如果你想不改任何配置,你可以执行安装命令,等待安装即可

    powershell 复制代码
    helm install my-gitlab gitlab/gitlab --version 8.4.0
  5. 我更倾向于把 chart 拉下来,根据自己的需求来修改配置

二、修改 Gitlab 配置

  1. 前面已经把安装文件下载到本地,那么把文件解压一下,进入到 values.yaml

  2. 禁用 ingress controller,ingres

    yaml 复制代码
    global: 
      ingress:
        configureCertmanager: false
        useNewIngressForCerts: false
        enabled: false
    
    nginx-ingress: &nginx-ingress
      enabled: false
  3. 禁用prometheus, gitlab-runner 等应用

  4. 把镜像替换成个人私有仓库的镜像(其实也是把官方镜像推到个人仓库里)

    • 替换镜像是个麻烦事,可能会漏掉要改的镜像,可以使用 helm template 命令把chart 生成一个模板yaml文件,这样就知道哪里漏改了
    • 进入到gitlab chart 目录里
    • 执行 helm template gitlab . > template.yaml 命令,输出 template.yaml 文件
    • 打开 template.yaml 文件,就知道要替换的镜像有哪些了

三、部署 Gitlab

  1. 创建 gitlab 命名空间

    bash 复制代码
    kubectl create namespace gitlab
  2. 创建 tls 证书

    bash 复制代码
    kubectl -n gitlab create secret tls gitlab-tls \
    --key /data/gzzsy/xx.com.cn.key \
    --cert /data/gzzsy/fullchain.cer
  3. 部署 gitlab

    • 进入到gitlab目录里,执行命令

      bash 复制代码
      helm install -n gitlab gitlab . 
    • 执行 kubectl get pods -n gitlab ,可以看到运行的pod

    • 执行 kubectl get svc -n gitlab ,可以看到运行的service

  4. 部署gitlab的ingress

    yaml 复制代码
    apiVersion: networking.k8s.io/v1
    kind: Ingress
    metadata:
      name: gitlab-ingress
      namespace: gitlab
      annotations:
        nginx.ingress.kubernetes.io/proxy-body-size: "0"
        nginx.ingress.kubernetes.io/ssl-redirect: "true"
    spec:
      ingressClassName: nginx
      rules:
        - host: xx.com.cn
          http:
            paths:
              - path: /
                pathType: Prefix
                backend:
                  service:
                    name: gitlab-webservice-default
                    port:
                      number: 8181
      tls:
        - hosts:
            - xx.com.cn
          secretName: gitlab-tls
  5. 访问gitlab页面, 这样就成功了

  6. 获取 gitlab初始化的密码, 账号默认是 root

    • kubectl get secrets -n gitlab
    • kubectl get secrets gitlab-gitlab-initial-root-password -n gitlab -o yaml
    • 把加密密码 base64 解密就可以了
  7. 这样gitlab就部署完成了,想要卸载执行

    bash 复制代码
    helm uninstall -n gitlab gitlab

看到最后,如果这篇文章对你有帮助的话,欢迎点赞收藏+follow,谢谢!

相关推荐
裁二尺秋风30 分钟前
CI/CD — Pipeline的使用以及Blue Ocean多分支流水线的使用方法
ci/cd·gitlab·jenkins
CC码码1 天前
管理你的多个 Git 密钥(多平台多账号)
git·gitlab·github
CC码码1 天前
管理你的多个 Git 密钥(单平台多账号)
git·gitlab·github
兔老大RabbitMQ2 天前
GitLab详细分析
gitlab
小道仙9714 天前
gitlab对接,gitlabRestApi,gitlab4j-api
java·git·gitlab
tswddd15 天前
项目:Gitlab HSD CI/CD总结
ci/cd·kubernetes·gitlab
许_安15 天前
docker中部署gitlab
docker·eureka·gitlab
Haoea!15 天前
持续集成 CI/CD-Jenkins持续集成GitLab项目打包docker镜像推送k8s集群并部署至rancher
ci/cd·gitlab·jenkins·rancher
xiaodaiwang15 天前
获取gitlab上项目分支版本(二)
gitlab
极小狐15 天前
GitLab CVE-2025-4278 安全漏洞解决方案
ci/cd·gitlab·devsecops·devops·gitlab升级·极狐gitlab·安全升级