Bir Apache sunucusunun arkasında iki hizmet çalıştırıyorum: Jenkins (Port 8080) ve SonarQube (Port 9000).
Apache yapılandırmam şöyle görünüyor:
<VirtualHost *:80>
ServerName server
Redirect permanent / https://server.domain.com/
</VirtualHost>
<VirtualHost *:80>
ServerName server.domain.com
Redirect permanent / https://server.domain.com/
</VirtualHost>
<VirtualHost *:443>
ServerName server.domain.com
SSLEngine on
SSLCertificateFile /etc/ssl/certs/server.crt
SSLCertificateKeyFile /etc/ssl/private/server.key
ProxyPass /jenkins http://localhost:8080/jenkins nocanon
ProxyPassReverse /jenkins http://localhost:8080/jenkins
ProxyPassReverse /jenkins http://server.domain.com/jenkins
ProxyPassReverse /jenkins https://server.domain.com/jenkins
ProxyPass /sonar http://localhost:9000/sonar nocanon
ProxyPassReverse /sonar http://localhost:9000/sonar
AllowEncodedSlashes NoDecode
ProxyRequests Off
ProxyPreserveHost On
<Proxy http://localhost:8080/*>
Order deny,allow
Allow from all
</Proxy>
</VirtualHost>
Jenkins'in bu mesajla şikayet etmesi dışında her şey iyi çalışıyor gibi görünüyor: Görünüşe göre ters proxy kurulumunuz bozuldu.
Jenkins tarafından sağlanan ReverseProxySetupMonitor sınamasını çalıştırdığımda, hata iletisi, ters proxy'ye sahip bir şeyin doğru şekilde ayarlanmadığını, http'yi https ile değiştirmediğini gösterir:
$ curl -iLk -e https://server.domain.com/jenkins/manage https://server.domain.com/jenkins/administrativeMonitor/hudson.diagnosis.ReverseProxySetupMonitor/test
[...]
404 http://server.domain.com/jenkins/manage vs. https://server.domain.com/jenkins/manage
[...]
Bu yalnızca sunucuda SSL'yi etkinleştirdikten sonra ortaya çıktı (şu anda kendinden imzalı bir sertifika kullanıyor).
Soru: Jenkins'in mutlu olması için ters proxy kurulumunu nasıl düzeltirim? Apache yapılandırma dosyasının nasıl geliştirileceğine dair ipuçları için bonus puanlar.
Aşağıdaki iki ilgili soruyu zaten kontrol ettim:
sudo a2enmod headers
, aksi takdirde alacağımInvalid command 'RequestHeader'