1.官网安装:
1.安装和配置必要的依赖项
sudo apt-get update
sudo apt-get install -y curl openssh-server ca-certificates
接下来,安装Postfix发送通知电子邮件。如果要使用其他解决方案发送电子邮件,请跳过此步骤并 在安装GitLab之后配置外部SMTP服务器。
sudo apt-get install -y postfix
在Postfix安装过程中,可能会出现一个配置屏幕。选择“ Internet网站”,然后按Enter。使用服务器的外部DNS作为“邮件名”,然后按Enter。如果出现其他屏幕,请继续按Enter接受默认设置。
2.添加GitLab软件包存储库并安装软件包
添加GitLab软件包存储库。
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh | sudo bash
接下来,安装GitLab软件包。更改https://gitlab.example.com为您要访问GitLab实例的URL。安装将自动配置并在该URL上启动GitLab。
对于https://URL,GitLab将使用Let's Encrypt自动请求证书,这需要入站HTTP访问和有效的主机名。您也可以使用自己的证书或仅使用http://。
sudo EXTERNAL_URL="https://gitlab.example.com" apt-get install gitlab-ee
3.浏览到主机名并登录
首次访问时,您将被重定向到密码重置屏幕。提供初始管理员帐户的密码,您将被重定向回登录屏幕。使用默认帐户的用户名root登录。
有关安装和配置的详细说明,请参见我们的文档。
Gitlab Community Edition 镜像使用帮助
注意: gitlab-ce 镜像仅支持 x86-64 架构
2.国内源安装(推荐)
版本:Debian/Ubuntu 用户
1.首先信任 GitLab 的 GPG 公钥:
curl https://packages.gitlab.com/gpg.key 2> /dev/null | sudo apt-key add - &>/dev/null
2.再选择你的 Debian/Ubuntu 版本
文本框中内容写进
sudo vim /etc/apt/sources.list.d/gitlab-ce.list
你的Debian/Ubuntu版本:(18.04) ,然后将以下地址复制进去
deb https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/ubuntu bionic main
3.安装 gitlab-ce:
sudo apt-get update
sudo apt-get install gitlab-ce
4.修改gitlab配置文件指定服务器ip和自定义端口:
vim /etc/gitlab/gitlab.rb
进入编辑器后按“i”键进入编辑状态,ESC键退出编辑状态
修改以下信息:
external_url 'http://localhost:8899'
unicorn['port']=8088
退出并保存,命令输入“:wq”
ps:注意这里设置的端口不能被占用,默认是8080端口,如果8080已经使用,请自定义其它端口,并在防火墙设置开放相对应得端口
5.重置并启动GitLab
执行:
gitlab-ctl reconfigure
gitlab-ctl restart
提示 "ok: run:"表示启动成功
3.汉化
1.克隆版本库
cd /usr/local/src/
git clone https://gitlab.com/xhang/gitlab.git
2.获取当前Gitlab版本
gitlab_version=$(cat /opt/gitlab/embedded/service/gitlab-rails/VERSION)
3.比较汉化标签和原标签,导出patch用的diff文件
cd /usr/local/src/gitlab
git diff v${gitlab_version} v${gitlab_version}-zh > ../${gitlab_version}-zh.diff
4.先停止gitlab
gitlab-ctl stop
5.导入汉化补丁
patch -d /opt/gitlab/embedded/service/gitlab-rails -p1 < ../${gitlab_version}-zh.diff
PS:如果出现类似以下内容,则按住回车,一直跳过就行了
can't find file to patch at input line 5
Perhaps you used the wrong -p or --strip option?
The text leading up to this was:
--------------------------
|diff --git a/app/assets/javascripts/awards_handler.js b/app/assets/javascripts/awards_handler.js
|index eb0f06e..73e4833 100644
|--- a/app/assets/javascripts/awards_handler.js
|+++ b/app/assets/javascripts/awards_handler.js
--------------------------
File to patch:
6.然后启动gitlab
gitlab-ctl start
4.更改clone地址:
输入:
sudo vim /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml
进入之后,更改
host: 10.1.63.217
5.Gitlab 保存设置项目时提示500错误
将gitlab转为docker后,发现管理后台保存配置时提示500错误,查看日志/var/log/gitlab/gitlab-rails/production.log
对应的错误信息为OpenSSL::Cipher::CipherError
查阅官方资料,得知是没有导入原来的加密信息/etc/gitlab/gitlab-secrets.json
导致,重置下即可。
- 进入控制台
docker exec -it docker bash
- 输入
gitlab-rails console
,等待进入rails控制台 - 输入
ApplicationSetting.current.reset_runners_registration_token!
,显示结果为true
- 再次尝试保存操作,已正常
如果项目设置也不正常,需进入DB控制台清理更多的Token设置,请参阅官方文献:
https://docs.gitlab.com/ee/raketasks/backup_restore.html#when-the-secrets-file-is-lost
6.docker-gitlab ssh仍需要密码
前言
如果gitlab直接部署在宿主上,使用ssh克隆没有问题。但是,gitlab部署在容器中就出现这个问题。
开启ssh传输的流程
一般情况下,如果客户机要免密访问gitlab,需要把本机的公钥(.pub)复制到gitlab服务器注册(一般在web界面操作),这样客户机就可以免密访问仓库了。
原因分析
ssh传输都是通过22端口传输的,一般被宿主的sshd服务占用。所以gitlab容器的22端口不能直接映射到宿主的22端口,要换个其他端口,比如222。
这样,通过端口映射,客户端的ssh传输请求就能达到容器中的gitlab服务。
同时,还需要修改gitlab的gitlab_rails[‘gitlab_shell_ssh_port’] = 222并使用命令gitlab-ctl reconfigure命令重新配置。这样,从网页获取的克隆地址就是222端口,通过该端口,客户机ssh请求直达容器内部。