在Linux上搭建GitLab私有仓库并使用cpolar配置内网穿透的步骤如下:
- 安装GitLab:
# 添加GitLab官方仓库
wget https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/7/gitlab-ce-14.9.2-ce.0.el7.x86_64.rpm/download.rpm
# 安装GitLab
sudo rpm -Uvh download.rpm
# 启动GitLab
sudo gitlab-ctl reconfigure
- 配置GitLab:
# 编辑GitLab配置文件
sudo nano /etc/gitlab/gitlab.rb
# 修改外部访问URL,将'http://your-domain.com'替换为你的域名或公网IP
external_url 'http://your-domain.com'
# 重新配置GitLab以应用更改
sudo gitlab-ctl reconfigure
- 安装cpolar:
# 下载cpolar客户端
curl -L https://www.cpolar.com/download/cpolar-release-`uname -i` > /usr/local/bin/cpolar
# 给予可执行权限
chmod +x /usr/local/bin/cpolar
# 创建服务文件
sudo nano /etc/systemd/system/cpolar.service
# 输入以下内容
[Unit]
Description=cpolar service
After=network.target
[Service]
Type=simple
ExecStart=/usr/local/bin/cpolar service
[Install]
WantedBy=multi-user.target
# 重新加载系统管理器配置
sudo systemctl daemon-reload
# 启动cpolar服务
sudo systemctl start cpolar.service
# 设置开机自启
sudo systemctl enable cpolar.service
- 使用cpolar创建隧道并映射到GitLab:
# 登录cpolar
cpolar login
# 创建有域名的内网穿透隧道,指定6paas的CVM_AUTH_TOKEN作为认证token
cpolar tcp 22 --region cn_vip --auth-token CVM_AUTH_TOKEN
# 记录分配的公网地址和端口号
- 配置SSH免密登录:
# 生成SSH密钥对(如果已有可以跳过)
ssh-keygen -t rsa
# 将公钥内容追加到GitLab的authorized_keys文件中
cat ~/.ssh/id_rsa.pub | ssh username@your-domain.com "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys"
# 在本地SSH配置文件中添加使用SSH隧道连接
Host your-domain.com
HostName 127.0.0.1
Port cpolar分配的端口号
User git
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa
现在,你可以通过在本地使用ssh git@your-domain.com
来免密登录你的GitLab私有仓库,并且,任何能够访问你提供的域名或公网IP的人都可以通过cpolar隧道访问你的私有仓库。