GitLab是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务,可以通过web界面,进行访问公开的或者私人项目,它有和Github类似的功能,能够浏览源代码,管理缺陷和注释,可以观念里团队对仓库的访问,它非常已于浏览提交过的版本并提供一个文件历史库,团队成员可以利用内置的简单聊天程序(Wall)进行交流,它还提供一个代码片段收集功能可以轻松实现代码复用。
官网:https://about.gitlab.com/
国内镜像:https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/
环境准备
一、安装环境
1、Centos7.9
2、2G内存(测试),生产至少需要4G
3、安装包:gitlab-ce-10.2.2-ce.0.el7.x86_64.rpm(下载连接放在文末)
4、禁用防火墙,关闭selinux
二、安装GitLab
可以官网下载,也可以选择安装rpm包(下载链接放在文末)
[root@Gitlab ~]# yum -y install policycoreutils-python #安装依赖
[root@Gitlab ~]# rpm -ivh gitlab-ce-10.2.2-ce.0.el7.x86_64.rpm #安装软件包
vim /etc/gitlab/gitlab.rb # gitlab 配置文件
更改url地址为本机IP地址 external_url 'http://10.0.0.200'
gitlab-ctl reconfigure # 更改配置文件后需重新配置
/opt/gitlab/ # gitlab的程序安装目录
/var/opt/gitlab # gitlab目录数据目录
/var/opt/gitlab/git-dfata # 存放仓库数据
gitlab-ctl status # 查看目前gitlab所有服务运维状态
gitlab-ctl stop # 停止gitlab服务
gitlab-ctl stop nginx # 单独停止某个服务
gitlab-ctl tail # 查看所有服务的日志
GitLab的服务构成:
nginx: 静态web服务器
gitlab-workhorse: 轻量级的反向代理服务器
logrotate:日志文件管理工具
postgresql:数据库
redis:缓存数据库
sidekiq:用于在后台执行队列任务(异步执行)。(Ruby)
unicorn:An HTTP server for Rack applications,GitLab Rails应用是托管在这个服务器上面的。(Ruby Web Server,主要使用Ruby编写)
GitLab汉化
直接访问10.0.0.200,显示英文界面
1、下载汉化补丁
[root@Gitlab ~]# git clone git@gitlab.com:xhang/gitlab.git #需要先做免密钥
将Gitlab主机上的公钥复制到gitlab官网(https://gitlab.com)自己的账号配置中
用http下载方式理论上也可以,但是我这边测试下载不上
2、查看全部分支版本
[root@Gitlab gitlab]# git branch -a #需要在安装好的gitlab目录下
3、对比版本、生成补丁包
[root@Gitlab gitlab]# git diff remotes/origin/10-2-stable remotes/origin/10-2-stable-zh > ../10.2.2-zh.diff
[root@Gitlab gitlab]# cd ..
[root@Gitlab ~]# ls
10.2.2-zh.diff gitlab gitlab.bak gitlab-ce-10.2.2-ce
4、停止服务器
gitlab-ctl stop
5、打补丁
[root@Gitlab ~]# patch -d /opt/gitlab/embedded/service/gitlab-rails -p1 < 10.2.2-zh.diff
6、启动和重新配置
gitlab-ctl start
gitlab-ctl reconfigure
再次访问显示中文界面
GitLab配置使用
首次登录需要先配置下密码,最短八位,登录用户名为root,密码是自己配置的密码
一、配置外观
配置好后登录界面会被修改
登录进去后左上角进行了更改
二、关闭自动注册
根据实际需求操作,如果是内网,取不取消无所谓,如果有公网,被人发现了随意注册就可以登录我们的gitlab了,很危险。
取消后下滑保存
三、创建群组、用户
创建群组
创建用户
创建好后点编辑,在此处添加用户密码
四、把用户添加进组里面
五、创建仓库(项目)
六、登录koten用户测试是否能看到空的test仓库
浏览器开隐私模式,首次登录koten用户需要修改密码,也可以原密码与新密码一致
七、添加ssh-keys到GitLab
一个服务器的key,只能添加到一个gitlab服务器上,一个用户可以添加多个key
八、添加远程仓库,推送本地代码到远程仓库
[root@Gitlab ~]# mkdir git_test
[root@Gitlab ~]# cd git_test
[root@Gitlab git_test]# git init #初始化git仓库
Initialized empty Git repository in /root/git_test/.git/
[root@Gitlab git_test]# git remote add origin git@10.0.0.200:koten_group/test.git #添加远程仓库
[root@Gitlab git_test]# git checkout -b master #创建本地master分支
Switched to a new branch 'master'
[root@Gitlab git_test]# git remote rename origin koten-origin #更改origin名字
[root@Gitlab git_test]# touch 1.txt
[root@Gitlab git_test]# git add . #添加项目到缓存区
[root@Gitlab git_test]# git commit -m "file 1.txt" #添加项目到本地仓库
[master (root-commit) e364410] file 1.txt
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 1.txt
[root@Gitlab git_test]# git push -u koten-origin master #推送本地仓库至远程仓库
Counting objects: 3, done.
Writing objects: 100% (3/3), 199 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To git@10.0.0.200:koten_group/test.git
* [new branch] master -> master
Branch master set up to track remote branch master from koten-origin.
刷新可以看到远程仓库的文件
九、克隆代码到另一台主机,并测试推送
如果不做认证会让输入gitlab的密码,我们使用key进行认证
[root@Web01 ~]# ssh-keygen
[root@Web01 ~]# cat .ssh/id_rsa.pub #复制进koten用户的ssh密钥
克隆代码
[root@Web01 git_test]# git config --global user.email "you@example.com"
[root@Web01 git_test]# git config --global user.name "Your Name"
[root@Web01 ~]# mkdir git_test
[root@Web01 ~]# cd git_test
[root@Web01 git_test]# git init
Initialized empty Git repository in /root/git_test/.git/
[root@Web01 git_test]# git clone git@10.0.0.200:koten_group/test.git #克隆远程仓库代码
Cloning into 'test'...
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (3/3), done.
[root@Web01 git_test]# tree
.
└── test
└── 1.txt
1 directory, 1 file
推送代码
[root@Web01 git_test]# git branch dev
[root@Web01 git_test]# git checkout dev
[root@Web01 git_test]# touch dev_test
[root@Web01 git_test]# git add .
[root@Web01 git_test]# git commit -m "add dev_test"
[dev cac97e4] add dev_test
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 dev_test
[root@Web01 git_test]# git remote add origin git@10.0.0.200:koten_group/test.git #添加远程仓库
[root@Web01 git_test]# git push -u origin dev #推送dev分支到远程仓库
Counting objects: 5, done.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (5/5), 464 bytes | 0 bytes/s, done.
Total 5 (delta 0), reused 0 (delta 0)
remote:
remote: To create a merge request for dev, visit:
remote: http://10.0.0.200/koten_group/test/merge_requests/new?merge_request%5Bsource_branch%5D=dev
remote:
To git@10.0.0.200:koten_group/test.git
* [new branch] dev -> dev
Branch dev set up to track remote branch dev from origin.
十、合并分支请求
首次可以在右上角点击创建合并请求
由于dev是给的身份是开发人员有自主接受合并请求的权限,如果我们给的身份是记者,就需要在root账号下去管理,接受请求,如果master分支被保护,我们也需要通过root进行接受请求
合并后虽然root端远程仓库可以显示合并的文件,但是在gitlab本地仓库没有,我们可以pull更新下仓库
[root@Gitlab git_test]# ls
1.txt
[root@Gitlab git_test]# git pull
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (6/6), done.
remote: Total 6 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (6/6), done.
From 10.0.0.200:koten_group/test
e364410..600d0ef master -> koten-origin/master
Updating e364410..600d0ef
Fast-forward
dev | 0
dev_test | 0
test | 1 +
3 files changed, 1 insertion(+)
create mode 100644 dev
create mode 100644 dev_test
create mode 160000 test
[root@Gitlab git_test]# ls
1.txt dev dev_test test
十一、设置保护主分支
我们可以给master设置为保护,这样除了root用户外,其他用户不能将代码直接推送至主分支
[root@Web01 git_test]# git checkout master #切换到master分支
Switched to branch 'master'
[root@Web01 git_test]# git merge dev #合并dev分支
Updating 53298b6..cac97e4
Fast-forward
dev_test | 0
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 dev_test
[root@Web01 git_test]# git push -u origin master #推送主分支
To git@10.0.0.200:koten_group/test.git
! [rejected] master -> master (fetch first)
error: failed to push some refs to 'git@10.0.0.200:koten_group/test.git'
hint: Updates were rejected because the remote contains work that you do
hint: not have locally. This is usually caused by another repository pushing
hint: to the same ref. You may want to first merge the remote changes (e.g.,
hint: 'git pull') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.
十二、root端测试推送保护的分支
#由于其他分支进行推送,和master端内容不一致,所以无法进行推送,使用git pull把代码拉取到本地,或者git fetch 把代码拉取到本地仓库后进行合并(注意:git pull = git tetch+git merge)
[root@Gitlab git_test]# git push -u koten-origin master
Branch master set up to track remote branch master from koten-origin.
Everything up-to-date
GitLab备份
对gitlab进行备份将会创建一个包含所有库和附件的归档文件。对备份的恢复只能恢复到与备份时的gitlab相同的版本。将gitlab迁移到另一台服务器上的最佳方法就是通过备份和还原。
gitlab提供了一个简单的命令行来备份整个gitlab,并且能灵活的满足需求。
备份文件将保存在配置文件中定义的backup_path中,文件名为TIMESTAMP_gitlab_backup.tar,TIMESTAMP为备份时的时间戳。TIMESTAMP的格式为:EPOCH_YYYY_MM_DD_Gitlab-version。
如果自定义备份目录需要赋予git权限
配置文件/etc/gitlab/gitlab.rb 中加入
gitlab_rails['backup_path'] = '/data/backup/gitlab'
gitlab_rails['backup_keep_time'] = 604800 备份保留的时间(以秒为单位,这个是七天默认值),
mkdir -p /data/backup/gitlab
chown -R git.git /data/backup/gitlab
完成后执行
gitlab-ctl reconfigure
gitlab rpm包下载连接:链接:https://pan.baidu.com/s/1WCXrPxDzEchFys4i7kjr8A?pwd=q80w
我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!
---------------------
作者:我是koten
来源:CSDN
原文:https://blog.csdn.net/qq_37510195/article/details/130795169
版权声明:本文为作者原创文章,转载请附上博文链接!
内容解析By:CSDN,CNBLOG博客文章一键转载插件