LoginSignup
2
1

More than 1 year has passed since last update.

JenkinsサーバーをAWS EC2上で作った

Last updated at Posted at 2022-07-28

はじめに

書き主はサーバーエンジニアではないため
サーバーなどの設定が甘い場合などがあります、参考にする際にはご注意ください。
あと、一部そのままのコピペでは動かないようなものもございますのでご注意ください。

動機

現在は大阪の拠点の中でローカルのPCの中でjenkinsサーバーを立ており。
そのサーバーからビルドをするPCをjenkinsにて繋ぎ、
自動ビルドや、定期的なコマンドを実行するなどの動作をしていた。

ただ、最近のコロナ禍により、リモートワークなどが多くなったため、
社外からjenkinsにアクセスする必要性などが出てきた。

じゃあ!サーバー側だけEC2に移して社外からアクセスが出来るようにしよう!

というのが動機になります。

今回はjenkinsサーバーの作成の部分だけ記事化してみました。

jenkinsサーバー作成

ざっくり仕様

  • AWS(EC2)上にjenkinsサーバーを設置し、大阪のローカルマシン(ノード)でビルドを行えるようにする。
  • sslを設定

以上!

EC2の仕様について

  • Ami名 : amzn-ami-2018.03.20210915-amazon-ecs-optimized
  • インスタンスタイプ : t2.micro
  • ボリュームサイズ : 8gb(ビルドマシンではないため最低限のサイズがあれば良い、好みで変更してください)

yumの更新と必要パッケージのインストール

$ sudo yum update
$ sudo yum install git java

dockerにユーザー追加

  • dockerについてはAmiに入っているので、ユーザーの追加だけをしておく
$ docker -v
Docker version 20.10.13, build a224086
$ sudo usermod -a -G docker ec2-user

DockerCompose追加

$ sudo curl -L https://github.com/docker/compose/releases/download/v2.7.0/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose
$ sudo chmod +x /usr/local/bin/docker-compose
$ docker-compose --version
Docker Compose version v2.7.0

docker用のフォルダの作成

$ cd /
$ sudo mkdir docker
$ cd docker
$ sudo mkdir jenkins
$ sudo chmod 777 jenkins
$ cd jenkins
  • 今回はここでGitを利用して作成をしたdocker-compese.ymlのbuildファイルなどを引っ張ってきた
  • docker-compose.ymlについては仮で以下を使ったという想定(細かくは違うので動作保証はできません)
docker-compose.yml
version: '3.7'
services:
	nginx:
		image: nginx:1.21.1
		restart: always
		environment:
		TZ: Asia/Tokyo
		depends_on:
			- jenkins
		ports:
			- "80:80"
			- "443:443"
		volumes:
			- /etc/passwd/:/etc/passwd/:ro
			- /etc/group/:/etc/group/:ro
			- ./etc/letsencrypt/:/etc/letsencrypt/:ro # ssl格納場所
			- ./etc/nginx/conf.d/:/etc/nginx/conf.d/:rw
			- ./var/www/html/:/var/www/html/:rw # 初期ルート
			- ./var/log/nginx/:/var/log/nginx/:rw # ログ保存用

	certbot:
		image: certbot/certbot:v1.21.0
		volumes:
			- ./etc/letsencrypt/:/etc/letsencrypt/:rw
			- ./var/log/letsencrypt/:/var/log/letsencrypt/:rw
			- ./var/www/html/:/var/www/html/:rw
		command: [ "--version" ]

	jenkins:
		image: jenkins/jenkins:2.300
		container_name: jenkins
		restart: always
		environment:
			LANGUAGE: ja_JP.UTF-8
			LANG: ja_JP.UTF-8
			LC_ALL: ja_JP.UTF-8
		ports:
			- "8080:8080"
			- "50000:50000" # SlaveからjenkinsにつなぐためのIP
		volumes:
			- /etc/passwd/:/etc/passwd/:ro
			- /etc/group/:/etc/group/:ro
			- ./var/jenkins_home/:/var/jenkins_home/:rw # jenkinsのWebRootみたいなもの
			- ./var/run/docker.sock/:/var/run/docker.sock/:rw
  • docker-compose buildで初期設定ファイルの作成
$ cd /docker/jenkins
$ ls
docker-compose.yml 
$ docker-compose build
$ docker-compose up
~ ログが落ち着いてから停止する ~
$ docker-compose down

nginx用の初期confの作成

  • nginxのルート設定を行う
($ cd /docker/jenkins)
$ cd etc/nginx/conf.d/
$ sudo vi default.conf
  • default.confの作成する。中身的には以下
  • example.comの部分はRoute53で作ったドメインなどに指定してください。
default.conf
server {
    server_name  example.com;
    listen 80;
    listen [::]:80;

    root         /var/www/html;
}

sslの証明書の取得

  • dockerを立ち上げる
$ cd /docker/jenkins
$ docker-compose up -d
  • 初回のsslの取得を行う
$ docker-compose run --rm certbot certonly --webroot -w /var/www/html -d example.com

sslに対応したnginxのconfへの修正

  • 証明書を取得できたらconfを修正し、sslを有効にする
$ cd /docker/jenkins/etc/nginx/conf.d/
$ sudo vi default.conf
default.conf
server {
	server_name example.com;
	listen 80;
	listen [::]:80;
	location /.well-known/acme-challenge/ {
		root /var/www/html/;
	}
	location / {
		return 301 https://example.com$request_uri;
	}
}

server {
	server_name example.com;
	listen 443 ssl http2;
	listen [::]:443 ssl http2;
	ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
	ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
	ssl_session_timeout 1d;
	ssl_session_cache shared:SSL:10m;
	ssl_session_tickets off;
	ssl_protocols TLSv1.3 TLSv1.2;
	ssl_ciphers 'ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-RSA-AES128-GCM-SHA256';
	ssl_prefer_server_ciphers off;
	add_header Strict-Transport-Security "max-age=2592000" always;
	access_log /var/log/nginx/access.log;
	error_log /var/log/nginx/error.log;
	location / {
		proxy_pass    http://jenkins:8080;
	}
}
  • nginxを再起動する
$ docker-compose exec nginx nginx -s reload
  • https://example.com/ にアクセスし、jenkinsが表示されるのを確認する。

作った後で入れといた方が良かったかもっていう設定

参考サイト

編集履歴

  • 2022/11/18 : 内容的におかしい文言の修正
2
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
1