写一个 适用于 Ubuntu 20.04/22.04 的 GitLab 一键部署脚本,包括:
安装依赖
安装 GitLab CE
配置公网 IP 或域名
自动开启 HTTPS(Let’s Encrypt)
配置防火墙
下面是完整脚本:
#!/bin/bash
# =========================
# GitLab 一键安装脚本
# =========================
# 1. 检查是否以 root 运行
if [ "$EUID" -ne 0 ]; then
echo "请使用 root 用户运行此脚本"
exit 1
fi
# 2. 更新系统
apt update && apt upgrade -y
# 3. 安装依赖
apt install -y curl openssh-server ca-certificates tzdata perl ufw
# 4. 配置防火墙
ufw allow http
ufw allow https
ufw allow OpenSSH
ufw --force enable
# 5. 安装 Postfix(用于邮件通知,可选)
debconf-set-selections <<< "postfix postfix/mailname string gitlab.example.com"
debconf-set-selections <<< "postfix postfix/main_mailer_type string 'Internet Site'"
apt install -y postfix
# 6. 添加 GitLab 仓库
curl -fsSL https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | bash
# 7. 设置外部 URL
read -p "请输入你的域名或公网 IP(例:http://gitlab.example.com 或 http://123.123.123.123): " EXTERNAL_URL
# 自动生成 GitLab 配置文件
export EXTERNAL_URL=$EXTERNAL_URL
# 8. 安装 GitLab
apt install -y gitlab-ce
# 9. 重新配置 GitLab
gitlab-ctl reconfigure
# 10. 自动启用 HTTPS(Let’s Encrypt)
read -p "是否启用 HTTPS(Let’s Encrypt)? [y/n]: " ENABLE_HTTPS
if [[ "$ENABLE_HTTPS" == "y" || "$ENABLE_HTTPS" == "Y" ]]; then
# 设置 GitLab 配置开启 Let's Encrypt
gitlab-ctl stop nginx
gitlab-ctl reconfigure
# 编辑配置文件启用 Let's Encrypt
GITLAB_CONFIG="/etc/gitlab/gitlab.rb"
sed -i "s|^# external_url '.*'|external_url 'https://$EXTERNAL_URL'|" $GITLAB_CONFIG
sed -i "s|^# letsencrypt\['enable'\] = false|letsencrypt['enable'] = true|" $GITLAB_CONFIG
# 重新配置
gitlab-ctl reconfigure
fi
# 11. 输出访问信息
echo "======================================"
echo "GitLab 安装完成!"
echo "访问地址: $EXTERNAL_URL"
echo "默认管理员账号: root"
echo "请首次访问设置管理员密码"
echo "======================================"
# 12. 查看服务状态
gitlab-ctl status
使用方法
新建一个脚本文件:
nano install_gitlab.sh
粘贴上面的内容,保存并退出。
赋予执行权限并运行:
chmod +x install_gitlab.sh
sudo ./install_gitlab.sh
按提示输入 公网 IP 或域名,选择是否开启 HTTPS。
这个脚本安装的是 GitLab CE 社区版,支持 HTTPS,防火墙也会自动配置好。