centos 7部署并汉化Gitlab及基础操作

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了centos 7部署并汉化Gitlab及基础操作相关的知识,希望对你有一定的参考价值。

Gitlab 是一个利用 Ruby on Rails 开发的开源应用程序,实现一个Git 项目仓库,可通过Web 界面进行访问公开的或者私人的项目 Gitlab 拥有与 Github 类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,他非常易于浏览提交过的版本并提供一个文件历史库。他还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。

关于gitlab的详细信息建议参考gitlab官网进行详细的了解!

博文大纲:
一、准备环境
二、安装Gitlab
三、汉化Gitlab
四、gitlab基本操作
五、远端库的基本操作
六、重置gitlab管理员密码

一、准备环境

操作系统 内存 CPU
centos 7 4G以上 双核

二、安装Gitlab

1)安装Gitlab所需依赖

[root@gitlab ~]# yum -y install  epel-release curl openssh-server openssh-clients postfix cronie policycoreutils-python

2)获取Gitlab的RPM软件包

方法一:通过清华大学的开源镜像站获取软件包(推荐)

[root@gitlab ~]# wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-12.3.5-ce.0.el7.x86_64.rpm

方法二:通过Gitlab官网来获取软件包(网络稳定时使用)

[root@gitlab ~]# wget --content-disposition https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/7/gitlab-ce-12.3.5-ce.0.el7.x86_64.rpm/download.rpm

3)安装Gitlab

[root@gitlab ~]# rpm -ivh gitlab-ce-12.3.5-ce.0.el7.x86_64.rpm 
#安装时间较长,耐心等待,安装过程中会出现gitlab的logo

4) 修改gitlab的url并执行reconfigure

[root@gitlab ~]# vim /etc/gitlab/gitlab.rb         #修改gitlab的配置文件
………………………………                 #省略部分内容
external_url ‘http://192.168.1.8‘                       #将此处改为本机的IP地址,便于访问
[root@gitlab ~]# gitlab-ctl reconfigure        #重新配置gitlab,就算不修改配置文件,也需要在安装后重新配置gitlab

5)web页面访问测试

如图:
技术图片
可以访问到表示没有问题,但是都是英文界面,对于英文不好的我表示很是头疼,还好可以通过一些方法使其汉化,方法如下!

三、汉化Gitlab

1)获取gitlab汉化补丁包(如果不需要汉化,则跳过此步骤即可)

[root@gitlab ~]# head -1 /opt/gitlab/version-manifest.txt           #查看gitlab的版本
gitlab-ce 12.3.5
[root@gitlab ~]# git clone https://gitlab.com/xhang/gitlab.git -b v12.3.5-zh
#获取汉化补丁包(注意需与gitlab的版本保持一致)
[root@gitlab ~]# cd gitlab/               #进入刚才clone下来的gitlab目录
[root@gitlab gitlab]# git diff v12.3.5 v12.3.5-zh > /root/v12.3.5-zh.diff
#用diff将英文原版与中文版的对比生成.diff文件

2)将中文补丁导入gitlab

[root@gitlab gitlab]# gitlab-ctl stop              #停止gitlab
[root@gitlab gitlab]# yum -y install patch
[root@gitlab gitlab]# patch -d /opt/gitlab/embedded/service/gitlab-rails -p1 <  ../v12.3.5-zh.diff
 #将刚才的diff文件做为补丁导入到gitlab中
#该命令执行过程中,一路回车跳过即可
[root@gitlab gitlab]# gitlab-ctl start                 #启动gitlab
[root@gitlab gitlab]# gitlab-ctl reconfigure      #重新配置gitlab

3)web页面再次访问

如图:
技术图片
技术图片
技术图片

四、gitlab基本操作

1)配置SSH方式免密登录

[root@gitlab ~]# ssh-keygen -t rsa -C "1454295320@qq.com"
#生成秘钥对,一路回车即可,“-C”后是自己的邮箱
[root@gitlab ~]# cat ~/.ssh/id_rsa.pub         #查看生成的公钥并复制 
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCvNm+nXc59ugb0SGr9iMHDSFjvmdSJk0ORuX3hbjt822Y2ofXysUrIuBSQ1Jn0Rss/LPU54K32i4bIDsa/jD9gIpN/GqU+YP1MQ9bEw3YVUONAs+nYeWJWahQ1rMTeM0HC9aKvNTrNsOqrXIboJymBrs6Odt+1NnZsYHMwA/KlpYCFsi0HQgBzsLbrD5v++cIDTvM/V4rMq6fqFsfWoYYMHWc8JeNMl/aWJV1RhJpt7wm17FEv3XiH+wyoef5ZYI60IkH5qMJkjWhKcRXCWG5SH3nphUb1fmktB4DH92TW/EGw///VQEnE7tkpNjyJpOTXDuHnEk2tw43cctDN2sJH 1454295320@qq.com

回到web页面,操作如下:
技术图片
技术图片
技术图片

2)创建一个基本库

如图:
技术图片
技术图片
技术图片
回到服务器上输入测试的命令,如下:

[root@gitlab ~]# git config --global user.name "Administrator"
[root@gitlab ~]# git config --global user.email "admin@example.com"
[root@gitlab ~]# git clone git@192.168.1.8:root/test01.git         
#克隆到本地,根据提示输入“yes”即可!
[root@gitlab ~]# cd test01/
[root@gitlab test01]# touch README.md
[root@gitlab test01]# git add README.md
[root@gitlab test01]# git commit -m "add README"
[root@gitlab test01]# git push -u origin master

刷新web页面即可,如图:
技术图片

五、远端库的基本操作

当你从远端仓库克隆时,实际上git自动把本地的master分支和远端的master分支对应起来了,并且远程仓库的默认名称是origin。

1)查看关联的远程库的信息

[root@gitlab test01]# git remote        #简洁信息
origin
[root@gitlab test01]# git remote -v         #详细信息
origin  git@192.168.1.8:root/test01.git (fetch)
origin  git@192.168.1.8:root/test01.git (push)

2)推送分支到远程仓库

[root@gitlab test01]# git checkout -b dev             #创建并切换到dev分支
[root@gitlab test01]# git push origin dev              #将本地的分支推送到远程仓库

刷新页面之后,如图:
技术图片

3)解决多人协作产生的问题

当我们整个小组对同一个分支进行开发时,如果在你提交之前,你的同事已经修改了分支的内容并推送到远端仓库,而碰巧你也对同样的文件做了修改,并试图推送,那么会推送失败,因为你的同事的最新提交的数据和你试图提交的数据有冲突(你本地的内容比远端仓库的旧了),解决的办法会在提示你推送失败的返回信息中给出,这里我们模拟一下这一过程。

#进入另一个目录,克隆远端仓库,模拟多人操作
[root@gitlab test01]# cd /tmp           
[root@gitlab tmp]# git clone git@192.168.1.8:root/test01.git
[root@gitlab tmp]# cd test01/
[root@gitlab test01]# git checkout -b etc            #重新创建一个分支并切换
[root@gitlab test01]# echo -e "touch /tmp/test01" > tmp.txt
[root@gitlab test01]# git add tmp.txt
[root@gitlab test01]# git commit -m "commmit from /tmp"
[root@gitlab test01]# git push origin etc                #将新修改的内容推送到远端

回到web界面进行刷新,即可看到新提交的分支:
技术图片
技术图片

#上述操作是在/tmp目录下执行的,接下来的操作在/root目录下执行:
[root@gitlab test01]# cd /root/test01/
[root@gitlab test01]# git checkout -b etc
[root@gitlab test01]# echo "touch /root/test01.txt" > root.txt
[root@gitlab test01]# git add root.txt
[root@gitlab test01]# git commit -m "commit from /root"
[root@gitlab test01]# git push origin  etc            
#再次推送,将会出现以下错误
To git@192.168.1.8:root/test01.git
 ! [rejected]        etc -> etc (fetch first)
error: 无法推送一些引用到 ‘git@192.168.1.8:root/test01.git‘
提示:更新被拒绝,因为远程版本库包含您本地尚不存在的提交。这通常是因为另外
提示:一个版本库已推送了相同的引用。再次推送前,您可能需要先合并远程变更
提示:(如 ‘git pull‘)。
提示:详见 ‘git push --help‘ 中的 ‘Note about fast-forwards‘ 小节。
[root@gitlab test01]# git pull origin etc              #将远端的etc分支pull到本地
[root@gitlab test01]# ls               #可以看出在/tmp目录下提交的文件就存在了
README.md  root.txt  tmp.txt
[root@gitlab test01]# git push origin etc                  #然后再次将本地的dev分支推送到gitlab,即可成功

再次刷新web页面,etc分支下就会有了我们在/tmp目录和/root目录下提交的所有内容,如图:
技术图片

4)合并远程分支

[root@gitlab test01]# git checkout master           #切换至master分支
[root@gitlab test01]# git merge etc                    #合并etc分支
[root@gitlab test01]# ls                   #查看合并后的分支下内容
README.md  root.txt  tmp.txt
[root@gitlab test01]# git add .
[root@gitlab test01]# git commit -m "提交"
[root@gitlab test01]# git push origin master             #推送到远端版本库

再次刷新web页面,如图:
技术图片

5)删除远程的分支

[root@gitlab test01]# git branch -d etc                 #删除本地的dev分支
[root@gitlab test01]# git branch -r -d origin/etc     #删除指定的远程分支
[root@gitlab test01]# git push origin :etc               #将删除的分支提交到远程版本库中
[root@gitlab test01]# git branch -d dev
[root@gitlab test01]# git branch -r -d origin/dev
[root@gitlab test01]# git push origin :dev                      #同上

再次刷新web页面,如下:
技术图片

六、重置gitlab管理员密码

[root@gitlab ~]# gitlab-rails console production             #必须是root用户登录服务器执行该命令
irb(main):001:0> user = User.where(id: 1).first             #id为1的是超级管理员
irb(main):002:0> user.password = ‘yourpassword‘       #密码必须至少8个字符
irb(main):003:0> user.save!                  #保存用户修改信息,如没有问题返回true
irb(main):004:0> exit                             #退出

至此,再次登录,就需要使用新密码yourpassword进行登录了。

以上是关于centos 7部署并汉化Gitlab及基础操作的主要内容,如果未能解决你的问题,请参考以下文章

centos7 部署 汉化版 gitlab 10.0.2

centos7 gitlab 9.1.0 安装以及汉化

GitLab10安装-部署-汉化-备份-升级

centos7安装gitlab并汉化

Centos7安装部署汉化Gitlab

Gitlab 10.5版本的部署使用及汉化