子目录中的Gitlab阻止了git Lab之外的其他位置

时间:2018-10-04 13:36:59

标签: apache gitlab gitlab-omnibus

我有一个位于子目录中的自托管内部omnibus安装,可以使用myinternalserver/gitlab进行访问。这样已经有一年多了。我们依靠CI进行内部软件迭代和变更跟踪。由于我们的域配置不允许我们使用子域,因此我们选择安装子目录。我们还希望将服务器用于不仅仅是gitlab的情况,不幸的是,myinternalserver/gitlab方案之外的任何内容都将以白页显示,其确切短语为Not found "/PLACEYOUWERELOOKINGFOR"

我要猜测一个错误,说“找不到”消息来自gitlab的nginx服务,我还要猜测它与服务器的apache重写规则有关,但我找不到正确的方法进行更改。

# This configuration has been tested on GitLab 8.2
# Note this config assumes unicorn is listening on default port 8080 and
# gitlab-workhorse is listening on port 8181. To allow gitlab-workhorse to
# listen on port 8181, edit /etc/gitlab/gitlab.rb and change the following:
#
# gitlab_workhorse['listen_network'] = "tcp"
# gitlab_workhorse['listen_addr'] = "127.0.0.1:8181"
#
#Module dependencies
# mod_rewrite
# mod_proxy
# mod_proxy_http



<VirtualHost *:80>
  DocumentRoot /var/www/html
  ServerName dev2
  ServerSignature Off

  ProxyPreserveHost on

  # Ensure that encoded slashes are not decoded but left in their encoded state.
  # http://doc.gitlab.com/ce/api/projects.html#get-single-project
  AllowEncodedSlashes NoDecode

 #Gitlab
 Alias /gitlab /opt/gitlab/embedded/html
  <Location /gitlab>
    # New authorization commands for apache 2.4 and up
    # http://httpd.apache.org/docs/2.4/upgrading.html#access
    Require all granted

    #Allow forwarding to gitlab-workhorse
    ProxyPassReverse http://127.0.0.1:8181
    ProxyPassReverse http://dev2/gitlab
  </Location>

  # Apache equivalent of nginx try files
  # http://serverfault.com/questions/290784/what-is-apaches-equivalent-of-nginxs-try-files
  # http://stackoverflow.com/questions/10954516/apache2-proxypass-for-rails-app-gitlab
  RewriteEngine on

  #Forward all requests to gitlab-workhorse except existing files like error documents
  RewriteCond %{REQUEST_URI} ^/gitlab/api/v3/.*
  RewriteRule .* http://127.0.0.1:8181%{REQUEST_URI} [P,QSA,NE]
  RewriteCond %{DOCUMENT_ROOT}/%{REQUEST_FILENAME} !-f [OR]
  RewriteCond %{REQUEST_URI} ^/gitlab/uploads/.*
  RewriteRule .* http://127.0.0.1:8181%{REQUEST_URI} [P,QSA,NE]

  # needed for downloading attachments
  DocumentRoot /opt/gitlab/embedded/service/gitlab-rails/public
  Alias /gitlab /opt/gitlab/embedded/

  #Set up apache error documents, if back end goes down (i.e. 503 error) then a maintenance/deploy page is thrown up.
  ErrorDocument 404 /404.html
  ErrorDocument 422 /422.html
  ErrorDocument 500 /500.html
  ErrorDocument 502 /502.html
  ErrorDocument 503 /503.html

  # It is assumed that the log directory is in /var/log/httpd.
  # For Debian distributions you might want to change this to
  # /var/log/apache2.
  LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b" common_forwarded
ProxyRequests on
  #ErrorLog /var/log/apache2/logs/dev2_error.log
  #CustomLog /var/log/apache2/logs/dev2_forwarded.log common_forwarded
  #CustomLog /var/log/apache2/logs/dev2_access.log combined env=!dontlog
  #CustomLog /var/log/apache2/logs/dev2.log combined
</VirtualHost>

任何帮助或建议将不胜感激。

0 个答案:

没有答案