Casual Developers Note

エンジニアやデザイナー向けの技術情報・英語学習情報・海外留学情報・海外旅行情報を提供中。世界を旅して人生を楽しもう。

  • ホーム
  • 技術 Tips & Tutorials
  • 技術塾
  • ライフハック
  • 海外留学
  • 英語学習
  • コラム
  • お問い合わせ
現在の場所:ホーム / アーカイブjenkins-pipeline

2018年12月3日 By KD コメントを書く

爆速でJenkinsをマスターしよう(Docker編) ~ JenkinsコンテナへのDockerインストール方法からJob DSL、Jenkins Pipelineまで ~

爆速でJenkinsをマスターしよう(Docker編) ~ JenkinsコンテナへのDockerインストール方法からJob DSL、Jenkins Pipelineまで ~

Docker上でアプリケーション開発から運用まで完結させる開発スタイルは今まさに求められています。今回はDocker前提としてDevOpsのCI/CDを実現させるために、JenkinsにDockerをインストールしてパイプラインで自動ビルドする方法を紹介します。

はじめに

以前の記事「爆速でJenkinsをマスターしよう(NodeJS編)」では、Jenkinsの基本的なインストール方法から始まり、Job DSLによる新しいジョブの作成方法、NodeJSアプリケーションの自動テスト方法、GitHubのコミットをトリガーにした自動ビルド方法を爆速で紹介しました。

今回は、JenkinsにDockerをインストールして、Jod DSLでパイプラインジョブを追加し、Jenkins Pipelineで自動ビルドする方法を紹介します。

前提

以下の準備が完了している必要があります。

  • Dockerがインストールされていること
  • GitHubのアカウントがあること
  • DockerHubのアカウントがあること

詳しいバージョンは「環境」を参照してください。

Docker入りのJenkinsのセットアップ

まずはDockerコマンドを使えるようにしたJenkinsをセットアップしましょう。

ベースを作る

必要なフォルダとファイルを作りましょう。

$ mkdir devops_jenkins_docker
$ cd devops_jenkins_docker
$ touch Dockerfile
$ touch docker-compose.yml

Dockerファイルを作る

Dockerfile

以下のようにDocker CEをJenkins内にインストールするようにします。

FROM jenkins

USER root

RUN apt-get update \
  && apt-get install -y \
  apt-utils \
  apt-transport-https \
  ca-certificates \
  curl \
  software-properties-common \
  && curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add - \
  && apt-key fingerprint 0EBFCD88 \
  && add-apt-repository \
  "deb [arch=amd64] https://download.docker.com/linux/ubuntu xenial stable" \
  && apt-get update \
  && apt-get install -y docker-ce \
  && apt-get clean \
  && rm -rf /var/lib/apt/lists/* \
  && usermod -aG docker jenkins

RUN cd tmp/ \
  && wget https://updates.jenkins-ci.org/latest/jenkins.war \
  && mv ./jenkins.war /usr/share/jenkins/

USER jenkins

docker-compose.yml

Dockerコンテナ上でDockerコマンドを実行するために「/var/run/docker.sock」のボリュームを設定します。

version: "3"

services:
  jenkins:
    build: .
    ports:
      - 8080:8080
    volumes:
      - ./jenkins_home:/var/jenkins_home
      - /var/run/docker.sock:/var/run/docker.sock

Jenkinsの起動

それではDockerからJenkinsを起動しましょう。「/var/run/docker.sock」の権限変更を忘れずに行いましょう。

$ docker-compose up --build -d
$ docker-compose ps
             Name                            Command               State                 Ports
------------------------------------------------------------------------------------------------------------
devops_jenkins_docker_jenkins_1   /bin/tini -- /usr/local/bi ...   Up      50000/tcp, 0.0.0.0:8080->8080/tcp
$ docker-compose exec -u root jenkins chmod 666 /var/run/docker.sock
$ docker-compose logs -f jenkins
...
jenkins_1  | *************************************************************
jenkins_1  | *************************************************************
jenkins_1  | *************************************************************
jenkins_1  |
jenkins_1  | Jenkins initial setup is required. An admin user has been created and a password generated.
jenkins_1  | Please use the following password to proceed to installation:
jenkins_1  |
jenkins_1  | c834fdf8220943fab0454f1f0ff823ea
jenkins_1  |
jenkins_1  | This may also be found at: /var/jenkins_home/secrets/initialAdminPassword
jenkins_1  |
jenkins_1  | *************************************************************
jenkins_1  | *************************************************************
jenkins_1  | *************************************************************
...

初期化キーとして「c834fdf8220943fab0454f1f0ff823ea」をメモしておきます。

Jenkinsのセットアップ

ブラウザで「localhost:8080」にアクセスして、セットアップを完了します。

NewImage

NewImage

NewImage

NewImage

NewImage

NewImage

NewImage

Jenkinsのインストールが完了しました。

Dockerの動作確認

JenkinsからDockerが実行できるかテストしましょう。

ホーム画面から「新しいジョブ」をクリックします。

NewImage

任意のジョブ名(今回は「test_docker」)を入力し、「パイプライン」を選択し、「OK」をクリックします。

NewImage

「パイプライン」から「Pipeline script」を選択し、以下の「Script」を入力し、「保存」をクリックします。

node {
  docker.image('alpine:latest').inside {
    sh 'echo Hello Docker!'
  }
}

NewImage

「ビルド実行」をクリックしてテストを実行します。

NewImage

ビルドが成功しました。

NewImage

これでDockerがJenkinsから実行されていることを確認できました。

DockerHub用の認証情報の追加

今回は最終的にビルドしたDockerイメージをDockerHub上にPushするので、DockerHubのアカウント情報をJenkinsに追加する必要があります。

ホーム画面から「認証情報」をクリックします。

NewImage

「Jenkins」をクリックします。

NewImage

「グローバルドメイン」から「Add credentials」をクリックします。

NewImage

「ユーザー名とパスワード」を選択し、DockerHubのアカウントのユーザ名とパスワードを入力し、任意のID(今回は「dockerhub-credentials」)を付けて、「保存」をクリックします。

NewImage

追加した認証情報が表示されています。

NewImage

Job DSL用のプラグインを追加

後でJob DSLを使うので、プラグインをインストールします。

NewImage

Jenkinsの再起動が完了すればOKです。

サンプルDockerアプリケーションの作成

ベースの作成

以前の記事「爆速でJenkinsをマスターしよう(NodeJS編)」で作成したNodeJSアプリケーションをそのままDocker化して使いましょう。

$ git clone https://github.com/{your-github-account}/devops_sample_nodejs.git
$ cd devops_sample_nodejs
$ touch Dockerfile

NodeJSアプリケーションのDocker化

Docker化して動作確認をしましょう。

Dockerfile

Dockerfileを以下のように書きます。

FROM node:11-alpine

WORKDIR /app

COPY package.json ./
COPY package-lock.json ./
RUN npm install

COPY ./ ./

CMD npm start

ビルドと実行

Dockerとしてビルドができ、Docker上でコマンドが実行できることを確認しましょう。

$ docker image build -t devops_sample_nodejs:latest .
$ docker container run devops_sample_nodejs:latest
...
Next year is 2019.
2 years until Tokyo Olympic.
The tax of 100 yen is 10 yen if the tax rate is 10%.
I baked 10 cookies. There're 5 people here so you can eat 2.
$ docker container run devops_sample_nodejs:latest npm test
...
PASS test/utis.spec.js
  utils test
    math test
      ✓ should be 3 when adding 1 and 2 (7ms)
      ✓ should be -1 when subtracting 2 from 1
      ✓ should be 12 when multipying 3 by 4 (1ms)
      ✓ should be 4 when dividing 8 by 4

Test Suites: 1 passed, 1 total
Tests:       4 passed, 4 total
Snapshots:   0 total
Time:        1.718s
Ran all test suites.
$ git add .
$ git commit -m 'Dockerize app'
$ git push origin master

OKですね。これをGitHubにPushしておきましょう。

Jenkins PipelineのためのJenkinsfileの作成

ベースを作る

パイプライン用のファイルを準備します。

$ mkdir misc
$ touch misc/Jenkinsfile

Jenkinsfileにパイプラインの設定を書く

Jenkinsfile

パイプライン上で、GitHubからのクローン、Dockerイメージのビルド、Docker内でのテスト、DockerHubへのイメージのPush、を実行するようにします。

node {
  def app

  stage('Clone repository') {
    checkout scm
  }

  stage('Build image') {
    app = docker.build('{your-dockerhub-account}/devops_sample_nodejs')
  }

  stage('Test') {
    app.inside {
      sh 'npm install --only=dev'
      sh 'npm test'
    }
  }

  stage('Push image') {
    docker.withRegistry('https://registry.hub.docker.com', 'dockerhub-credentials') {
      app.push("latest")
    }
  }
}

「{your-dockerhub-account}」は自分のDockerHubのアカウント名を置き換えてください。

Job DSLによるパイプラインジョブの追加

ベースを作る

Job DSL用のファイルを作成します。

$ touch pipeline.groovy

Job DSLの設定ファイルを書く

pipeline.groovy

Job DSLには以下のように、5分単位のポーリング、パイプライン用のJenkinsfileのパス指定、を設定します。

pipelineJob('Pipeline Basic Job') {

  def repo = 'https://github.com/{your-github-account}/devops_sample_nodejs.git'

  description("Pipeline for $repo")

  triggers {
    scm('H/5 * * * *')
  }

  definition {
    cpsScm {
      scm {
        git {
          remote { url(repo) }
          branches('master')
          scriptPath('misc/Jenkinsfile')
          extensions { }
        }
      }
    }
  }
}

「{your-github-account}」は自分のGitHubのアカウント名に置き換えてください。

GitHubにPushする

パイプライン用に作成したファイルをGitHubにPushしておきます。

$ git add .
$ git commit -m 'Add pipeline'
$ git push origin master

Job DSLから新しいJenkins Pipelineのジョブを追加する

ホーム画面から「新規ジョブ作成」から、任意の名前(今回は「seed_job」)を入力し、「フリースタイル・プロジェクトのビルド」を選択し、「OK」をクリックします。

NewImage

「ソースコード管理」の「Git」を選択し、「リポジトリURL」を入力します。

NewImage

「ビルド」の「Process Job DSLs」をクリックします。

NewImage

「DSL Scripts」にDSLファイル名を入力し、「保存」をクリックします。

NewImage

「In-process Script Approval」をクリックします。

NewImage

「Approve」をクリックします。

NewImage

これでDSLが承認されました。

NewImage

プロジェクト画面に戻って、「ビルド実行」をクリックします。

NewImage

ビルドが成功し、新しいジョブが作成されました。

NewImage

自動作成されたジョブ内容の確認

DSLで自動作成されてパイプラインジョブの設定を確認しましょう。

NewImage

「設定」をクリックします。

NewImage

「説明」が正しく設定されています。

NewImage

「スケジュール」が正しく設定されています。

NewImage

「リポジトリURL」が正しく設定されています。

NewImage

これでパイプラインジョブの設定が完了です。

CIの動作確認

最後に、Jenkins上でDockerを動かし、自動ビルドしてみましょう。

パイプラインによる自動ビルドの実行

「ビルド実行」をクリックします。(キャプチャでは、パイプラインが見やすいように予め複数回ビルドを実行してあります。)

NewImage

ビルドが成功しました。

NewImage

自動的にテストが実行されています。

NewImage

自動的にDockerイメージがDockerHubにPushされています。

NewImage

ジョブの画面に戻ると、パイプラインで実行したステージが確認できます。

NewImage

DockerHubの画面も確認してみましょう。

NewImage

正しくDockerHubにイメージがPushされています。

これで完了です。

最後に

いかがでしたか?これでDockerアプリケーションをJenkinsでビルドする方法やパイプラインの使い方をマスターできたことでしょう。今回はNodeJSベースのDockerアプリケーションですが、当然他の言語でも動きます。JenkinsとDockerを使いこなしてCI/CDを開発現場で実施していきましょう。それでは。

環境

  • Docker: 18.06.1-ce, build e68fc7a
  • Jenkins: 2.151

カテゴリ : 技術 Tips & Tutorials タグ : cicd, devops, docker, jenkins, jenkins-job-dsl, jenkins-pipeline

  • « 前のページ
  • 1
  • 2

ブログ更新情報や海外の関連情報などを配信する無料メルマガ

Sponsored Links

About Author

KD

世界を旅し日本を愛するエンジニア。大学でコンピュータサイエンスの楽しさを学び、日本の大手IT企業で働く中で、新しい技術やスケールするビジネスが北米にある事に気づく。世界に挑戦するための最大の壁が英語であったため、フィリピン留学およびカナダ留学を経て英語を上達させた。現在は日本在住でエンジニアとして働きつつ、次の挑戦に備えて世界の動向を注視している。挑戦に終わりはない。このブログでは、エンジニアやデザイナー向けの技術情報から、海外に留学したい人向けの留学情報、海外に興味がある人向けの海外旅行情報など、有益な情報を提供しています。

https://casualdevelopers.com/

最近の投稿

  • 2020年JS周辺のバックエンド寄りの注目技術!ネクストNodeJSの「Deno」と分散型パッケージレジストリの「Entropic」の紹介

    2020年JS周辺のバックエンド寄りの注目技術!ネクストNodeJSの「Deno」と分散型パッケージレジストリの「Entropic」の紹介

    2020年1月13日
  • 今さら聞けないJavaによる関数型プログラミング入門 ~ラムダ式、ストリーム、関数型インターフェース~

    今さら聞けないJavaによる関数型プログラミング入門 ~ラムダ式、ストリーム、関数型インターフェース~

    2019年11月4日
  • ReactのためのEslintおよびPrettierの設定方法 ~Airbnb JavaScript Style Guideの適用~

    ReactのためのEslintおよびPrettierの設定方法 ~Airbnb JavaScript Style Guideの適用~

    2019年10月30日
  • BashからZshに移行する方法(Mac編)

    BashからZshに移行する方法(Mac編)

    2019年10月21日
  • Create React Appを使わないでゼロからReactの開発環境を構築する方法(Webpack/Docker編)

    Create React Appを使わないでゼロからReactの開発環境を構築する方法(Webpack/Docker編)

    2019年9月30日

カテゴリ

  • 技術 Tips & Tutorials (100)
  • 技術塾 (6)
  • ライフハック (26)
  • 海外留学 (12)
  • 英語学習 (3)
  • コラム (6)

アーカイブ

最高の学習のために

人気記事ランキング

  • MySQLで「ERROR 2003 (HY000): Can't connect to MySQL server」と怒られた時の対処法
    MySQLで「ERROR 2003 (HY000): Can't connect to MySQL server」と怒られた時の対処法
  • SAKURAのメールボックスで独自ドメインのメールを設定し、Gmail経由で送受信する方法
    SAKURAのメールボックスで独自ドメインのメールを設定し、Gmail経由で送受信する方法
  • Expressで「Cannot set headers after they are sent to the client」と怒られた時の対処法
    Expressで「Cannot set headers after they are sent to the client」と怒られた時の対処法
  • AWS ECRとECSの入門(EC2編) ~ ECSのEC2版を使ってReactのDockerアプリケーションをAWS上で稼働させる方法 ~
    AWS ECRとECSの入門(EC2編) ~ ECSのEC2版を使ってReactのDockerアプリケーションをAWS上で稼働させる方法 ~
  • 爆速でJenkinsをマスターしよう(GitHubアカウント統合編) ~ JenkinsのGitHub Organizationの設定方法 ~
    爆速でJenkinsをマスターしよう(GitHubアカウント統合編) ~ JenkinsのGitHub Organizationの設定方法 ~
  • Amazon EC2インスタンスにSSHできなくなった時の対処法
    Amazon EC2インスタンスにSSHできなくなった時の対処法
  • バンクーバー留学豆知識:バンクーバーのATMで日本の銀行のキャッシュカードを使ってお得にお金を引き出す方法
    バンクーバー留学豆知識:バンクーバーのATMで日本の銀行のキャッシュカードを使ってお得にお金を引き出す方法
  • Jupyter Notebookで「The kernel appears to have died. It will restart automatically.」というエラーが出た場合の原因と対処法
    Jupyter Notebookで「The kernel appears to have died. It will restart automatically.」というエラーが出た場合の原因と対処法
  • [tips][bat] バッチで明日の日付を計算する。
    [tips][bat] バッチで明日の日付を計算する。
  • [tips][perl] Perlで文字コードをいい感じに処理する方法
    [tips][perl] Perlで文字コードをいい感じに処理する方法

Bitcoin寄付 / BTC Donation

Bitcoinを寄付しよう

BTC
Select Payment Method
Personal Info

Donation Total: BTC 0.0010

このブログの運営のためにBitcoinでの寄付を募集しています。お気持ち程度の寄付を頂けると管理者の励みになります。

Bitcoin寄付について知りたい方はこちらの記事へ

ビットコイン取引ならここ

  • ホーム
  • 技術 Tips & Tutorials
  • 技術塾
  • ライフハック
  • 海外留学
  • 英語学習
  • コラム
  • サイトマップ
  • タグ一覧
  • プライバシーポリシー
  • お問い合わせ

Copyright © 2023 KD - Casual Developers Notes