GitLab Docker 安装完整配置项说明

文章目录

  • [1. 基础运行配置](#1. 基础运行配置)
  • [2. 数据持久化配置](#2. 数据持久化配置)
  • [3. 完整配置示例](#3. 完整配置示例)
  • [4. 环境变量配置项](#4. 环境变量配置项)
  • [5. 高级配置选项](#5. 高级配置选项)
  • [6. Docker Compose 完整示例](#6. Docker Compose 完整示例)
  • [7. 重要注意事项](#7. 重要注意事项)

1. 基础运行配置

bash 复制代码
docker run -d \
  --name gitlab \
  --restart always \
  --hostname gitlab.example.com \  # GitLab 访问域名,必须设置
  -p 8443:443 \      # HTTPS 端口映射
  -p 8080:80 \       # HTTP 端口映射  
  -p 8022:22 \       # SSH 端口映射
  --shm-size 256m \  # 共享内存大小,防止内存不足
  gitlab/gitlab-ce:latest

2. 数据持久化配置

bash 复制代码
docker run -d \
  # ... 其他参数 ...
  -v /srv/gitlab/config:/etc/gitlab \      # 配置文件持久化
  -v /srv/gitlab/logs:/var/log/gitlab \    # 日志文件持久化
  -v /srv/gitlab/data:/var/opt/gitlab \    # 应用数据持久化
  gitlab/gitlab-ce:latest

3. 完整配置示例

bash 复制代码
docker run -d \
  --name gitlab \
  --restart always \
  --hostname gitlab.example.com \
  
  # 端口映射
  -p 8080:80 \        # Web 访问端口
  -p 8443:443 \       # HTTPS 端口  
  -p 8022:22 \        # Git SSH 端口
  
  # 数据卷映射
  -v /docker/gitlab/config:/etc/gitlab \
  -v /docker/gitlab/logs:/var/log/gitlab \
  -v /docker/gitlab/data:/var/opt/gitlab \
  
  # 内存和资源限制
  --shm-size 256m \
  --memory 4096m \     # 限制内存使用
  --cpus 2 \          # 限制 CPU 核心数
  
  # 环境变量配置
  -e GITLAB_OMNIBUS_CONFIG="external_url 'https://gitlab.example.com'; gitlab_rails['gitlab_shell_ssh_port'] = 8022;" \
  
  gitlab/gitlab-ce:latest

4. 环境变量配置项

基础配置

bash 复制代码
# 外部访问 URL(必须)
-e EXTERNAL_URL="https://gitlab.example.com"

# 时区设置
-e GITLAB_TIME_ZONE="Asia/Shanghai"
邮件配置
bash
-e GITLAB_OMNIBUS_CONFIG="
gitlab_rails['smtp_enable'] = true;
gitlab_rails['smtp_address'] = 'smtp.gmail.com';
gitlab_rails['smtp_port'] = 587;
gitlab_rails['smtp_user_name'] = 'your-email@gmail.com';
gitlab_rails['smtp_password'] = 'your-password';
gitlab_rails['smtp_domain'] = 'gmail.com';
gitlab_rails['smtp_authentication'] = 'login';
gitlab_rails['smtp_enable_starttls_auto'] = true;
gitlab_rails['smtp_tls'] = false;
gitlab_rails['gitlab_email_from'] = 'gitlab@example.com';
"
数据库配置
bash
# 使用外部 PostgreSQL
-e GITLAB_OMNIBUS_CONFIG="
gitlab_rails['db_adapter'] = 'postgresql';
gitlab_rails['db_encoding'] = 'unicode';
gitlab_rails['db_host'] = 'postgresql';
gitlab_rails['db_port'] = '5432';
gitlab_rails['db_username'] = 'gitlab';
gitlab_rails['db_password'] = 'password';
"
Redis 配置
bash
# 使用外部 Redis
-e GITLAB_OMNIBUS_CONFIG="
gitlab_rails['redis_host'] = 'redis';
gitlab_rails['redis_port'] = '6379';
"

5. 高级配置选项

SSL 证书配置

bash 复制代码
# 挂载 SSL 证书
-v /path/to/ssl:/etc/gitlab/ssl

-e GITLAB_OMNIBUS_CONFIG="
external_url 'https://gitlab.example.com';
nginx['redirect_http_to_https'] = true;
nginx['ssl_certificate'] = '/etc/gitlab/ssl/gitlab.example.com.crt';
nginx['ssl_certificate_key'] = '/etc/gitlab/ssl/gitlab.example.com.key';
"
备份配置
bash
# 备份目录挂载
-v /backup/gitlab:/var/opt/gitlab/backups

# 备份设置
-e GITLAB_OMNIBUS_CONFIG="
gitlab_rails['backup_path'] = '/var/opt/gitlab/backups';
gitlab_rails['backup_keep_time'] = 604800; # 保留7天
"
性能调优
bash
-e GITLAB_OMNIBUS_CONFIG="
# 工作进程数
unicorn['worker_processes'] = 2;

# Sidekiq 并发数
sidekiq['concurrency'] = 10;

# 数据库连接池大小
gitlab_rails['db_pool'] = 10;

# Redis 连接池
gitlab_rails['redis_cache_database'] = 0;
"

6. Docker Compose 完整示例

yaml 复制代码
version: '3.8'
services:
  gitlab:
    image: gitlab/gitlab-ce:latest
    container_name: gitlab
    restart: always
    hostname: 'gitlab.example.com'
    
    environment:
      GITLAB_OMNIBUS_CONFIG: |
        external_url 'https://gitlab.example.com'
        gitlab_rails['gitlab_shell_ssh_port'] = 8022
        gitlab_rails['smtp_enable'] = true
        gitlab_rails['smtp_address'] = "smtp.gmail.com"
        gitlab_rails['smtp_port'] = 587
        gitlab_rails['smtp_user_name'] = "your-email@gmail.com"
        gitlab_rails['smtp_password'] = "your-password"
        gitlab_rails['smtp_domain'] = "gmail.com"
        gitlab_rails['smtp_authentication'] = "login"
        gitlab_rails['smtp_enable_starttls_auto'] = true
        gitlab_rails['smtp_tls'] = false
        gitlab_rails['gitlab_email_from'] = 'gitlab@example.com'
        
    ports:
      - "8080:80"
      - "8443:443" 
      - "8022:22"
      
    volumes:
      - ./gitlab/config:/etc/gitlab
      - ./gitlab/logs:/var/log/gitlab
      - ./gitlab/data:/var/opt/gitlab
      - ./backup:/var/opt/gitlab/backups
      
    shm_size: '256m'
    mem_limit: 4g
    cpus: 2.0

7. 重要注意事项

  1. 首次启动需要耐心等待(5-10分钟)
  2. 确保挂载目录有正确权限
  3. hostname 必须与访问域名一致
  4. 备份数据卷非常重要
  5. 生产环境建议配置资源限制

这个配置清单涵盖了 GitLab Docker 安装的主要配置项,你可以根据实际需求进行调整。

相关推荐
学Linux的语莫4 小时前
docker,docker-compose二进制包安装
docker
_oP_i6 小时前
Docker 整体架构
docker·容器·架构
杨浦老苏6 小时前
可视化服务构建器Dock-Dploy
docker·工具·群晖
落世繁华7 小时前
DIFY合同生成全流程开发实践(三、后端接口以及优化方向)
docker·一键部署·dify·合同生成·文字转word
ascarl20107 小时前
Kubernetes 环境 NFS 卡死问题排查与解决纪要
云原生·容器·kubernetes
m0_5695310110 小时前
《K8s 网络入门到进阶:Service 与 Ingress 原理、部署方案及核心区别对比》
网络·容器·kubernetes
wxjlkh10 小时前
docker 搭建 grafana+prometheus 监控主机资源之node_exporter
docker·grafana·prometheus
HIT_Weston11 小时前
63、【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(七)
前端·ubuntu·gitlab
杨浦老苏12 小时前
安全共享敏感信息的共享工具Hemmelig.app
docker·群晖·密码·阅后即焚
眠りたいです12 小时前
Docker:容器虚拟化技术基础-namespace,cgroups,资源管理与LXC
运维·docker·中间件·容器