在CentOS上通过Docker容器化部署GitLab是一个相对简单且高效的方法。以下是详细的步骤指南:
安装Docker: 确保你的CentOS系统上已经安装了Docker。如果没有安装,可以参考Docker官方文档进行安装。
拉取GitLab镜像: 使用以下命令从Docker Hub拉取最新版本的GitLab社区版镜像:
docker pull gitlab/gitlab-ce:latest
创建并启动GitLab容器: 使用以下命令创建并启动GitLab容器。请根据你的实际需求调整端口映射和主机名:
docker run --detach \
--hostname gitlab.example.com \
--publish 443:443 \
--publish 80:80 \
--publish 22:22 \
--name gitlab \
--restart always \
-v /path/to/gitlab/config:/etc/gitlab \
-v /path/to/gitlab/logs:/var/log/gitlab \
-v /path/to/gitlab/data:/var/opt/gitlab \
gitlab/gitlab-ce:latest
命令参数解释:
-d
:以守护进程模式运行容器。--hostname
:设置容器的主机名。-p
:将容器端口映射到宿主机端口。--name
:设置容器名称。--restart always
:容器退出后自动重启。-v
:挂载目录,将宿主机的目录映射到容器的对应目录。初始化GitLab设置: 容器启动后,GitLab会开始初始化过程。首次访问时,需要设置管理员账户密码。可以通过以下命令查看初始密码:
docker exec -it gitlab grep 'Password:' /etc/gitlab/initial_root_password
在浏览器中输入服务器的IP地址或域名,使用root账户和生成的初始密码登录,然后进行必要的配置,如设置外部URL、配置SMTP邮件服务等。
配置HTTPS: 为了安全起见,建议为GitLab配置HTTPS。你可以使用Let’s Encrypt来获取免费的SSL证书。首先,安装Certbot和Nginx:
sudo yum install -y certbot python3-certbot-nginx
然后,使用Certbot获取并配置SSL证书:
sudo certbot --nginx -d gitlab.example.com
按照提示完成证书的获取和配置。
配置邮件服务: 配置SMTP服务器以发送电子邮件通知:
gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.example.com"
gitlab_rails['smtp_port'] = 587
gitlab_rails['smtp_user_name'] = "your-email@example.com"
gitlab_rails['smtp_password'] = "your-password"
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['smtp_tls'] = false
gitlab_rails['gitlab_email_from'] = "your-email@example.com"
然后重载配置:
docker exec -t gitlab gitlab-ctl reconfigure
gitlab-ctl restart
安全性: 确保你的GitLab实例配置了适当的安全措施,如禁用不必要的服务、启用SSH密钥认证等。
性能优化: 根据你的服务器资源情况,可能需要调整GitLab的内存和CPU限制。
通过以上步骤,你应该能够在CentOS上成功部署并运行GitLab容器化应用。如果在部署过程中遇到任何问题,可以参考GitLab的官方文档或寻求社区帮助。