Jenkins-クイックガイド
なぜジェンキンス?
Jenkinsは次のことを可能にするソフトウェアです continuous integration。Jenkinsは、中央ビルドが行われるサーバーにインストールされます。次のフローチャートは、Jenkinsがどのように機能するかについての非常に単純なワークフローを示しています。
ジェンキンスと一緒に、時々、 Hudson。Hudsonは、Sun Microsystemsによって開発された非常に人気のあるオープンソースのJavaベースの継続的インテグレーションツールであり、後にOracleに買収されました。OracleによるSunの買収後、Hudsonソースコードからフォークが作成され、Jenkinsが導入されました。
継続的インテグレーションとは何ですか?
継続的インテグレーションは、開発者が定期的にコードを共有リポジトリに統合する必要がある開発手法です。この概念は、ビルドライフサイクルで後で発生する問題を見つけるという問題を取り除くことを目的としていました。継続的インテグレーションでは、開発者が頻繁にビルドする必要があります。一般的な方法は、コードコミットが発生するたびに、ビルドをトリガーする必要があるというものです。
システム要求
JDK | JDK1.5以降 |
記憶 | 2 GB RAM(推奨) |
ディスクスペース | 最小要件はありません。すべてのビルドはJenkinsマシンに保存されるため、ビルドストレージに十分なディスク容量が利用可能であることを確認する必要があることに注意してください。 |
オペレーティングシステムのバージョン | Jenkinsは、Windows、Ubuntu / Debian、Red Hat / Fedora / CentOS、Mac OS X、openSUSE、FReeBSD、OpenBSD、Gentooにインストールできます。 |
Javaコンテナ | WARファイルは、サーブレット2.4 / JSP 2.0以降をサポートする任意のコンテナで実行できます(例はTomcat 5です)。 |
Jenkinsをダウンロード
Jenkinsの公式ウェブサイトはJenkinsです。指定されたリンクをクリックすると、以下に示すようにJenkinsの公式Webサイトのホームページが表示されます。
デフォルトでは、最新リリースと長期サポートリリースがダウンロード可能になります。過去のリリースもダウンロードできます。ダウンロードセクションの[長期サポートリリース]タブをクリックします。
「古いが安定したバージョン」のリンクをクリックして、Jenkinswarファイルをダウンロードします。
Jenkinsを起動する
コマンドプロンプトを開きます。コマンドプロンプトから、jenkins.warファイルが存在するディレクトリを参照します。次のコマンドを実行します
D:\>Java –jar Jenkins.war
コマンドの実行後、さまざまなタスクが実行されます。その1つは、winstoneと呼ばれる組み込みWebサーバーによって実行されるwarファイルの抽出です。
D:\>Java –jar Jenkins.war
Running from: D:\jenkins.war
Webroot: $user.home/ .jenkins
Sep 29, 2015 4:10:46 PM winstone.Logger logInternal
INFO: Beginning extraction from war file
大きなエラーなしに処理が完了すると、コマンドプロンプトの出力に次の行が表示されます。
INFO: Jenkins is fully up and running
Jenkinsへのアクセス
Jenkinsが起動して実行されると、リンクからJenkinsにアクセスできます- http://localhost:8080
このリンクをクリックすると、Jenkinsダッシュボードが表示されます。
Jenkins Tomcatをセットアップするには、次の前提条件が満たされている必要があります。
ステップ1:Javaインストールの確認
Javaのインストールを確認するには、コンソールを開き、次のjavaコマンドを実行します。
OS | 仕事 | コマンド |
---|---|---|
ウィンドウズ | コマンドコンソールを開く | \> java –version |
Linux | コマンドターミナルを開く | $ java –version |
Javaがシステムに正しくインストールされている場合は、作業しているプラットフォームに応じて、次のいずれかの出力が得られるはずです。
OS | 出力 |
---|---|
ウィンドウズ | Javaバージョン「1.7.0_60」 Java(TM)SEランタイム環境(ビルド1.7.0_60-b19) Java Hotspot(TM)64ビットサーバーVM(ビルド24.60-b09、混合モード) |
Linux | Javaバージョン「1.7.0_25」 JDKランタイム環境を開きます(rhel-2.3.10.4.el6_4-x86_64) JDK 64ビットサーバーVMを開きます(ビルド23.7-b01、混合モード) |
このチュートリアルの読者は、このチュートリアルに進む前に、システムにJava1.7.0_60がインストールされていることを前提としています。
Java JDKをお持ちでない場合は、リンクOracleからダウンロードできます。
ステップ2:Javaインストールの確認
Javaがマシンにインストールされているベースディレクトリの場所を指すように、JAVA_HOME環境変数を設定します。例えば、
OS | 出力 |
---|---|
ウィンドウズ | 環境変数JAVA_HOMEをC:\ ProgramFiles \ java \ jdk1.7.0_60に設定します |
Linux | エクスポートJAVA_HOME = / usr / local / java-current |
Javaコンパイラの場所のフルパスをシステムパスに追加します。
OS | 出力 |
---|---|
ウィンドウズ | 文字列を追加します。C:\ Program Files \ Java \ jdk1.7.0_60 \ binをシステム変数PATHの最後に追加します。 |
Linux | export PATH = $ PATH:$ JAVA_HOME / bin / |
上で説明したように、コマンドプロンプトからコマンドjava-versionを確認します。
ステップ3:Tomcatをダウンロードする
tomcatの公式ウェブサイトはTomcatです。所定のリンクをクリックすると、以下のようにTomcat公式サイトのホームページが表示されます。
リンクを参照する https://tomcat.apache.org/download-70.cgi Tomcatのダウンロードを取得します。
「バイナリ配布」セクションに移動します。32ビットのWindowszipファイルをダウンロードします。
次に、ダウンロードしたzipファイルの内容を解凍します。
ステップ4:JenkinsとTomcatのセットアップ
前のセクションからダウンロードしたJenkis.warファイルをコピーして、tomcatフォルダーのwebappsフォルダーにコピーします。
次に、コマンドプロンプトを開きます。コマンドプロンプトから、tomcat7フォルダーがあるディレクトリを参照します。このフォルダのbinディレクトリを参照し、start.batファイルを実行します
E:\Apps\tomcat7\bin>startup.bat
大きなエラーなしに処理が完了すると、コマンドプロンプトの出力に次の行が表示されます。
INFO: Server startup in 1302 ms
ブラウザを開き、リンクに移動します- http://localhost:8080/jenkins。JenkinsはTomcatで稼働します。
この演習では、Jenkinsがインストールされているマシンからインターネット接続が存在することを確認する必要があります。Jenkinsダッシュボード(ホーム画面)で、左側にある[Jenkinsの管理]オプションをクリックします。
次の画面で、[プラグインの管理]オプションをクリックします。
次の画面で、[利用可能]タブをクリックします。このタブには、ダウンロード可能なプラグインのリストが表示されます。[フィルター]タブで「Gitプラグイン」と入力します
その後、リストはフィルタリングされます。Gitプラグインオプションをチェックし、「再起動せずにインストール」ボタンをクリックします
その後、インストールが開始され、ダウンロードのステータスを示すために画面が更新されます。
すべてのインストールが完了したら、ブラウザで次のコマンドを発行してJenkinsを再起動します。 http://localhost:8080/jenkins/restart
Jenkinsを再起動すると、ジョブの構成中にオプションとしてGitを使用できるようになります。確認するには、Jenkinsのメニューオプションで[新しいアイテム]をクリックします。次に、ジョブの名前を入力します。次の場合、入力した名前は「デモ」です。アイテムタイプとして「フリースタイルプロジェクト」を選択します。[OK]ボタンをクリックします。
次の画面で、[ソースコード管理]セクションを参照すると、オプションとして[Git]が表示されます。
ステップ1:Mavenのダウンロードとセットアップ
Mavenの公式ウェブサイトがあるのApache Mavenの。所定のリンクをクリックすると、以下のようにMaven公式Webサイトのホームページが表示されます。
サイトを閲覧しているときに、[ファイル]セクションに移動し、Binary.zipファイルへのリンクをダウンロードします。
ファイルがダウンロードされたら、関連するアプリケーションフォルダにファイルを抽出します。この目的のために、MavenファイルはE:\ Apps \ apache-maven-3.3.3に配置されます。
ステップ2:JenkinsとMavenをセットアップする
Jenkinsダッシュボード(ホーム画面)で、左側のメニューから[Jenkinsの管理]をクリックします。
次に、右側から[システムの構成]をクリックします。
[システムの構成]画面で、[Maven]セクションが表示されるまで下にスクロールし、[Mavenの追加]ボタンをクリックします。
[自動インストール]オプションのチェックを外します。
設定の名前とMAVEN_HOMEの場所を追加します。
次に、画面の最後にある[保存]ボタンをクリックします。
これで、「Mavenプロジェクト」オプションを使用してジョブを作成できます。Jenkinsダッシュボードで、[新しいアイテム]オプションをクリックします。
Jenkins内でオプションを構成する必要があった前の演習で、おそらく2、3回見たことがあるでしょう。以下に、Jenkinsのさまざまな構成オプションを示します。
したがって、左側のメニュー側から[Manage Jenkins]オプションをクリックすると、Jenkinsのさまざまな構成オプションを取得できます。
次に、次の画面が表示されます-
[システムの構成]をクリックします。以下では、実行できるJenkins構成設定の一部について説明します。
Jenkinsホームディレクトリ
Jenkinsは、ビルドを実行してアーカイブを保持するために、ある程度のディスク容量を必要とします。Jenkinsの設定画面からこの場所を確認できます。デフォルトでは、これは〜/ .jenkinsに設定されており、この場所は最初はユーザープロファイルの場所に保存されます。適切な環境では、この場所を適切な場所に変更して、関連するすべてのビルドとアーカイブを保存する必要があります。一度これを次の方法で行うことができます
サーブレットコンテナを起動する前に、「JENKINS_HOME」環境変数を新しいホームディレクトリに設定します。
「JENKINS_HOME」システムプロパティをサーブレットコンテナに設定します。
JNDI環境エントリ「JENKINS_HOME」を新しいディレクトリに設定します。
次の例では、「JENKINS_HOME」環境変数を設定する最初のオプションを使用します。
まず、新しいフォルダーE:\ Apps \ Jenkinsを作成します。既存の〜/ .jenkinsからこの新しいディレクトリにすべてのコンテンツをコピーします。
JENKINS_HOME環境変数を設定して、Javaがマシンにインストールされているベースディレクトリの場所を指すようにします。例えば、
OS | 出力 |
---|---|
ウィンドウズ | 環境変数JENKINS_HOMEを、希望する場所に設定します。例として、E:\ Apps \ Jenkinsに設定できます |
Linux | JENKINS_HOME = / usr / local / Jenkinsまたは目的の場所をエクスポートします。 |
Jenkinsダッシュボードで、左側のメニューから[Jenkinsの管理]をクリックします。次に、右側から[システムの構成]をクリックします。
ホームディレクトリに、設定された新しいディレクトリが表示されます。
エグゼキュータの数
これは、Jenkinsマシンで実行できる同時ジョブ実行の総数を指します。これは、要件に基づいて変更できます。パフォーマンスを向上させるために、この数をマシンのCPUの数と同じに保つことをお勧めする場合があります。
環境変数
これは、すべてのジョブに適用されるカスタム環境変数を追加するために使用されます。これらはキーと値のペアであり、必要に応じてビルドでアクセスして使用できます。
JenkinsのURL
デフォルトでは、JenkinsURLはlocalhostを指します。マシンにドメイン名を設定している場合は、これをドメイン名に設定します。そうでない場合は、ローカルホストをマシンのIPで上書きします。これは、$ {JENKINS_URL}としてアクセスできる環境変数JENKINS_URLを使用してJenkinsURLに直接アクセスできるため、スレーブを設定し、電子メールを使用してリンクを送信する際に役立ちます。
電子メール通知
電子メール通知領域では、電子メールを送信するためのSMTP設定を構成できます。これは、JenkinsがSMTPメールサーバーに接続し、受信者リストに電子メールを送信するために必要です。
Jenkinsを管理するには、左側のメニュー側から[ManageJenkins]オプションをクリックします。
したがって、左側のメニュー側から[Manage Jenkins]オプションをクリックすると、Jenkinsのさまざまな構成オプションを取得できます。
次に、次の画面が表示されます-
管理オプションのいくつかは次のとおりです-
システムの構成
ここで、JDK、AntとMavenのバージョン、セキュリティオプション、電子メールサーバー、その他のシステム全体の構成の詳細など、ビルドで使用するさまざまなツールへのパスを管理できます。プラグインがインストールされている場合。Jenkinsは、プラグインのインストール後に必要な構成フィールドを動的に追加します。
ディスクから構成をリロードします
Jenkinsは、すべてのシステムとビルドジョブの構成の詳細をXMLファイルとして保存します。このファイルはJenkinsのホームディレクトリに保存されます。ここにもすべてのビルド履歴が保存されます。ビルドジョブをあるJenkinsインスタンスから別のインスタンスに移行する場合、または古いビルドジョブをアーカイブする場合は、対応するビルドジョブディレクトリをJenkinsのビルドディレクトリに追加または削除する必要があります。これを行うためにJenkinsをオフラインにする必要はありません。「ディスクから構成を再ロード」オプションを使用するだけで、Jenkinsシステムをリロードし、ジョブ構成を直接構築できます。
プラグインの管理
ここでは、Git、Mercurial、ClearCaseなどのさまざまなソースコード管理ツールから、コード品質やコードカバレッジメトリックレポートまで、さまざまなサードパーティプラグインをインストールできます。プラグインは、[プラグインの管理]画面からインストール、更新、および削除できます。
システムインフォメーション
この画面には、現在のすべてのJavaシステムプロパティとシステム環境変数のリストが表示されます。ここでは、Java Jenkinsのどのバージョンで実行されているか、どのユーザーで実行されているかなどを正確に確認できます。
次のスクリーンショットは、このセクションで利用できる名前と値の情報の一部を示しています。
システムログ
システムログ画面は、Jenkinsログファイルをリアルタイムで表示するための便利な方法です。繰り返しますが、この画面の主な用途はトラブルシューティングです。
負荷統計
このページには、同時ビルドの数とビルドキューの長さの観点から、Jenkinsインスタンスのビジー状態に関するグラフィカルデータが表示されます。これにより、ビルドが実行されるまでの待機時間がわかります。これらの統計は、インフラストラクチャの観点から、追加の容量または追加のビルドノードが必要かどうかを判断するのに役立ちます。
スクリプトコンソール
この画面では、サーバー上でGroovyスクリプトを実行できます。内部のJenkinsアーキテクチャに関する深い知識が必要なため、高度なトラブルシューティングに役立ちます。
ノードを管理する
Jenkinsは、並列ビルドと分散ビルドを処理できます。この画面では、必要なビルド数を構成できます。Jenkinsは同時に実行され、分散ビルドを使用している場合は、ビルドノードをセットアップします。ビルドノードは、Jenkinsがビルドを実行するために使用できる別のマシンです。
シャットダウンの準備
Jenkinsをシャットダウンする必要がある場合、またはJenkinsが実行されているサーバーをシャットダウンする必要がある場合は、ビルドの実行時にシャットダウンしないことをお勧めします。Jenkinsをクリーンにシャットダウンするには、[シャットダウンの準備]リンクを使用して、新しいビルドが開始されないようにします。最終的に、現在のビルドがすべて終了すると、Jenkinsを正常にシャットダウンできるようになります。
この演習では、Jenkinsで、単純なHelloWorldアプリケーションを取得し、Javaプログラムをビルドして実行するジョブを作成します。
Step 1 − Jenkinsダッシュボードに移動し、[新しいアイテム]をクリックします
Step 2−次の画面で、アイテム名を入力します。この場合は、Helloworldという名前を付けています。「フリースタイルプロジェクトオプション」を選択します
Step 3 −ジョブの詳細を指定できる次の画面が表示されます。
Step 4−ビルドする必要のあるファイルの場所を指定する必要があります。この例では、「HelloWorld.java」ファイルを含むローカルgitリポジトリ(E:\ Program)がセットアップされていると想定します。したがって、下にスクロールしてGitオプションをクリックし、ローカルのgitリポジトリのURLを入力します。
Note− Githubでホストされている場合にリポジトリを作成する場合は、そのリポジトリのURLをここに入力することもできます。これに加えて、資格情報の[追加]ボタンをクリックして、ユーザー名とパスワードをgithubリポジトリに追加し、リモートリポジトリからコードを取得できるようにする必要があります。
Step 5 −次に、[ビルド]セクションに移動し、[ビルドステップの追加]→[Windowsバッチコマンドの実行]をクリックします。
Step 6 −コマンドウィンドウで、次のコマンドを入力し、[保存]ボタンをクリックします。
Javac HelloWorld.java
Java HelloWorld
Step 7 −保存したら、[今すぐビルド]オプションをクリックして、ジョブが正常に定義されているかどうかを確認できます。
Step 8−ビルドがスケジュールされると、実行されます。次のビルド履歴セクションは、ビルドが進行中であることを示しています。
Step 9−ビルドが完了すると、ビルドのステータスにビルドが成功したかどうかが表示されます。この場合、次のビルドは正常に実行されました。ビルド履歴の#1をクリックして、ビルドの詳細を表示します。
Step 10 −ビルドの詳細を表示するには、[コンソール出力]リンクをクリックします
上記の手順とは別に、ビルドジョブを作成する方法はたくさんありますが、利用できるオプションもたくさんあります。そのため、Jenkinsは素晴らしい継続的デプロイツールになっています。
Jenkinsは、Junitにすぐに使用できる機能を提供し、他のテクノロジの単体テスト用のプラグインのホストを提供します。たとえば、MSTest for.Net単体テストがあります。リンクに行くとhttps://wiki.jenkins-ci.org/display/JENKINS/xUnit+Plugin 利用可能なユニットテストプラグインのリストが表示されます。
JenkinsでのJUnitテストの例
次の例では、
- Junitに基づく単純なHelloWorldTestクラス。
- それに応じてクラスをビルドするためのJenkins内のビルドツールとしてのAnt。
Step 1 − Jenkinsダッシュボードに移動し、既存のHelloWorldプロジェクトをクリックして、[構成]オプションを選択します
Step 2 −セクションを参照してビルドステップを追加し、Antを呼び出すオプションを選択します。
Step 3 − [詳細]ボタンをクリックします。
Step 4 −ビルドファイルセクションに、build.xmlファイルの場所を入力します。
Step 5 −次に、ビルド後のオプションを追加するオプションをクリックし、「JUnitテスト結果レポートを公開する」オプションを選択します。
Step 6−テストレポートのXMLで、以下に示すように場所を入力します。ReportsがHelloWorldプロジェクトワークスペースで作成されたフォルダーであることを確認します。「* .xml」は基本的に、JUnitテストケースの実行によって生成された結果のxmlファイルを取得するようにJenkinsに指示します。これらのxmlファイルは、後で表示できるレポートに変換されます。
完了したら、最後にある[保存]オプションをクリックします。
Step 7 −保存したら、[今すぐビルド]オプションをクリックできます。
ビルドが完了すると、ビルドのステータスにビルドが成功したかどうかが表示されます。ビルド出力情報に、テスト結果と呼ばれる追加のセクションがあります。私たちの場合、例として結果が失敗するように、否定的なテストケースを入力しました。
コンソール出力に移動して、詳細情報を確認できます。しかし、さらに興味深いのは、[テスト結果]をクリックすると、テスト結果のドリルダウンが表示されることです。
継続的インテグレーションの基本原則の1つは、ビルドを検証可能にする必要があるということです。特定のビルドがビルドプロセスの次の段階に進む準備ができているかどうかを客観的に判断できる必要があります。これを行う最も便利な方法は、自動テストを使用することです。適切な自動テストがないと、多くのビルドアーティファクトを保持して手動でテストする必要がありますが、これは継続的インテグレーションの精神ではほとんどありません。次の例は、Seleniumを使用して自動Webテストを実行する方法を示しています。
Step 1 −プラグインの管理に移動します。
Step 2− Hudson Seleniumプラグインを見つけて、インストールすることを選択します。Jenkinsインスタンスを再起動します。
Step 3 − [システムの構成]に移動します。
Step 4 −セレンサーバーjarを構成し、[保存]ボタンをクリックします。
Note−セレンjarファイルはSeleniumHQの場所からダウンロードできます。
Seleniumスタンドアロンサーバーのダウンロードをクリックします。
Step 5 −ダッシュボードに戻り、HelloWorldプロジェクトの[構成]オプションをクリックします。
Step 6 − [ビルドステップの追加]をクリックして、「SeleniumHQhtmlSuiteRun」のオプチンを選択します
Step 7−セレンテストに必要な詳細を追加します。ここで、suiteFileは、SeleniumIDEを使用して生成されたTestSuiteです。[保存]をクリックしてビルドを実行します。これで、ポストビルドはSeleniumドライバーを起動し、htmlテストを実行します。
Jenkinsには、ビルドプロジェクトの電子メール通知を追加するためのすぐに使用できる機能が付属しています。
Step 1−SMTPサーバーの構成。Jenkinsの管理→システムの構成に移動します。[電子メール通知]セクションに移動し、必要なSMTPサーバーとユーザーの電子メールサフィックスの詳細を入力します。
Step 2− Jenkinsプロジェクトで受信者を構成する-Jenkinsビルドプロジェクトを構成する場合、最後に、不安定なビルドまたは壊れたビルドの電子メール通知を受け取る受信者を追加する機能があります。次に、[保存]ボタンをクリックします。
デフォルトとは別に、市場には通知プラグインもあります。例として、JSONおよびXML形式でジョブステータス通知を送信できるTikalKnowledgeの通知プラグインがあります。このプラグインを使用すると、エンドポイントを次のように構成できます。
各オプションの詳細は次のとおりです-
"Format" −これは、JSONまたはXMLのいずれかである通知ペイロード形式です。
"Protocol" −通知メッセージ、HTTP、TCP、またはUDPの送信に使用するプロトコル。
"Event" −通知をトリガーするジョブイベント:ジョブ開始、ジョブ完了、ジョブ終了、またはすべてのイベント(デフォルトオプション)。
"URL"−通知を送信するURL。それは「http://host"HTTPプロトコルの場合、および
"host:port"
TCPおよびUDPプロトコルの場合。"Timeout" −通知要求を送信するためのミリ秒単位のタイムアウト。デフォルトでは30秒。
前のセクションで示したように、利用可能なレポートプラグインは多数ありますが、最も単純なものはjUnitテストで利用可能なレポートです。
任意のジョブのビルド後アクションで、作成するレポートを定義できます。ビルドが完了すると、[テスト結果]オプションを使用してさらにドリルダウンできます。
Jenkinsには多数のコード分析プラグインがあります。さまざまなプラグインはで見つけることができますhttps://wiki.jenkins-ci.org/display/JENKINS/Static+Code+Analysis+Plugins
このプラグインは、静的コード分析プラグインのユーティリティを提供します。Jenkinsは、CheckStyle、FindBugs、PMDなどのさまざまなコード分析ツールから結果ファイルを解析できます。対応するコード分析ツールごとに、Jenkinsのプラグインをインストールする必要があります。
さらに、これらのプラグインの個々の結果を単一のトレンドグラフとビューに結合するアドオンプラグインStatic AnalysisCollectorが利用可能です。
プラグインは次のような情報を提供できます
- ジョブ内の警告の総数
- ビルドの新しい警告と修正された警告の表示
- ビルドごとの警告の数を示すトレンドレポート
- モジュール、パッケージ、カテゴリ、またはタイプごとに検出された警告の概要
- 見つかった警告の詳細レポートは、オプションで重大度(または新規および修正済み)でフィルタリングされます
定期的にビルドされる、より大きくて重いプロジェクトがある場合は、多くのビルドマシンが必要になることがあります。また、これらすべてのビルドを中央マシンで実行することは、最善のオプションではない場合があります。このようなシナリオでは、他のJenkinsマシンをスレーブマシンとして構成して、マスターJenkinsサーバーから負荷を取り除くことができます。
ビルドをテストするために、いくつかの異なる環境が必要になる場合もあります。この場合、必要な各環境を表すためにスレーブを使用することはほぼ必須です。
スレーブは、ビルドプロジェクトをマスターからオフロードするようにセットアップされたコンピューターであり、セットアップが完了すると、このタスクの分散はかなり自動的に行われます。正確な委任動作は、各プロジェクトの構成によって異なります。プロジェクトによっては、ビルドのために特定のマシンに「固執」することを選択する場合もあれば、スレーブ間を自由にローミングすることを選択する場合もあります。
各スレーブは「スレーブエージェント」と呼ばれる個別のプログラムを実行するため、完全なJenkins(パッケージまたはコンパイル済みバイナリ)をスレーブにインストールする必要はありません。スレーブエージェントを起動するにはさまざまな方法がありますが、最終的には、スレーブエージェントとJenkinsマスターは、動作するために双方向通信リンク(TCP / IPソケットなど)を確立する必要があります。
Jenkinsでスレーブ/ノードを設定するには、以下の手順に従います。
Step 1 − [Jenkinsの管理]セクションに移動し、[ノードの管理]セクションまで下にスクロールします。
Step 2 − [新しいノード]をクリックします
Step 3 −ノードに名前を付け、[ダムスレーブ]オプションを選択して、[OK]をクリックします。
Step 4−ノードスレーブマシンの詳細を入力します。以下の例では、スレーブマシンをWindowsマシンと見なしているため、起動方法として「JenkinsにこのWindowsスレーブをWindowsサービスとして制御させる」オプションを選択しました。また、ノード名やノードマシンのログイン資格情報など、スレーブノードの必要な詳細を追加する必要があります。[保存]ボタンをクリックします。名前が「New_Slave」として入力されているラベルは、このスレーブマシンを使用するようにジョブを構成するために使用できるものです。
上記の手順が完了すると、新しいノードマシンは最初はオフライン状態になりますが、前の画面のすべての設定が正しく入力されるとオンラインになります。必要に応じて、いつでもノードスレーブマシンをオフラインにすることができます。
ビルドが成功した後、それぞれのアプリケーション/ Webサーバーにビルドファイルを転送するために使用できるプラグインが多数あります。例としては、「コンテナプラグインへのデプロイ」があります。これを使用するには、以下の手順に従ってください。
Step 1− [Jenkinsの管理]→[プラグインの管理]に移動します。[利用可能]セクションに移動し、プラグイン「コンテナプラグインにデプロイ」を見つけてプラグインをインストールします。Jenkinsサーバーを再起動します。
このプラグインはwar / earファイルを受け取り、ビルドの最後に実行中のリモートアプリケーションサーバーにデプロイします。
Tomcat 4.x / 5.x / 6.x / 7.x
JBoss 3.x / 4.x
Glassfish 2.x / 3.x
Step 2−ビルドプロジェクトに移動し、[構成]オプションをクリックします。「war / earをコンテナにデプロイする」オプションを選択します
Step 3− [war / earをコンテナにデプロイする]セクションで、ファイルをデプロイする必要があるサーバーの必要な詳細を入力し、[保存]ボタンをクリックします。これらの手順により、ビルドが成功した後、必要なファイルが必要なコンテナーに確実にデプロイされるようになります。
Jenkinsで利用できるさまざまなプラグインがあり、一定期間にわたって実行されるビルドのメトリックを紹介します。これらのメトリックは、ビルドと、時間の経過とともに失敗/通過する頻度を理解するのに役立ちます。例として、「Build HistoryMetricsプラグイン」を見てみましょう。
このプラグインは、インストールされたすべてのビルドについて次のメトリックを計算します
- 平均故障間隔(MTTF)
- 平均修復時間(MTTR)
- ビルド時間の標準偏差
Step 1 − Jenkinsダッシュボードに移動し、[Jenkinsの管理]をクリックします
Step 2 − [プラグインの管理]オプションに移動します。
Step 3 − [利用可能]タブに移動し、プラグイン「ビルド履歴メトリックプラグイン」を検索して、「再起動せずにインストール」を選択します。
Step 4−プラグインが正常にインストールされたことを確認するために、次の画面が表示されます。Jenkinsインスタンスを再起動します。
[求人]ページに移動すると、計算された指標の表が表示されます。メトリックは、過去7日間、過去30日間、およびすべての時間で表示されます。
Jenkinsの全体的な傾向を確認するために、ビルドとJenkins内から情報を収集し、それらをグラフィック形式で表示するために使用できるプラグインがあります。このようなプラグインの一例は、「Hudsonglobal-build-statsプラグイン」です。それでは、このための手順を見ていきましょう。
Step 1 − Jenkinsダッシュボードに移動し、[Jenkinsの管理]をクリックします
Step 2 − [プラグインの管理]オプションに移動します
Step 3 − [利用可能]タブに移動し、プラグイン「Hudson global-build-statsプラグイン」を検索し、「再起動せずにインストール」を選択します。
Step 4−プラグインが正常にインストールされたことを確認するために、次の画面が表示されます。Jenkinsインスタンスを再起動します。
グローバル統計を表示するには、ステップ5から8に従ってください。
Step 5− Jenkinsダッシュボードに移動し、[Jenkinsの管理]をクリックします。[Jenkinsの管理]画面で下にスクロールすると、[グローバルビルド統計]というオプションが表示されます。このリンクをクリックしてください。
Step 6−「統計の初期化」ボタンをクリックします。これは、すでに実行されたビルドの既存のすべてのレコードを収集し、これらの結果に基づいてチャートを作成できることを意味します。
Step 7−データが初期化されたら、新しいグラフを作成します。[新しいグラフの作成]リンクをクリックします。
Step 8−新しいチャートの詳細に関連する情報を入力するためのポップアップが表示されます。次の必須情報を入力してください
- タイトル–この例では、タイトル情報は「デモ」として示されます。
- チャート幅– 800
- チャートの高さ– 600
- チャートの時間スケール–毎日
- チャートの期間– 30日
残りの情報はそのままにしておくことができます。情報を入力したら、[新しいグラフの作成]をクリックします。
これで、時間の経過に伴うビルドの傾向を示すグラフが表示されます。
チャート内のいずれかのセクションをクリックすると、ジョブとそのビルドの詳細のドリルダウンが表示されます。
以下は、実行する基本的なアクティビティの一部です。そのうちのいくつかは、Jenkinsサーバーのメンテナンスのベストプラクティスです。
URLオプション
次のコマンドをJenkinsインスタンスのURLに追加すると、Jenkinsインスタンスで関連するアクションが実行されます。
http://localhost:8080/jenkins/exit −ジェンキンスをシャットダウンします
http://localhost:8080/jenkins/restart −jenkinsを再起動します
http://localhost:8080/jenkins/reload −構成をリロードします
バックアップジェンキンスホーム
Jenkinsホームディレクトリは、Jenkinsがジョブやビルドなどのすべての情報を保存するドライブ上の場所に他なりません。ホームディレクトリの場所は、[Jenkinsの管理]→[システムの構成]をクリックすると表示されます。
最も空きディスク容量のあるパーティションにJenkinsをセットアップする– Jenkinsは定義されたさまざまなジョブのソースコードを取得して継続的ビルドを実行するため、十分なハードディスク容量のあるドライブにJenkinsがセットアップされていることを常に確認してください。ハードディスクの容量が不足すると、Jenkinsインスタンスのすべてのビルドが失敗し始めます。
もう1つのベストプラクティスは、Jenkinsがセットアップされているディスクがいっぱいになるのを防ぐために、クリーンアップ操作を実行できるcronジョブまたはメンテナンスタスクを作成することです。
Jenkinsは、継続的デプロイとデリバリーを提供するための優れたサポートを提供します。ソフトウェア開発から展開までの流れを見ると、以下のようになります。
継続的デプロイの主な部分は、上記のプロセス全体が自動化されていることを確認することです。Jenkinsは、さまざまなプラグインを介してこれらすべてを実現します。そのうちの1つは、前のレッスンで見た「コンテナプラグインへのデプロイ」です。
継続的デプロイプロセスを実際にグラフィカルに表現できるプラグインが利用可能です。ただし、最初にJenkinsで別のプロジェクトを作成して、これがどのように機能するかを最もよく理解できるようにします。
QAステージをエミュレートし、Helloworldアプリケーションのテストを実行する簡単なプロジェクトを作成しましょう。
Step 1− Jenkinsダッシュボードに移動し、[新しいアイテム]をクリックします。「フリースタイルプロジェクト」を選択し、プロジェクト名を「QA」として入力します。[OK]ボタンをクリックして、プロジェクトを作成します。
Step 2 −この例では、シンプルに保ち、このプロジェクトを使用してHelloworldアプリケーションのテストプログラムを実行しています。
これで、プロジェクトのQAが設定されました。ビルドを実行して、正しくビルドされるかどうかを確認できます。
Step 3 −次に、Helloworldプロジェクトに移動し、[構成]オプションをクリックします。
Step 4 −プロジェクト構成で、「ビルド後のアクションの追加」を選択し、「他のプロジェクトのビルド」を選択します
Step 5− [ビルドするプロジェクト]セクションで、ビルドするプロジェクト名としてQAを入力します。このオプションは、「ビルドが安定している場合にのみトリガーする」のデフォルトのままにしておくことができます。[保存]ボタンをクリックします。
Step 6−Helloworldプロジェクトをビルドします。これで、コンソール出力が表示された場合、Helloworldプロジェクトが正常にビルドされた後、QAプロジェクトのビルドも行われることがわかります。
Step 7−配信パイプラインプラグインをインストールしましょう。Jenkinsの管理→プラグインの管理に移動します。使用可能なタブで、「配信パイプラインプラグイン」を検索します。[再起動せずにインストール]をクリックします。完了したら、Jenkinsインスタンスを再起動します。
Step 8 −配信パイプラインの動作を確認するには、Jenkinsダッシュボードで、[すべて]タブの横にあるタブの+記号をクリックします。
Step 9 −ビュー名に任意の名前を入力し、[配信パイプラインビュー]オプションを選択します。
Step 10−次の画面で、デフォルトのオプションをそのままにしておくことができます。以下の設定を変更できます-
- [静的解析結果を表示する]オプションがオンになっていることを確認します。
- [合計ビルド時間を表示する]オプションがオンになっていることを確認します。
- 初期ジョブの場合–ビルドする最初のジョブとしてHelloworldプロジェクトを入力します。
- パイプラインの名前を入力します
- [OK]ボタンをクリックします。
これで、配信パイプライン全体のすばらしいビューが表示され、パイプライン全体の各プロジェクトのステータスを確認できるようになります。
もう1つの有名なプラグインは build pipeline plugin。これを見てみましょう。
Step 1− [Jenkinsの管理]→[プラグインの管理]に移動します。使用可能なタブで、「BuildPipelinePlugin」を検索します。[再起動せずにインストール]をクリックします。完了したら、Jenkinsインスタンスを再起動します。
Step 2 −ビルドパイプラインの動作を確認するには、Jenkinsダッシュボードで、[すべて]タブの横にあるタブの+記号をクリックします。
Step 3 −ビュー名に任意の名前を入力し、[パイプラインビューの構築]オプションを選択します。
Step 4− [選択された初期ジョブ]でデフォルト設定を受け入れ、Helloworldプロジェクトの名前を入力してください。[OK]ボタンをクリックします。
これで、配信パイプライン全体のすばらしいビューが表示され、パイプライン全体の各プロジェクトのステータスを確認できるようになります。
Jenkins内で利用可能なすべてのプラグインのリストを取得するには、リンクにアクセスしてください- https://wiki.jenkins-ci.org/display/JENKINS/Plugins
プラグインをインストールするための多くのインスタンスをすでに見てきました。プラグインに関する他のいくつかのメンテナンスタスクを見てみましょう。
プラグインのアンインストール
プラグインをアンインストールするには、[Jenkinsの管理]→[プラグインの管理]に移動します。[インストール済み]タブをクリックします。一部のプラグインにはアンインストールオプションがあります。これらのボタンをクリックして、プラグインをアンインストールできます。アンインストール後、必ずJenkinsインスタンスを再起動してください。
プラグインの別のバージョンをインストールする
古いバージョンのプラグインをインストールする必要がある場合があります。そのような場合は、JenkinsWebサイトの関連するプラグインページからプラグインをダウンロードできます。その後、を使用することができますUpload プラグインを手動でアップロードするオプション。
Jenkinsでは、Jenkinsインスタンスでユーザーとそれに関連する権限を設定できます。デフォルトでは、Jenkinsですべての人がジョブやその他の管理タスクを定義できるようにする必要はありません。したがって、Jenkinsにはセキュリティ構成を設定する機能があります。
Jenkinsでセキュリティを構成するには、以下の手順に従います。
Step 1 − [Jenkinsの管理]をクリックして、[グローバルセキュリティの構成]オプションを選択します。
Step 2− [セキュリティを有効にする]オプションをクリックします。例として、Jenkinsに独自のユーザーデータベースを維持させたいと仮定します。そのため、セキュリティレルムで、「Jenkins独自のユーザーデータベース」のオプションを選択します。
デフォルトでは、中央管理者がシステム内のユーザーを定義する必要があるため、[ユーザーにサインアップを許可する]オプションが選択されていないことを確認してください。残りは今のところそのままにして、[保存]ボタンをクリックします。
Step 3−最初のユーザーを追加するように求められます。例として、システムの管理者ユーザーを設定しています。
Step 4−システムでユーザーをセットアップする時が来ました。これで、[Jenkinsの管理]に移動して下にスクロールすると、[ユーザーの管理]オプションが表示されます。このオプションをクリックします。
Step 5−管理者ユーザーを定義したのと同じように、システムの他のユーザーの作成を開始します。例として、「user」という別のユーザーを作成しています。
Step 6−次に、認証を設定します。基本的に、誰が何にアクセスできるかです。Jenkinsの管理→グローバルセキュリティの設定に移動します。
次に、[認証]セクションで、[マトリックスベースのセキュリティ]をクリックします。
Step 7−ユーザーグループリストにユーザーが表示されない場合は、ユーザー名を入力してリストに追加してください。次に、ユーザーに適切な権限を付与します。
関連する認証を定義したら、[保存]ボタンをクリックします。
これで、Jenkinsセキュリティが設定されました。
Note − Windows AD認証の場合、ActiveDirectoryプラグインをJenkinsに追加する必要があります。
Jenkinsには、Jenkinsに関連する重要な構成設定をバックアップするために使用できるバックアッププラグインがあります。以下の手順に従って、バックアップを作成します。
Step 1 − [Jenkinsの管理]をクリックして、[プラグインの管理]オプションを選択します。
Step 2−使用可能なタブで、「バックアッププラグイン」を検索します。[再起動せずにインストール]をクリックします。完了したら、Jenkinsインスタンスを再起動します
Step 3− [Jenkinsの管理]に移動して下にスクロールすると、オプションとして[バックアップマネージャー]が表示されます。このオプションをクリックします。
Step 4 − [設定]をクリックします。
Step 5−ここで、定義する主なフィールドはバックアップのディレクトリです。Jenkinsインスタンスがセットアップされているドライブとは異なる別のドライブにあることを確認してください。[保存]ボタンをクリックします。
Step 6 −バックアップマネージャ画面から[バックアップハドソン構成]をクリックして、バックアップを開始します。
次の画面には、バックアップのステータスが表示されます
バックアップから回復するには、[バックアップマネージャー]画面に移動し、[ハドソン構成の復元]をクリックします。
バックアップのリストが表示されます。適切なものをクリックして[復元の起動]をクリックし、バックアップの復元を開始します。
セレンテストなどのWebテストは、マスタースレーブとセレンスイートプラグインのインストールを介してリモートスレーブマシンで実行できます。次の手順は、この構成を使用してリモートテストを実行する方法を示しています。
Step 1−マスタースレーブ構成が適切に設定されていることを確認します。マスターJenkinsサーバーに移動します。Jenkinsの管理→ノードの管理に移動します。
ノードリストでは、DXBMEM30ラベルはスレーブマシンです。この例では、マスターマシンとスレーブマシンの両方がWindowsマシンです。
Step 2 −DXBMEM30スレーブマシンの構成をクリックします。
Step 3 −起動メソッドが「JavaWebStartを介したスレーブエージェントの起動」として設定されていることを確認します
Step 4−次に、スレーブマシンに移動し、そこからブラウザインスタンスを開いてJenkinsマスターインスタンスを開きます。次に、[Jenkinsの管理]→[ノードの管理]に移動します。DXBMEM30に移動し、をクリックします
Step 5 −DXBMEM30インスタンスをクリックします。
Step 6 −下にスクロールすると、「JavaWebStart」を開始するためのオプションである「起動」オプションが表示されます。
Step 7−セキュリティ警告が表示されます。[承認]チェックボックスをクリックして、[実行]をクリックします。
これで、Jenkinsスレーブウィンドウが開き、接続されたことがわかります。
Step 8−スレーブで実行するようにテストを構成します。ここでは、作成されるジョブが特にセレンテストのみを実行することを意図していることを確認する必要があります。
ジョブ構成で、[このプロジェクトを実行できる場所を制限する]オプションが選択されていることを確認し、ラベル式にスレーブノードの名前を入力します。
Step 9−ジョブのセレン部分が構成されていることを確認します。Sample.htmlファイルとselenium-server.jarファイルもスレーブマシンに存在することを確認する必要があります。
上記のすべての手順を実行し、[ビルド]をクリックすると、このプロジェクトは期待どおりにスレーブマシンでSeleniumテストを実行します。