一、前言

1、本文次要内容

  • GitLab社区版部署
  • GitLab配置禁用创立组权限
  • GitLab配置邮件(SMTP)
  • Gitlab备份配置
  • GitLab常用命令阐明

    2、GitLab介绍

    GitLab一个开源的git仓库治理平台,不便团队合作开发、治理。在GitLab上能够实现残缺的CI(继续集成)、CD(继续公布)流程。而且还提供了收费应用的Plan,以及收费的能够独立部署的社区版本(https://gitlab.com/gitlab-org/gitlab-ce )。官网:https://about.gitlab.com/

    二、筹备工作

    1、安准根底依赖(这一步根本都能够跳过,很多服务器默认装置)

    #装置技术依赖sudo yum install -y curl policycoreutils-python openssh-server#启动ssh服务&设置为开机启动sudo systemctl enable sshdsudo systemctl start sshd

    2、装置Postfix

    Postfix是一个邮件服务器,GitLab发送邮件须要用到

    #装置postfixsudo yum install -y postfix#启动postfix并设置为开机启动sudo systemctl enable postfixsudo systemctl start postfix

    3、凋谢ssh以及http服务

    依据理论状况执行,公司外部服务器初始时,防火墙就没关上

    #凋谢ssh、http服务sudo firewall-cmd --add-service=ssh --permanentsudo firewall-cmd --add-service=http --permanent#重载防火墙规定sudo firewall-cmd --reload

    三、部署过程

    本次咱们部署的是社区版:gitlab-ce,如果要部署商业版能够把关键字替换为:gitlab-ee

    1、Yum装置GitLab

  • 增加GitLab社区版Package

    curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash 
  • 装置GitLab社区版

    sudo yum install -y gitlab-ce 

    装置胜利后会看到gitlab-ce打印了以下图形

异样解决:

呈现“policycoreutils-python is needed by问题”,应该是在装置gitlab时,gitlab的版本是centos7的,如果你确定你的centos版本是centos7

解决办法

sudo yum installpolicycoreutils-python

如果这个办法有效,你的centos版本肯定不是centos7
如果你的centos版本是centos8.那么换一个gitlab版本,也就是从新下载一个,这里是最新地址

https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el8/

下载命令:

wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el8/gitlab-ce-12.10.1-ce.0.el8.x86_64.rpm

装置:

sudo rpm -i gitlab-ce-12.10.1-ce.0.el8.x86_64.rpm

若呈现谬误“policycoreutils-python-utils is needed by gitlab-ce-12.10.1-ce.0.el8.x86_64”
解决办法:

sudo yum install policycoreutils-python-utils

而后重新安装。

参考:https://blog.csdn.net/fu18838928050/article/details/107901895

2、配置GitLab站点Url

GitLab默认的配置文件门路是/etc/gitlab/gitlab.rb
默认的站点Url配置项是:

external_url 'http://gitlab.example.com'

这里我将GitLab站点Url批改为"external_url 'http://192.168.0.80:9000"
也能够用IP代替域名,这里依据本人需要来即可

#批改配置文件sudo vi /etc/gitlab/gitlab.rb#配置首页地址(大概在第15行)external_url 'http://192.168.0.80:9000'

3、启动并拜访GitLab

  • 启动GitLab

    #重新配置并启动sudo gitlab-ctl reconfigure#实现后将会看到如下输入Running handlers completeChef Client finished, 432/613 resources updated in 03 minutes 43 secondsgitlab Reconfigured!
  • 拜访GitLab

将设置的域名DNS解析到服务器IP,或者批改本地host将域名指向服务器IP。
拜访:http://192.168.0.80:9000

这时候会提醒为管理员账号设置明码。管理员账号默认username是root。
设置实现之后即可应用root账号登录,登陆后会进入欢送界面。

四、GitLab罕用配置

1、邮件配置

配置邮箱能够让GitLab在产生相应事件的时候进行邮件告诉
比方配置腾讯企业邮箱如下:

gitlab_rails['smtp_enable'] = truegitlab_rails['smtp_address'] = "smtp.exmail.qq.com"gitlab_rails['smtp_port'] = 465gitlab_rails['smtp_user_name'] = "你的邮箱"gitlab_rails['smtp_password'] = "你的邮箱明码"gitlab_rails['smtp_domain'] = "exmail.qq.com"gitlab_rails['smtp_authentication'] = "login"gitlab_rails['smtp_enable_starttls_auto'] = truegitlab_rails['smtp_tls'] = truegitlab_rails['gitlab_email_from'] = '你的邮箱'

具体参考:
https://docs.gitlab.com/omnibus/settings/smtp.html

2、禁用创立组权限

GitLab默认所有的注册用户都能够创立组。但对于团队来说,通常只会给Leader相干权限。
尽管能够在用户治理界面勾销权限,但毕竟不不便。咱们能够通过配置GitLab默认禁用创立组权限。

#批改配置文件sudo vi /etc/gitlab/gitlab.rb#开启gitlab_rails['gitlab_default_can_create_group'] 选项,并将值设置为false### GitLab user privilegesgitlab_rails['gitlab_default_can_create_group'] = false#保留后,重新配置并启动GitLabsudo gitlab-ctl reconfigure

3.配置代码地位

找到git_data_dirs 选型,配置地址

git_data_dirs({   "default" => {     "path" => "/data/tools/gitlab/data"    }})

参考链接:https://docs.gitlab.com/omnibus/settings/configuration.html

4.gitlab 备份

1)批改配置文件

# 关上gitlab配置文件vim /etc/gitlab/gitlab.rb#设置备份文件的保留地位gitlab_rails['backup_path'] = "/data/tools/gitlab/backup"#设置备份文件的过期工夫,单位为秒,默认7天gitlab_rails['backup_keep_time'] = 604800

执行wq保留后,刷新配置

gitlab-ctl reconfigure

2)执行备份命令验证

执行备份命令,去对应的文件门路查看是否曾经创立了备份文件

gitlab-rake gitlab:backup:create

执行打印如下:

红色字体形容为 gitlab.rb 和gitlab-secrets.json为敏感文件须要手动备份

3)通过cron定时备份

办法1、在命令行输出: crontab -e 而后增加相应的工作,wq存盘退出。

#输出命令crontab -ecrontab -e  #输出相应的工作0 2 * * * /opt/gitlab/bin/gitlab-rake gitlab:backup:create CRON=1  

办法2、间接编辑/etc/crontab 文件,即vim /etc/crontab,而后增加相应的工作

# edited by ouyang 2017-8-11 增加定时工作,每天凌晨两点,执行gitlab备份0  2    * * *   root    /opt/gitlab/bin/gitlab-rake gitlab:backup:create CRON=1

重启cron服务

systemctl restart crond.service

5.gitlab-ctl常用命令介绍

命令阐明
check-config查看在gitlab中是否有任何配置。在指定版本中删除的rb
deploy-page装置部署页面
diff-config将用户配置与包可用配置进行比拟
remove-accounts删除所有用户和组
upgrade降级
service-list查看所有服务
once如果GitLab服务进行了就启动服务,如果已启动就不做任何操作
restart重启GitLab服务
start如果GitLab服务进行了就启动服务,如果已启动就重启服务
stop进行GitLab服务
status查看GitLab服务状态
reconfigurereconfigure重新配置GitLab并启动

参考链接:
https://ken.io/note/centos7-gitlab-install-tutorial