CentOS7下Gitlab(开源代码管理平台) 使用心得

本文介绍了如何使用YUM安装GitLab,并提供了适用于国内用户的安装指南。同时,文章还分享了解决安装过程中的常见问题的经验,以及如何进行GitLab的无损迁移。
本文章仅作为个人笔记
Gitlab是一款非常好用且开源免费的git管理平台,非常适合创业公司用于代码管理,笔者在安装配置过程中遇到一些问题,及积累的一些经验特此记录,以备下次使用。
Gitlab官网:https://gitlab.com/
官方安装文档:https://about.gitlab.com/downloads/#centos7
国内用户建议安装文档:https://mirror.tuna.tsinghua.edu.cn/help/gitlab-ce/
本人使用国内文档方案:
  • 新建/etc/yum.repos.d/gitlab-ce.repo文件
  • 添加内容:
    [gitlab-ce]
    name=Gitlab CE Repository
    baseurl=https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el$releasever/
    gpgcheck=0
    enabled=1
  • 运行yum makecache更新加载yum源
  • 运行yum install gitlab-ce.x86_64完成安装Gitlab
  • 以上所述均为yum安装方案,本人不建议使用rpm安装,这样在Gitlab的升级方面非常吃力(ps:yum升级简单粗暴),重要的是Gitlab不支持跨版本恢复数据,这种情况下yum可以很好的完成版本一致并无损迁移(无数据迁移需求自动忽略)。
  • 安装完成后可先编辑/etc/gitlab/gitlab.rb文件更改默认域名及邮箱配置,如:(external_url ‘http://git.temp.com‘)等…..
  • 创建自己的项目后会生成一个项目的git及http地址,为了保证此地址有效,此时应设置cd /opt/gitlab/embedded/service/gitlab-rails/config文件内的host选项(初始值为服务器名称),使其为域名或您的ip地址。
  • 觉得配置的差不多了,可以运行 gitlab-ctl reconfigure 进行初始化(Gitlab默认占用80,8060端口),若在使用Gitlab前已经有服务使用过此端口,特别是已经有自己的nginx占用80端口的,可在/var/opt/gitlab/nginx/conf目录下更改gitlab-http.conf文件更改nginx配置(nginx配置不熟悉的自行脑补),8060端口为此目录下nginx-status.conf文件,不建议使用自己的nginx完全替代Gitlab自带nginx,这样可能会有其他一些问题出现,笔者就曾出现502错误,最终将原有nginx配置复制一份放置于Gitlab的nginx下导入使用。另外笔者在另一个Centos系统下运行gitlab-ctl reconfigure遇到另一个奇葩的问题,有人说是源的问题,为此笔者特地翻墙下了官方的镜像安装,但依然出现同样的问题,好的是有临时解决方案且再执行gitlab-ctl reconfigure未再出现。此问题是:运行时卡死在ruby_block[supervise_redis_sleep] action run,笔者的解决方案是再开一个ssh窗口执行GitLab-ctl start,这样会发现之前的窗口继续往下走了。后面就正常了。
  • 至此Gitlab安装配置完成。
  • 运行一段时间后准备在此服务器上加其他服务,发现以前的服务器(2核CPU/2G运行内存/20G硬盘)隐隐有些不够用,且由于其他资费等问题准备切换服务器,这个时候就涉及到Gitlab的无损迁移问题了,好在Gitlab本身是带这个功能的(笔者使用的是9.1.3版本及8.*版本)。
  • 先上官方的详细文档链接:https://docs.gitlab.com
  • 运行gitlab-rake gitlab:backup:create即可完成Gitlab的完整备份,此时会生成一个*.gitlab_backup.tar文件于/var/opt/gitlab/backups文件夹下,将此文件发送至迁移的服务器同目录下(要先在迁移的服务器安装同一版本,同一版本,同一版本Gitlab),发送完,在迁移服务器运行gitlab-rake gitlab:backup:restore(即可完成数据无损迁移,运行前保证迁移服务器backups目录下只存在一个备份文档,否则需要指定版本,如:gitlab-rake gitlab:backup:restore BACKUP=1393513186),运行完恢复操作,可运行gitlab-rake gitlab:check命令对整个Gitlab进行检测,若检测出问题,一般输出的log会打印相应的解决方案。当初步检测两个服务器的数据(用户,仓库,权限)等一致时,只需更改以前的服务器的域名解析改为当前服务器的ip即可完成无缝切换(Gitlab用户无需做任何操作)。
  • Gitlab升级:yum update gitlab-ce.x86_64
  • Gitlab操作相关
    • gitlab-ctl restart # 重启gitlab服务
    • gitlab-ctl start # 启动gitlab服务
    • gitlab-ctl stop # 停止gitlab服务
  • 遇到的问题:
    • 某次升级后遇到git登陆后报500错误。各种百度后最终运行gitlab-rake db:migrate:status 发现很多数据库状态未down,此时再运行gitlab-rake db:migrate重建数据库,再运行gitlab-ctl restart即可解决此问题。
<think>好的,我现在需要在CentOS 7上安装和配置GitLab。首先,我应该从哪里开始呢?记得之前有看到过一些步骤,可能涉及添加仓库、安装包之类的。让我仔细想想。 首先,系统需要满足哪些要求?可能要有足够的存储空间和内存,GitLab比较占用资源。然后,可能需要安装一些依赖项,比如curl、policycoreutils之类的工具。对了,参考内容里的引用[2]提到用curl添加GitLab仓库,然后执行脚本。所以第一步应该是添加仓库。 接下来,安装GitLab社区版。引用[2]和引用[3]都提到了使用yum安装gitlab-ce。安装完成后,需要配置外部URL,比如设置external_url,这个在引用[3]和引用[4]里都有提到,可能需要修改/etc/gitlab/gitlab.rb文件。然后运行重新配置命令,比如gitlab-ctl reconfigure,这样配置才会生效。 然后,防火墙设置可能需要开放HTTP和HTTPS端口,或者自定义的端口,如引用[4]中的8888端口。CentOS 7用的是firewalld,所以要用firewall-cmd来开放端口,并重载防火墙规则。 安装完成后,如何访问呢?通过浏览器访问设置的external_url,第一次登录可能需要设置root密码。之后可以创建项目、用户,配置SSH密钥等,这些步骤在引用[1]里提到过。 另外,汉化的问题,引用[3]提到CentOS上安装和汉化GitLab服务器,但具体步骤可能没详细说明,可能需要下载汉化包替换文件,但用户可能不需要汉化,所以这部分可能可以省略,除非用户特别要求。 可能遇到的问题:安装过程中依赖项缺失,或者端口冲突。比如如果external_url的端口被占用,GitLab服务可能无法启动。这时候需要检查端口使用情况,或者修改配置中的端口号。 还有存储目录的设置,引用[4]里提到git_data_dirs,可以自定义仓库存储路径,避免默认路径空间不足的问题。这也是配置时需要注意的地方。 总结步骤大概是:安装依赖、添加仓库、安装包、配置external_url和存储路径、防火墙设置、启动服务、访问并初始化。需要按照这些步骤详细说明,同时引用相关的参考内容中的命令和配置。</think>### 逐步安装和配置 GitLab 的步骤 #### **1. 系统准备** - **要求**:确保系统内存≥4GB,磁盘空间≥10GB,并安装必要工具: ```bash sudo yum install -y curl policycoreutils-python openssh-server postfix sudo systemctl enable postfix sudo systemctl start postfix ``` #### **2. 添加 GitLab 仓库并安装** - 使用官方脚本添加仓库[^2]: ```bash curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash ``` - 安装 GitLab 社区版[^2][^3]: ```bash sudo yum install -y gitlab-ce ``` #### **3. 配置 GitLab** - 编辑配置文件 `/etc/gitlab/gitlab.rb`[^4]: ```ruby external_url 'http://<你的域名或IP>:端口' # 示例:external_url 'http://192.168.1.100:80' git_data_dirs({ "default" => { "path" => "/自定义/存储路径" } }) # 可选,修改仓库存储目录 ``` - 应用配置并启动服务: ```bash sudo gitlab-ctl reconfigure # 自动配置并启动所有组件 ``` #### **4. 防火墙设置** - 开放 HTTP/HTTPS 或自定义端口[^4]: ```bash sudo firewall-cmd --permanent --add-service=http sudo firewall-cmd --permanent --add-port=8888/tcp # 若使用自定义端口 sudo firewall-cmd --reload ``` #### **5. 访问 GitLab** - 通过浏览器访问 `http://<你的域名或IP>:端口`,首次登录需设置 root 用户密码。 - 登录后创建项目、添加 SSH 密钥或管理用户[^1]。 #### **6. 常用命令** - 启动/停止服务: ```bash sudo gitlab-ctl start # 启动 sudo gitlab-ctl stop # 停止 sudo gitlab-ctl restart # 重启 ``` --- ### **常见问题解决** 1. **端口冲突** - 修改 `external_url` 中的端口,并确保防火墙放行。 2. **磁盘空间不足** - 在配置中指定 `git_data_dirs` 到更大容量的目录。 3. **无法访问页面** - 检查服务状态:`sudo gitlab-ctl status` - 查看日志:`sudo journalctl -u gitlab-*` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值