Gitlab部署

1、简介

GitLab 是一个自托管的 Git 仓库管理工具,它提供了源代码管理、代码审查、问题跟踪、持续集成和部署等功能。通过 GitLab,团队成员可以协作开发和管理软件项目。在本文中,我们将介绍如何在 Linux 系统上安装 GitLab。

2、硬件和软件要求

  • 4 核 CPU
  • 4 GB 内存
  • 2 GB 硬盘空间

    3、安装

    Ubuntu:

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

CE

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash
sudo EXTERNAL_URL=”访问域名” yum install -y gitlab-ce

访问域名要写全:https://gitlab.example.com

EE

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh | sudo bash
sudo EXTERNAL_URL=”访问域名” yum install -y gitlab-ee


Centos:

sudo yum install -y curl policycoreutils-python perl postfix

Check if opening the firewall is needed with: sudo systemctl status firewalld

sudo firewall-cmd –permanent –add-service=http
sudo firewall-cmd –permanent –add-service=https
sudo systemctl reload firewalld

sudo systemctl enable postfix
sudo systemctl start postfix

CE

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash
sudo EXTERNAL_URL=”访问域名” yum install -y gitlab-ce

EE

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash
sudo EXTERNAL_URL=”访问域名” yum install -y gitlab-ee


* 安装完成后随机密码在/etc/gitlab/initial_root_password文件中,或者设置初始密码

设置初始密码
要提供自定义初始 root 密码,您有两个选择:
-   如果服务器的主机名设置正确,则将`GITLAB_ROOT_PASSWORD`环境变量传递给安装命令。如果在安装期间 GitLab 没有自动执行重新配置,则必须将`GITLAB_ROOT_PASSWORD`变量传递给第一次`gitlab-ctl reconfigure`运行。

GITLAB_ROOT_PASSWORD=’PASSWORD’ yum install -y gitlab-ee

-   在第一次重新配置之前,编辑`/etc/gitlab/gitlab.rb`(如果不存在则创建它)并设置:

gitlab_rails[‘initial_root_password’] = ”


# 4、配置
## 4.1 配置访问域名(可选)

vim /etc/gitlab/gitlab.rb


顶部附近是`external_url`配置线。更新它以匹配您的域。更改`http`为`https`以便GitLab会自动将用户重定向到受Let's加密证书保护的站点:

external_url ‘https://example.com


接下来,查找`letsencrypt['contact_emails']`设置。此设置定义了一个电子邮件地址列表,如果您的域存在问题,Let的加密项目可以用来与您联系。取消注释并填写此内容是一个好主意,以便您知道任何问题:

letsencrypt[‘contact_emails’] = [‘sammy@example.com’]


## 4.2 SMTP配置(可选)

vim /etc/gitlab/gitlab.rb

gitlab_rails[‘smtp_enable’] = true
gitlab_rails[‘smtp_address’] = “smtp.exmail.qq.com”
gitlab_rails[‘smtp_port’] = 465
gitlab_rails[‘smtp_user_name’] = “xxxx@xx.com”
gitlab_rails[‘smtp_password’] = “password”
gitlab_rails[‘smtp_authentication’] = “login”
gitlab_rails[‘smtp_enable_starttls_auto’] = true
gitlab_rails[‘smtp_tls’] = true
gitlab_rails[‘gitlab_email_from’] = ‘xxxx@xx.com’
gitlab_rails[‘smtp_domain’] = “exmail.qq.com”


保存并关闭文件。运行以下命令重新配置Gitlab:

 生效配置文件

sudo gitlab-ctl reconfigure


## 4.3自定义https证书(可选)

将你的ssl证书放入/etc/gitlab/ssl/

修改gitlab配置文件

sudo vim /etc/gitlab/gitlab.rb

external_url ‘https://域名
nginx[‘enable’] = true
nginx[‘redirect_http_to_https’] = true # 访问http自动跳转https
nginx[‘ssl_certificate’] = “/etc/gitlab/ssl/域名的ssl证书.crt”
nginx[‘ssl_certificate_key’] = “/etc/gitlab/ssl/域名的ssl证书.key”

生效配置文件

sudo gitlab-ctl reconfigure


## 4.4相关命令

检查配置

gitlab-ctl check-config

重启服务

gitlab-ctl restart

启动服务

gitlab-ctl start

查看服务状态

gitlab-ctl status

停止服务

gitlab-ctl stop

查看服务列表

gitlab-ctl service-list

查看日志

gitlab-ctl tail


## 4.5 gitlab 自带Nginx与原Nginx冲突的解决方案
### 4.5.1 修改gitlab.rb

vim /etc/gitlab/gitlab.rb

nginx[‘enable’] = false

gitlab_workhorse[‘listen_network’] = “tcp”
gitlab_workhorse[‘listen_addr’] = “127.0.0.1:8088”

nginx[‘listen_port’] = 8088
nginx[‘listen_https’] = true

web_server[‘external_users’] = [‘www’]
web_server[‘username’] = ‘www’

gitlab_workhorse[‘listen_network’] = “tcp”
gitlab_workhorse[‘listen_addr’] = “127.0.0.1:8088”


### 4.5.2 修改nginx默认配置文件

vim /etc/local/nginx/conf/nginx.conf

user www www;

worker_processes auto;
worker_cpu_affinity auto;

error_log /home/wwwlogs/nginx_error.log crit;

pid /usr/local/nginx/logs/nginx.pid;

Specifies the value for maximum file descriptors that can be opened by this process.

worker_rlimit_nofile 51200;

events
{
use epoll;
worker_connections 51200;
multi_accept off;
accept_mutex off;
}

http
{
include mime.types;
default_type application/octet-stream;

    server_names_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 32k;
    client_max_body_size 50m;

    sendfile on;
    sendfile_max_chunk 512k;
    tcp_nopush on;

    keepalive_timeout 60;

    tcp_nodelay on;

    fastcgi_connect_timeout 300;
    fastcgi_send_timeout 300;
    fastcgi_read_timeout 300;
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size 128k;
    fastcgi_temp_file_write_size 256k;

    gzip on;
    gzip_min_length  1k;
    gzip_buffers     4 16k;
    gzip_http_version 1.1;
    gzip_comp_level 2;
    gzip_types     text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/xml+rss;
    gzip_vary on;
    gzip_proxied   expired no-cache no-store private auth;
    gzip_disable   "MSIE [1-6].";

    #limit_conn_zone $binary_remote_addr zone=perip:10m;
    ##If enable limit_conn_zone,add "limit_conn perip 10;" to server section.
    include /opt/gitlab/embedded/conf/mime.types;

    proxy_cache_path proxy_cache keys_zone=gitlab:10m max_size=1g levels=1:2;
    proxy_cache gitlab;

    map $http_upgrade $connection_upgrade {
        default upgrade;
        ''      close;
    }

    # Remove private_token from the request URI
    # In:  /foo?private_token=unfiltered&authenticity_token=unfiltered&rss_token=unfiltered&...
    # Out: /foo?private_token=[FILTERED]&authenticity_token=unfiltered&rss_token=unfiltered&...
    map $request_uri $temp_request_uri_1 {
      default $request_uri;
      ~(?i)^(?<start>.*)(?<temp>[?&]private[-_]token)=[^&]*(?<rest>.*)$ "$start$temp=[FILTERED]$rest";
    }

    # Remove authenticity_token from the request URI
    # In:  /foo?private_token=[FILTERED]&authenticity_token=unfiltered&rss_token=unfiltered&...
    # Out: /foo?private_token=[FILTERED]&authenticity_token=[FILTERED]&rss_token=unfiltered&...
    map $temp_request_uri_1 $temp_request_uri_2 {
      default $temp_request_uri_1;
      ~(?i)^(?<start>.*)(?<temp>[?&]authenticity[-_]token)=[^&]*(?<rest>.*)$ "$start$temp=[FILTERED]$rest";
    }

    # Remove rss_token from the request URI
    # In:  /foo?private_token=[FILTERED]&authenticity_token=[FILTERED]&rss_token=unfiltered&...
    # Out: /foo?private_token=[FILTERED]&authenticity_token=[FILTERED]&rss_token=[FILTERED]&...
    map $temp_request_uri_2 $filtered_request_uri {
      default $temp_request_uri_2;
      ~(?i)^(?<start>.*)(?<temp>[?&]rss[-_]token)=[^&]*(?<rest>.*)$ "$start$temp=[FILTERED]$rest";
    }

    # A version of the referer without the query string
    map $http_referer $filtered_http_referer {
      default $http_referer;
      ~^(?<temp>.*)? $temp;
    }

    upstream gitlab-workhorse {
      server 127.0.0.1:8088;
    }
    server_tokens off;
    access_log off;

server
{
listen 80 default_server reuseport;

listen [::]:80 default_server ipv6only=on;

    server_name _;
    index index.html index.htm index.php;
    root  /home/wwwroot/default;

    #error_page   404   /404.html;

    # Deny access to PHP files in specific directory
    #location ~ /(wp-content|uploads|wp-includes|images)/.*.php$ { deny all; }

    include enable-php.conf;

    location /nginx_status
    {
        stub_status on;
        access_log   off;
    }

    location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$
    {
        expires      30d;
    }

    location ~ .*.(js|css)?$
    {
        expires      12h;
    }

    location ~ /.well-known {
        allow all;
    }

    location ~ /.
    {
        deny all;
    }

    access_log  /home/wwwlogs/access.log;
}

include vhost/*.conf;
}


### 4.5.3 修改gitlab网页配置

vim /usr/local/nginx/conf/vhost/gitlab.conf

server {
listen *:80;

server_name gitlab.xxx.net;
server_tokens off; ## Don’t show the nginx version number, a security best practice

location / {
return 301 https://gitlab.xxx.net:443$request_uri;
}

health checks configuration

include /var/opt/gitlab/nginx/conf/gitlab-health.conf;

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

server {
listen *:443 ssl http2;

server_name gitlab.xxx.net;
server_tokens off; ## Don’t show the nginx version number, a security best practice

Increase this if you want to upload large attachments

Or if you want to accept large git objects over http

client_max_body_size 250m;

Strong SSL Security

https://raymii.org/s/tutorials/Strong_SSL_Security_On_nginx.html & https://cipherli.st/

ssl_certificate /opt/certs/gitlab/gitlab.crt;
ssl_certificate_key /opt/certs/gitlab/gitlab.key;

GitLab needs backwards compatible ciphers to retain compatibility with Java IDEs

ssl_ciphers ‘ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:AES256-GCM-SHA384’;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_prefer_server_ciphers off;
ssl_session_cache shared:SSL:10m;
ssl_session_tickets off;
ssl_session_timeout 1d;

Real IP Module Config

http://nginx.org/en/docs/http/ngx_http_realip_module.html

HSTS Config

https://www.nginx.com/blog/http-strict-transport-security-hsts-and-nginx/

add_header Strict-Transport-Security “max-age=63072000”;

Rails sets a default policy of strict-origin-when-cross-origin, so

hide that and just send the one we’ve configured for nginx

proxy_hide_header Referrer-Policy;
add_header Referrer-Policy strict-origin-when-cross-origin;

Individual nginx logs for this GitLab vhost

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

if ($http_host = “”) {
set $http_host_with_default “gitlab.xxxx.net”;
}

if ($http_host != “”) {
set $http_host_with_default $http_host;
}

gzip on;
gzip_static on;
gzip_comp_level 2;
gzip_http_version 1.1;
gzip_vary on;
gzip_disable “msie6”;
gzip_min_length 250;
gzip_proxied no-cache no-store private expired auth;
gzip_types text/plain text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript application/json;

https://github.com/gitlabhq/gitlabhq/issues/694

Some requests take more than 30 seconds.

proxy_read_timeout 3600;
proxy_connect_timeout 300;
proxy_redirect off;
proxy_http_version 1.1;

proxy_set_header Host $http_host_with_default;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header X-Forwarded-Ssl on;

location ~ (/api/vd/jobs/d+/artifacts$|.git/git-receive-pack$|.git/gitlab-lfs/objects|.git/info/lfs/objects/batch$) {
proxy_cache off;
proxy_pass http://gitlab-workhorse;
proxy_request_buffering off;
}

location /-/grafana/ {
proxy_pass http://localhost:3000/;
}

health checks configuration

include /var/opt/gitlab/nginx/conf/gitlab-health.conf;

location / {
proxy_cache off;
proxy_pass http://gitlab-workhorse;
}

location /assets {
add_header X-Content-Type-Options nosniff;
proxy_cache gitlab;
proxy_pass http://gitlab-workhorse;
}

error_page 404 /404.html;
error_page 500 /500.html;
error_page 502 /502.html;
location ~ ^/(404|500|502)(-custom)?.html$ {
root /opt/gitlab/embedded/service/gitlab-rails/public;
internal;
}
}

生效配置文件

gitlab-ctl reconfigure

重启nginx服务

systemctl restart nginx


## 4.6 gitlab头像不显示
使用以下命令更改GitLab默认使用的头像引用URL:

vim /var/opt/gitlab/gitlab-rails/etc/gitlab.yml

plain_url: http://sdn.geekzu.org/avatar/%{hash}?s=%{size}&d=identicon
ssl_url: https://sdn.geekzu.org/avatar/%{hash}?s=%{size}&d=identicon

重新启动gitlab

gitlab-ctl restart


这种方法重新配置后会失效,建议使用下面这一种

vim /etc/gitlab/gitlab.rb

Gravatar Settings

gitlab_rails[‘gravatar_plain_url’] = ‘http://sdn.geekzu.org/avatar/%{hash}?s=%{size}&d=identicon
gitlab_rails[‘gravatar_ssl_url’] = ‘https://sdn.geekzu.org/avatar/%{hash}?s=%{size}&d=identicon

重新配置gitlab

gitlab-ctl reconfigure

重启gitlab

gitlab-ctl restart

# 5、Gitlab Runner部署
## 5.1 添加官方Gitlab库
For Debian/Ubuntu/Mint:

curl -L “https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.deb.sh” | sudo bash


For RHEL/CentOS/Fedora:

curl -L “https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.rpm.sh” | sudo bash

## 5.2 安装最新版Gitlab Runner
For Debian/Ubuntu/Mint:

sudo apt-get install gitlab-runner


For RHEL/CentOS/Fedora:

yum install gitlab-runner

## 5.3 To register a runner under Linux

gitlab-runner register

查看运行状态

gitlab-runner status

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

给TA打赏
共{{data.count}}人
人已打赏
LinuxOps工具

vdbench在ARM服务器上出现共享库aarch64.so问题

2025-4-3 11:45:48

Ops工具

Gitlab安装和使用

2025-4-1 11:37:44

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索
Index