gitlab 安裝、配置

gitlab 安裝、配置

對於企業級的私有 git 倉庫,gitlab 是個不錯的選擇。

今天就來說說 gitlab 的安裝、配置。

系統配置建議:最低雙核 4G 內存。

當前針對 gitlab 版本:11.5.3

1. 說明

根據官方的安裝教程,選取 ubuntu 環境下的社區版進行安裝:https://about.gitlab.com/install/#ubuntu?version=ce

如果需要其他的環境(如 CentOSdocker 等)或者企業版,參考這裏:https://about.gitlab.com/install/

注:社區版是免費的,企業版是收費的。

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 地址(也可以安裝後在配置文件裏面更改)。

到這裏爲止,gitlab 就算安裝好了。

4. 安裝之後

gitlab 默認建議安裝在一個單獨的主機上,默認使用內置的 nginx 服務器,並使用 808080 兩個端口。

如果你是按照 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許可證

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章