一、gitlab部署
1.参考网站
2.部署步骤:
2.1. Install and configure the necessary dependencies
sudo yum install curl openssh-server openssh-clients postfix cronie
sudo service postfix start
sudo chkconfig postfix on
sudo lokkit -s http -s ssh
2.2 Add the GitLab package server and install the package
yum clean all
新建 /etc/yum.repos.d/gitlab-ce.repo,内容为
touch /etc/yum.repos.d/gitlab-ce.repo
你的CentOS/RHEL版本:
[gitlab-ce]
name=gitlab-ce
baseurl=
repo_gpgcheck=0
gpgcheck=0
enabled=1
gpgkey=
再执行
sudo yum makecache
sudo yum install gitlab-ce
清华大学 TUNA 协会最初叫清华
或者RPM包安装
rpm -ivh gitlab-ce-8.6.5-ce.0.el6.x86_64.rpm
2.3Configure and start GitLab
sudo gitlab-ctl reconfigure
2.4Browse to the hostname and login
------------------------------------------------------------------------------------------------------------------------------------------------------
安装后的配置文件目录:
主文件:/etc/gitlab/
主配置文件:/var/opt/gitlab/
/opt/gitlab/
日志目录:/var/log/gitlab/
二、目录以及备份迁移
1. 安装和配置必要的依赖关系Install and configure the necessary dependencies
如果你安装postfix发送邮件,请选择“网站设置”中。而不是使用后缀也可以用邮件或 配置自定义SMTP服务器。如果你想使用的进出口,请 配置为SMTP服务器。
在CentOS7,下面的命令将在系统防火墙打开HTTP和SSH访问。
yum install curl openssh-server postfix
systemctl enable sshd postfix
systemctl start sshd postfix
firewall-cmd –permanent –add-service=http
systemctl reload firewalld
2. 添加gitlab包服务器安装包Add the GitLab package server and install the package
curl -sS | sudo bash
yum install gitlab-ce
3. 配置并启动gitlab Configure and start GitLab
gitlab-ctl reconfigure
gitlab-ctl status
gitlab-ctl stop
gitlab-ctl start
这个是如何备份
备份和恢复omnibus-gitlab配置
创建一个应用程序备份
恢复备份的应用程序
使用non-packaged数据库备份和恢复
上传备份到远程存储(云)
手动管理备份目录
基本上都在/var/opt/gitlab/
Gitlab 创建备份
使用Gitlab一键安装包安装Gitlab非常简单, 同样的备份恢复与迁移也非常简单. 使用一条命令即可创建完整的Gitlab备份:
gitlab-rake gitlab:backup:create
使用以上命令会在/var/opt/gitlab/backups目录下创建一个名称类似为1393513186_gitlab_backup.tar的压缩包, 这个压缩包就是Gitlab整个的完整部分, 其中开头的1393513186是备份创建的日期.
Gitlab 修改备份文件默认目录
你也可以通过修改/etc/gitlab/gitlab.rb来修改默认存放备份文件的目录:
gitlab_rails['backup_path'] = '/mnt/backups'
/mnt/backups修改为你想存放备份的目录即可, 修改完成之后使用gitlab-ctl reconfigure命令重载配置文件即可.
Gitlab 自动备份
也可以通过crontab使用备份命令实现自动备份:
sudo su -
crontab -e
加入以下, 实现每天凌晨2点进行一次自动备份:
0 2 * * * /opt/gitlab/bin/gitlab-rake gitlab:backup:create
Gitlab 恢复
同样, Gitlab的从备份恢复也非常简单:
# 停止相关数据连接服务
gitlab-ctl stop unicorn
gitlab-ctl stop sidekiq
# 从1393513186编号备份中恢复
gitlab-rake gitlab:backup:restore BACKUP=1393513186# 启动Gitlab
sudo gitlab-ctl start
Gitlab迁移
迁移如同备份与恢复的步骤一样, 只需要将老服务器/var/opt/gitlab/backups目录下的备份文件拷贝到新服务器上的/var/opt/gitlab/backups即可(如果你没修改过默认备份目录的话). 但是需要注意的是新服务器上的Gitlab的版本必须与创建备份时的Gitlab版本号相同. 比如新服务器安装的是最新的7.60版本的Gitlab, 那么迁移之前, 最好将老服务器的Gitlab 升级为7.60在进行备份.
其他
最新版本的Gitlab已经修复了HTTPS设备的BUG, 现在使用官方HTTPS配置即可轻松启用HTTPS.
还有一个方法,是找到备份出来的tar文件,然后解压后,编辑backup_information.yml文件,将
:gitlab_version: 8.4.1 改成 :gitlab_version: 8.6.0 ,然后重新打包(记得打包名字和之前备份的要一样,如果是在备份目录重新打包,记得将原备份文件改名)。之后运行还原就可以。
三、gitlab升级
gitlab升级:
注意事项,不要停止服务,
yum update gitlab-ce
四、https配置
mkdir -p /etc/gitlab/ssl
chmod 700 /etc/gitlab/ssl
在目录/etc/gitlab/下生产如下两个文件
openssl req -new -x509 -nodes -days 3560 -out gitlab.crt -keyout gitlab.key
执行后他会提示你注册一些 国家 省市 公司 邮件的信息
cp gitlab.example.com.key gitlab.example.com.crt /etc/gitlab/ssl/
然后在/etc/gitlab/gitlab.rb里配置
external_url ""
nginx['redirect_http_to_https'] = true
nginx['ssl_certificate'] = "/etc/gitlab/ssl/gitlab.crt"
nginx['ssl_certificate_key'] = "/etc/gitlab/ssl/gitlab.key"
重启配置
[ gitlab]# gitlab-ctl reconfigure
客户端
如果你用的自己生成的非授权KEY 每个客户端都得执行这条命令去关闭 官方授权
先 git -c http.sslVerify=false clone
然后git config http.sslVerify false
git学习参考资料