JenkinsとGitBcketの連携・ビルドまで
Jenkinsで作成したジョブを実行すればGitBcketで管理されたソースを各サーバに配布するとこまでを目的とし検証してみました。
ただし、Jenkinsの連携機能であるGitで pushやPull RequestをきっかけでWebhookにてJenkinsのジョブを自動実行は、ITインフラにおいてシステムの全体停止を招く可能性があるため、採用しないこととする。そのため、Jenkinsのジョブ実行は手動とします。
(Jenkinsの特性を理解できれば後々、masterブランチにpushされた場合は、開発環境にWebhookでビルド・デプロイし、releaseブランチにpushされた場合は、本番環境にWebhookでビルド・デプロイするとこまで自動化したいと思います。)
まずは、GitBcketと連携するためにJenkinsにプラグインを導入しビルドするまでの設定を行っていきます。
前回のJenkins環境の構築は、Jenkinsをdocker上に構築を参照。
この検証をするにあたり前提となる運用ルールは、サイト管理のためのGit運用フローを作ってみました。を参照。
前々回のGitBucket環境の構築はGitBucketをdockerで構築を参照。
ちなみにバージョン管理及びCIでちょいちょい出てくる、ビルドとデプロイの違いを私は理解していなかったので以下のリンクに分かり易く説明されているので参考にさせていただきました。
ビルドとデプロイって結局なんやねん!?!?!???みたいな記事
1.Jenkinsの設定
1.1. 環境
CentOS : 7.5.1804 Docker : 18.09.0, build 4d60db4 Docker-compose : 1.23.2, build 1110ad01 ※Dockerには、[Docker CE]とエンタープライズ版の[Docker EE]がありますが、今回は無償の[Docer CE]を使用します。 GitBucket 4.29.0 Jenkins 2.150 (LTS版)
1.2. Jenkinsのプラグイン管理
まずは、JenkinsとGitBcketを連携するためにJenkinsにGitBcketプラグインを導入していきたいと思います。
- Jenkinsにログインし、[ダッシュボード]-[Jennkinsの管理]クリック
- Jenkins管理画面で[プラグインの管理]をクリック
- [利用可能]をクリックし、フィルターに以下を入力し、チェックを入れて「ダウンロードして再起動後インストール後」をクリック。
- GIT client plugin ※1
- GIT plugin ※1
- GIT server plugin ※1
- GitBucket Plugin
※1 : Jenkins初回アクセス時に「Install suggested plugin」を選択するか「Select plugins to install」を選択したうえで個別に選択しインストールしていれば必要ありません。
- 成功と出力されればプラグインのインストールは完了です。
1.3. Projectの作成(とりあえずWebhookを使わずビルドまで)
- 「Enter an item name」にプロジェクト名を入力し、今回はGitBucketとの連携しビルドするので「フリースタイル・プロジェクトのビルド」をクリック。
- 説明にプロジェクトの説明を入力し、GitBcketのURLに「http://
:8888/ / 」を入力。
- ソースコード管理で「Git」を選択しリポジトリURLに「http://
:8888/git/ / .git」を入力。
- リポジトリの認証情報の「追加」ボタンをクリックし、「ユーザ名」にGitBcketのユーザ名と「パスワード」にGitBcketのユーザのパスワードを入力し「追加」ボタンをクリック。
- リポジトリの認証情報のプルダウンをクリックし、先ほど入力したGitBcketのユーザ名を選択する。
- ビルド・トリガで「Build when a chenge is pushed to GitBucket」、「Pass-through Git Commit」を選択し、「保存」ボタンをクリックする。
1.4. Jenkinsジョブの実行
- プロジェクト画面で「ビルドの実行」をクリック。
- 「最新のビルド」をクリック。
- 出力されたビルド結果を確認し、エラーが出力されていないことを確認する。
4.Jenkinsサーバにjenkins起動ユーザでSSHでログインし、jenkins起動ユーザのhomeディレクトリの「jenkins_home/workspace/
1.5. GitbucketのWebhook設定
Gitbucketにpushされた場合にwebhookでjonekinsジョブを実行できるように設定します。
ただし、最終的な目標であるmasterブランチにpushされた場合は、開発環境にWebhookでビルド・デプロイし、releaseブランチにpushされた場合は、本番環境にWebhookでビルド・デプロイするとこまで自動化するためにWebhook毎に対象ブランチを設定できると想像していましたが、設定項目を見るとそれにあたる設定項目がないので更に調査が必要です。。。
なので、以下は次回の参考にまで・・・。
- Gitbucketにログインし「Settings」-「Service Hooks」タブをクリックし「Add webhook」をクリック。
- Payload URLに「JenkinsのURL+gitbucket-webhook/」を入力し「Push」にチェックを入れ、「Add webhook」ボタンをクリック。
以上