gitlab使用文档

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请求直达容器内部。

你可能感兴趣的:(gitlab使用文档)