Jumkinsを実行しているFedoraサーバーがあり、yum経由でインストールします。すべて問題ありません。http://ci.mydomain.com
でアクセスできます。
しかし、今はhttps://ci.mydomain.com
でアクセスしたいので、ユーザー名とパスワードでのログインは暗号化されます。
これどうやってするの?
以下は、私の/etc/sysconfig/jenkins
ファイルです。 Jenkinsの起動は機能しますが、https://ci.mydomain.com
またはhttp://ci.mydomain.com:443
、...を使用してWebブラウザーでJenkinsにアクセスできません。
## Path: Development/Jenkins
## Description: Configuration for the Jenkins continuous build server
## Type: string
## Default: "/var/lib/jenkins"
## ServiceRestart: jenkins
#
# Directory where Jenkins store its configuration and working
# files (checkouts, build reports, artifacts, ...).
#
JENKINS_HOME="/var/lib/jenkins"
## Type: string
## Default: ""
## ServiceRestart: jenkins
#
# Java executable to run Jenkins
# When left empty, we'll try to find the suitable Java.
#
JENKINS_Java_CMD=""
## Type: string
## Default: "jenkins"
## ServiceRestart: jenkins
#
# Unix user account that runs the Jenkins daemon
# Be careful when you change this, as you need to update
# permissions of $JENKINS_HOME and /var/log/jenkins.
#
JENKINS_USER="jenkins"
## Type: string
## Default: "-Djava.awt.headless=true"
## ServiceRestart: jenkins
#
# Options to pass to Java when running Jenkins.
#
JENKINS_Java_OPTIONS="-Djava.awt.headless=true"
## Type: integer(0:65535)
## Default: 8080
## ServiceRestart: jenkins
#
# Port Jenkins is listening on.
#
JENKINS_PORT="8080"
## Type: integer(1:9)
## Default: 5
## ServiceRestart: jenkins
#
# Debug level for logs -- the higher the value, the more verbose.
# 5 is INFO.
#
JENKINS_DEBUG_LEVEL="5"
## Type: yesno
## Default: no
## ServiceRestart: jenkins
#
# Whether to enable access logging or not.
#
JENKINS_ENABLE_ACCESS_LOG="no"
## Type: integer
## Default: 100
## ServiceRestart: jenkins
#
# Maximum number of HTTP worker threads.
#
JENKINS_HANDLER_MAX="100"
## Type: integer
## Default: 20
## ServiceRestart: jenkins
#
# Maximum number of idle HTTP worker threads.
#
JENKINS_HANDLER_IDLE="20"
## Type: string
## Default: ""
## ServiceRestart: jenkins
#
# Pass arbitrary arguments to Jenkins.
# Full option list: Java -jar jenkins.war --help
#
JENKINS_ARGS="--httpsPort=443 --httpsKeyStore=/root/.keystore --httpsKeyStorePassword=MYPASSWORD"
このページは、Apache(HTTPSを処理する)の背後で設定するのに役立ちます。 https://wiki.Eclipse.org/Hudson-ci/Running_Hudson_behind_Apache
「通常の」リバースプロキシであることは別にして、(このページに示すように)これが必要になります。
Header edit Location ^http://www.example.com/hudson/ https://www.example.com/hudson/
ApacheではなくNginxを使用している場合に備えて、proxy_redirect http:// https://;
応答がJenkinsから返されたときにLocationヘッダーを書き換えます。
SSLがNginxで終了し、8080を使用して内部でJenkinsにプロキシされる完全なnginx設定は次のようになります。
upstream jenkins {
server 127.0.0.1:8080 fail_timeout=0;
}
server {
listen 80 default;
server_name 127.0.0.1 *.mydomain.com;
rewrite ^ https://$server_name$request_uri? permanent;
}
server {
listen 443 default ssl;
server_name 127.0.0.1 *.mydomain.com;
ssl_certificate /etc/ssl/certs/my.crt;
ssl_certificate_key /etc/ssl/private/my.key;
ssl_session_timeout 5m;
ssl_protocols SSLv3 TLSv1;
ssl_ciphers HIGH:!ADH:!MD5;
ssl_prefer_server_ciphers on;
# auth_basic "Restricted";
# auth_basic_user_file /home/jenkins/htpasswd;
location / {
proxy_set_header Host $http_Host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_redirect http:// https://;
add_header Pragma "no-cache";
proxy_pass http://jenkins;
}
}
Jenkinsがキーを生成できることに注意してください(いつか?)。JENKINS_ARGS
で--httpsPort=(portnum)
パラメータを設定するだけで済みます。
私の場合、私はJENKINS_PORT="-1"
(httpを無効にする)を設定し、--httpsPort=8080
を設定しました。
通常、1000未満のポートにはrootアクセスが必要なので、それより高いポートを選択してください...
( リンク 詳細情報)
Ubuntuサーバーの場合(apt-get install jenkins
でインストールした場合):
ファイルの下部にある/etc/default/jenkins
を編集し、Jenkins_argsを編集します。私の議論では、httpアクセスを無効にし(-1を使用)、SSLをデフォルトのJenkinsポート(8080)に配置しました。ここで最も重要な部分は、httpsPortと証明書/キーを送信したことです(ある場合は、自己生成したものでオフにできます)。私はcrtsをApacheに配置して両方に使用しますが、どこにでも配置できます。
JENKINS_ARGS="--webroot=/var/cache/jenkins/war --httpsPort=$HTTP_PORT --httpPort=-1 --httpsCertificate=/etc/Apache2/ssl.crt/CERT.crt --httpsPrivateKey=/etc/Apache2/ssl.key/KEY.key --ajp13Port=$AJP_PORT"
場合によっては、Java Key Storeを使用する必要があります。最初に、キーを変換します。
openssl pkcs12 -inkey /var/lib/jenkins/jenkins.key.pem -in /var/lib/jenkins/jenkins.crt.pem -export -out keys.pkcs12
keytool -importkeystore -srckeystore keys.pkcs12 -srcstoretype pkcs12 -destkeystore jenkins.jks
今のようなジェンキンスの引数を使用してください
JENKINS_ARGS="--webroot=/var/cache/$NAME/war --httpsPort=$HTTP_PORT --httpPort=-1 --httpsKeyStore=/etc/Apache2/ssl.crt/jenkins.jks --httpsKeyStorePassword=thePassword --ajp13Port=$AJP_PORT"
また、 https://serverfault.com/a/569898/300544 も参照してください