• 【GitLab私有仓库】在Linux上用Gitlab搭建自己的私有库并配置cpolar内网穿透


    前言

    GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的Web服务。

    Gitlab是被广泛使用的基于git的开源代码管理平台, 基于Ruby on Rails构建, 主要针对软件开发过程中产生的代码和文档进行管理, Gitlab主要针对group和project两个维度进行代码和文档管理, 其中group是群组, project是工程项目, 一个group可以管理多个project, 可以理解为一个群组中有多项软件开发任务, 而一个project中可能包含多个branch, 意为每个项目中有多个分支, 分支间相互独立, 不同分支可以进行归并。

    下面我们通过在Linux centOS8 中搭建GitLab私有仓库并且结合Cpolar内网穿透工具,实现在公网环境下也可以访问私有仓库Gitlab。

    1. 下载Gitlab

    在系统中创建一个目录,名字叫GitLab,存放下载的安装包

    mkdir /usr/local/gitlab
    
    • 1

    进入创建的目录

    cd /usr/local/gitlab
    
    • 1

    下载Gitlab安装包,等待下载完成

    wget --content-disposition https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/8/gitlab-ce-15.0.2-ce.0.el8.x86_64.rpm/download.rpm
    
    • 1

    1678717872337

    2. 安装Gitlab

    下载成功后,开始安装Gitlab,首先安装一个工具包,时间很长,等待安装完成:

    yum install  policycoreutils-python-utils
    
    • 1

    1678720861569

    然后安装Gitlab,进去我们上面创建的/usr/local/gitlab目录下执行:

    rpm -Uvh gitlab-ce-15.0.2-ce.0.el8.x86_64.rpm
    
    • 1

    1678721095616

    安装完成后,更新配置,稍微需要点时间,耐心等待一下,完成后,我们可以看到用户名和密码

    gitlab-ctl reconfigure 
    
    • 1

    以下信息我们可以看到用户名和密码,用户名为:root,密码需要单独查看

    1678721702117

    上面那个路径就是密码路径,查看密码:

    cat /etc/gitlab/initial_root_password
    
    • 1

    1678721881291

    3. 启动Gitlab

    测试启动,没有出错表示成功

    gitlab-ctl start
    
    • 1

    1678722005864

    然后修改访问地址,编辑Gitlab配置文件,

    vim /etc/gitlab/gitlab.rb
    
    • 1

    把external_url的值换成http://127.0.0.1:8088,端口号可以自己指定,这里指定8088,然后保存

    image-20230314003117292

    修改完后重新加载配置文件

    gitlab-ctl reconfigure
    
    • 1

    然后重新启动Gitlab

    sudo gitlab-ctl restart
    
    • 1

    如果有防火墙,添加防火墙端口:8088

    firewall-cmd --zone=public --add-port=8088/tcp --permanent
    
    • 1

    然后打开浏览器,输入Linux 局域网ip+8088,即可访问成功

    1678725368861

    输入上面的用户名:root 和上面查看的密码即可登录成功啦

    1678725526795

    4. 安装cpolar

    上面我们在本地Linux虚拟机安装了Gitlab,下面我们安装cpolar内网传统工具,通过cpolar的http公网地址,我们可以很容易远程也可以访问GitLab,而无需自己注册域名.下面是安装cpolar步骤

    • 使用一键脚本安装命令
    curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
    
    • 1
    • token认证

    登录cpolar官网后台,点击左侧的验证,查看自己的认证token,之后将token贴在命令行里:

    cpolar authtoken xxxxxxx
    
    • 1

    20230206171248

    • 向系统添加服务,将cpolar配置为开机自启
    sudo systemctl enable cpolar
    
    • 1
    • 启动cpolar服务
    sudo systemctl start cpolar
    
    • 1

    5. 创建隧道配置访问地址

    成功启动cpolar服务后,我们在浏览器上访问Linux局域网ip地址+9200端口,登录cpolar web UI管理界面。

    登录成功后,点击左侧仪表盘的隧道管理——创建隧道,创建一个http协议的隧道指向上面设置的8088端口:

    • 隧道名称:可自定义,注意不要与已有的隧道名称重复
    • 协议:http
    • 本地地址:8088
    • 域名类型:免费选择随机域名
    • 地区:选择China VIP

    点击创建

    1678724119867

    然后打开在线隧道列表,查看并且复制公网地址

    1678724278844

    然后打开浏览器,输入公网地址,即可访问成功

    1678725654998

    6. 固定GitLab访问地址

    由于刚刚创建隧道使用的是随机临时地址,该地址会在24小时内发生变化,为了长期远程访问,我们接下来将这个公网地址配置为固定的。

    6.1 保留二级子域名

    需升级至基础套餐或以上才支持配置二级子域名

    登录cpolar官网后台,点击左侧仪表盘的预留,找到保留二级子域名,为http隧道保留一个二级子域名。

    • 地区:选择服务器地区
    • 名称:填写您想要保留的二级子域名(可自定义)
    • 描述:即备注,可自定义填写

    1678725876220

    本例保留一个名称为gitlabTest的二级子域名。子域名保留成功后,我们将子域名复制下来,接下来需要将其配置到隧道中去。

    1678725912846

    6.2 配置二级子域名

    登录cpolar web ui管理界面。点击左侧仪表盘的隧道管理——隧道列表,找到需要配置二级子域名的隧道,点击右侧的编辑

    1678725955880

    修改隧道信息,将二级子域名配置到隧道中:

    • 域名类型:改为选择二级子域名
    • Sub Domain:填写我们刚刚所保留的二级子域名(本例为gitlabTest

    修改完成后,点击更新

    1678725995744

    隧道更新成功后,点击左侧仪表盘的状态——在线隧道列表,可以看到隧道的公网地址,已经更新为二级子域名了,将公网地址复制下来。

    1678726056852

    7. 测试访问二级子域名

    打开浏览器,我们来测试一下访问配置成功的二级子域名,测试成功,可以正常访问。现在,我们全网唯一的私有二级子域名,就创建好了。 而且这个地址也不会再随机变化,他是固定不变的,只要保持隧道在线,我们在外就可以通过这个公网地址,随时随地远程访问,无需公网IP,也不用设置路由器。

    1678726105739

  • 相关阅读:
    区块链技术的应用场景和优势
    对于电商API接口详情问题-淘宝/天猫的介绍
    部署zabbix5.4
    【项目笔记】物联网并发5000+Qps (理论上连接百万级设备)搭建全解
    《向量数据库指南》——向量数据库Milvus Cloud如何面对市场质疑?
    K8s - 安装部署Kafka、Zookeeper集群教程(支持从K8s外部访问)
    安森美LM317全系列低压差线性稳压器(LDO)多种不同封装类型 高性能更可靠
    Linux 内核打印(高级字符设备六)
    数据结构刷题——dfs
    应收和应付会计岗位自动化:多重赋能,为企业提效300%,让劳动更具价值
  • 原文地址:https://blog.csdn.net/xinhang10/article/details/132702048