gitlab 安装、配置

gitlab 安装、配置

对于企业级的私有 git 仓库,gitlab 是个不错的选择。html

今天就来讲说 gitlab 的安装、配置。nginx

系统配置建议:最低双核 4G 内存。git

当前针对 gitlab 版本:11.5.3github

1. 说明

根据官方的安装教程,选取 ubuntu 环境下的社区版进行安装:https://about.gitlab.com/install/#ubuntu?version=ceweb

若是须要其余的环境(如 CentOSdocker 等)或者企业版,参考这里:https://about.gitlab.com/install/docker

注:社区版是免费的,企业版是收费的。npm

2. 安装、配置所需依赖

sudo apt-get install -y curl openssh-server ca-certificates
sudo apt-get install -y postfix

3. 添加安装包地址,并安装

curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash
sudo EXTERNAL_URL="http://gitlab.example.com" apt-get install gitlab-ce

这里须要把 http://gitlab.example.com 改为你本身的真正对外服务的 gitlab url 地址(也能够安装后在配置文件里面更改)。ubuntu

到这里为止,gitlab 就算安装好了。tomcat

4. 安装以后

gitlab 默认建议安装在一个单独的主机上,默认使用内置的 nginx 服务器,并使用 808080 两个端口。bash

若是你是按照 gitlab 的默认建议,使用的是单独的主机,直接访问 ip 地址 http://ip,或者把域名解析到这台机器上后直接访问域名 http://gitlab.your.com,而后按照步骤在 web 页面上初始化 gitlab 就能够了。

然而,不少状况下,gitlab 并不会部署到一台单独的服务器上,而是像其余不少服务同样(如 jenkins),部署到同一台服务器上,而后使用 nginx 反向代理。

5. nginx 反向代理配置

添加 nginx 配置:

upstream gitlab-workhorse {
    server unix:/var/opt/gitlab/gitlab-workhorse/socket;
}

server {
  listen 0.0.0.0:80;
  listen [::]:80;
  server_name gitlab.your.com;
  server_tokens off;
  root /opt/gitlab/embedded/service/gitlab-rails/public;

  access_log  /var/log/nginx/gitlab_access.log;
  error_log   /var/log/nginx/gitlab_error.log;

  location / {
    client_max_body_size 0;
    gzip off;

    proxy_read_timeout      300;
    proxy_connect_timeout   300;
    proxy_redirect          off;
    proxy_http_version 1.1;
    proxy_set_header    Host                $http_host;
    proxy_set_header    X-Real-IP           $remote_addr;
    proxy_set_header    X-Forwarded-For     $proxy_add_x_forwarded_for;
    proxy_set_header    X-Forwarded-Proto   $scheme;
    proxy_pass http://gitlab-workhorse;
  }
}

若是想要了解更详细的配置,能够参考:NGINX settings | GitLab

从新加载 nginx 配置:

service nginx reload
# or
service nginx restart

修改 gitlab 配置:

vi /etc/gitlab/gitlab.rb

external_url 'http://gitlab.your.com'            # 此处修为你本身的 gitlab url
web_server['external_users'] = ['www-data']      # 设置外部 webserver 用户
nginx['enable'] = false                          # 不使用内置的 nginx
sudo usermod -aG gitlab-www www-data             # 把 www-data 用户添加到 gitlab-www 组

gitlab 服务默认使用的是 8080 端口,若是 8080 端口已经被其余程序(如 tomcat)占用,须要改为其余端口:

unicorn['port'] = 8081                           # 改为你本身以为好的端口

更新 gitlab 配置,重启服务:

gitlab-ctl reconfigure
gitlab-ctl restart

如今你就能够访问 http://gitlab.your.com,而后按照步骤在 web 页面上初始化 gitlab 就能够了。

6. 经常使用命令

gitlab-ctl start                                 # 启动 gitlab
gitlab-ctl stop                                  # 中止 gitlab
gitlab-ctl restart                               # 重启 gitlab
gitlab-ctl status                                # 查看服务状态
vi /etc/gitlab/gitlab.rb                         # 修改配置文件
gitlab-ctl reconfigure                           # 从新编译 gitlab 配置
gitlab-rake gitlab:check SANITIZE=true --trace   # 检查 gitlab
gitlab-ctl tail                                  # 查看日志
gitlab-ctl tail nginx/gitlab_access.log

7. 经常使用目录

/var/log/gitlab/                                 # 日志地址 
/var/opt/gitlab/                                 # 服务地址

8. 查看版本

cat /opt/gitlab/embedded/service/gitlab-rails/VERSION

9. 可能遇到的一些问题

9.1 File to import not found or unreadable

图片描述

解决:须要 npm 安装一下

cd /opt/gitlab/embedded/service/gitlab-rails
npm install
gitlab-ctl restart                               # 重启服务

后续

更多博客,查看 https://github.com/senntyou/blogs

做者:深予之 (@senntyou)

版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证

相关文章
相关标签/搜索