Apache Proxy 背后的 Gitlab

Gitlab behind Apache Proxy

在搜索了几个小时后,在 Apache 反向代理后面找到了 Gitlab 运行 的解决方案。需要说明的是,我可以连接到 Gitlab 实例,而且我还可以执行所有基本功能,例如推送、克隆代码等。

我的问题是我在 Issue 中 post 的每张图片总是有 http://127.0.0.1:8090/.../ 作为 URL。我尝试更改 external_url 这总是导致 Gitlab 响应 502。我更改和尝试的任何其他设置要么没有效果,要么导致 500s 或 503s。 我决定向你们中的任何一个人寻求提示。

我目前的配置是: /etc/gitlab/gitlab.rb

 external_url 'http://127.0.0.1:8090'
 gitlab_rails['time_zone'] = 'Europe/Berlin'

 gitlab_rails['smtp_enable'] = true
 gitlab_rails['smtp_address'] = "mail.server.de"
 gitlab_rails['smtp_port'] = 465
 gitlab_rails['smtp_user_name'] = "noreply@server.de"
 gitlab_rails['smtp_password'] = "password"
 gitlab_rails['smtp_domain'] = "mail.server.de"
 gitlab_rails['smtp_authentication'] = "login"
 gitlab_rails['smtp_enable_starttls_auto'] = false
 gitlab_rails['smtp_tls'] = true
 gitlab_rails['smtp_pool'] = false

 gitlab_rails['smtp_openssl_verify_mode'] = 'none'

 gitlab_rails['gitlab_email_enabled'] = true

 gitlab_rails['gitlab_email_from'] = 'noreply@server.de'
 gitlab_rails['gitlab_email_display_name'] = 'NoReply Server'
 gitlab_rails['gitlab_email_reply_to'] = 'kontakt@server.de'

 gitlab_rails['gitlab_default_theme'] = 2

 letsencrypt['enable'] = false

/etc/apache2/sites-available/gitlab.conf

<VirtualHost *:443>
    ServerName gitlab.server.de
    
    ProxyPreserveHost On
    ProxyRequests Off
    ProxyPass /.well-known/acme-challenge !
    ProxyPass / http://127.0.0.1:8090/ retry=0
    ProxyPassReverse / http://127.0.0.1:8090/
    
    SSLEngine on
    SSLCertificateFile /etc/letsencrypt/live/gitlab.server.de/fullchain.pem
    SSLCertificateKeyFile /etc/letsencrypt/live/gitlab.server.de/privkey.pem
    Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>

你们能帮我吗? 提前致谢。

将您的 external_url 设置为 URL 用户用来访问您的 GitLab 服务器。例如gitlab.server.de 根据您的 Apache 配置。

此外,如果您不使用双向 TLS,您需要修复代理 headers 以处理协议更改。

最重要的是,您需要显式配置 GitLab 的内部 nginx 以侦听您在 proxy/proxypass 配置中指定的端口,而不是使用 https。

所以,像这样:

external_url "https://gitlab.server.de"

# set listen port explicitly, required when using non-default port
# and port is not specified in external_url
nginx['listen_port'] = 8090

# disable https listener, since Apache is setup for SSL/TLS termination
nginx['listen_https'] = false


# technically optional, set proxy headers
nginx['proxy_set_headers'] = {
    "X-Forwarded-Proto" => "http",
    "X-Forwarded-Port" => "80"
}

同样重要的是要注意 GitLab 本身应该能够使用它的 external_url 到达自己。换句话说,您的 Apache 服务器应该 (1) 可由主机上的 DNS 解析,并且 (2) 允许从 GitLab 访问。