В настоящее время я использую CentOS, на котором размещены мой веб-сервер и сервер gitlab, а также компьютер с Windows, на котором размещен дозвуковой сервер. В настоящее время мой ip указывает на CentOS, но не перенаправляет правильно. Я могу получить доступ / но не могу получить доступ к другим сайтам с поддоменом, несмотря на сделанные мной настройки, поэтому я хотел бы знать, где я ошибаюсь и как исправить проблему. Возможно ли, что когда люди входят http://git.example.com
что он будет автоматически перенаправлен на https://git.example.com
? Заранее спасибо!
NameVirtualHost *:80
#This should lead to subsonic server
<VirtualHost *>
ServerName music.company.com
ServerAlias www.music.company.com
ProxyRequests Off
<Proxy *>
Order deny,allow
Allow from all
</Proxy>
ProxyErrorOverride On
ProxyPass / http://192.168.1.14:6060/
ProxyPassReverse / http://192.168.1.14:6060/
<Location />
Order allow,deny
Allow from all
</Location>
</VirtualHost>
Gitlab.conf
LoadModule ssl_module modules/mod_ssl.so
SSLSessionCache "shmcb:logs/ssl_scache(512000)"
<VirtualHost *:443>
SSLEngine on
#strong encryption ciphers only
#see ciphers(1) http://www.openssl.org/docs/apps/ciphers.html
SSLCipherSuite SSLv3:TLSv1:+HIGH:!SSLv2:!MD5:!MEDIUM:!LOW:!EXP:!ADH:!eNULL:!aNULL
SSLCertificateFile /etc/pki/tls/certs/ca.crt
SSLCertificateKeyFile /etc/pki/tls/private/ca.key
SSLCACertificateFile /etc/pki/tls/certs/ca.crt
ServerName 127.0.0.1
ServerSignature Off
ProxyPreserveHost On
<Location />
Order deny,allow
Allow from all
ProxyPassReverse http://127.0.0.1:8080
ProxyPassReverse http://127.0.0.1/
</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
RewriteCond %{DOCUMENT_ROOT}/%{REQUEST_FILENAME} !-f
RewriteRule .* http://127.0.0.1:8080%{REQUEST_URI} [P,QSA]
RequestHeader set X_FORWARDED_PROTO 'https'
# needed for downloading attachments
DocumentRoot /home/git/gitlab/public
#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 503 /deploy.html
LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b" common_forwarded
ErrorLog /var/log/httpd/logs/gitlab.example.com_error.log
CustomLog /var/log/httpd/logs/gitlab.example.com_forwarded.log common_forwarded
CustomLog /var/log/httpd/logs/gitlab.example.com_access.log combined env=!dontlog
CustomLog /var/log/httpd/logs/gitlab.example.com.log combined
</VirtualHost>
У вас несоответствие между
NameVirtualHost *:80
и
<VirtualHost *>
Вам нужно изменить VirtualHost
быть таким же, как NameVirtualHost
, т.е.
<VirtualHost *:80>
Что касается перенаправления, ответ vic должен помочь - если нет, посмотрите Перенаправление, изменение URL-адресов или перенаправление HTTP на HTTPS в Apache - все, что вы когда-либо хотели знать о правилах Mod_Rewrite, но боялись спросить
Я знаю, что очень опаздываю на вечеринку, но когда я искал ответ, это отображается в верхней части поисковой системы. Это работает для меня как шарм:
<VirtualHost YOUR.SERVERS.IP.HERE:80>
RewriteEngine on
ReWriteCond %{SERVER_PORT} !^443$
RewriteRule ^/(.*) https://%{HTTP_HOST}/$1 [NC,R,L]
</VirtualHost>
Используйте эти правила, которые у меня сработали:
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule (.*) (https)://%{HTTP_HOST}%{REQUEST_URI}
RewriteEngine On
RewriteRule ^apache-redirect-http-to-https\.html$ (https)://www.yoursite.com/apache-redirect-http-to-https.html [R=301,L]
Примечание: remove () со ссылкой https. Это мои конфиги:
NameVirtualHost *:80
<VirtualHost *:80>
ServerName mysite.example.com
DocumentRoot /usr/local/apache2/htdocs
Redirect permanent / https://mysite.example.com/
</VirtualHost>
<VirtualHost _default_:443>
ServerName mysite.example.com
DocumentRoot /usr/local/apache2/htdocs
SSLEngine On
# etc...
</VirtualHost>