JenkinsとSSH

2011/05/07

jenkins ssh tomcat 開発

t f B! P L
記事内に広告が含まれています。

定期的なビルドを行うツールの1つに、Jenkins CIがある。ソースのあるリポジトリをチェックし、必要に応じてApache AntなりMaven なり実行してくれるのだが、「リポジトリにはSSHでトンネル掘ってアクセス」なんて環境だと、困ってしまう。パスワードの設定されていないキーを使えとは言うものの、実際にはなかなか難しかったりする。

一方、SSHを便利に使うツールの1つに、ssh-agentがある。ssh-addで登録されたパスフレーズを、ユーザの代わりにsshに入力してくれるのだ。
これを使えば、Jenkinsがssh経由でリポジトリにアクセスするとき、パスフレーズを自動的に入力させることが可能だ。 sshは環境変数SSH_AUTH_SOCKにセットされているソケットからパスフレーズを読みだす。また、ssh-agentが出力する内容は、環境変数SSH_AUTH_SOCKおよびSSH_AGENT_PIDをセットする形になっている。だから、

  • ssh-agentの出力内容をどこかに取って置き
  • Jenkinsからsshを起動する際、取っておいたssh-agentの出力を取りこんで、ssh-agentにパスフレーズの入力をしてもらう
という形にすれば、うまくいくはずだ。

まずはssh-agentの起動スクリプト。例えば、setup-jenkins-sshとする。出力内容は後で使うので、/tmp/jenkins-envに出しておく。

#!/bin/sh
PATH=$PATH:/usr/bin
export PATH
if [ "x" == "x`pgrep -u tomcat ssh-agent`" ]; then
  umask 077
  ssh-agent -s > /tmp/jenkins-env
  ssh-agent
fi
次。sshのwrapperを、以下の内容で作成する。ファイル名は、例えばjenkins-sshとする。
#!/bin/sh
. /tmp/jenkins-env
ssh $*
sshのキー関係は適切に準備する。とはいっても、~tomcat/ssh に、リポジトリにアクセスするときの秘密鍵を置いておけばよい。 これで、準備OK。最初に、sudo -u tomcat setup-jenkins-ssh として、ユーザtomcatでアクセスしたときのパスフレーズを登録しておく。
あとはjenkinsでjobを作成する。リポジトリにアクセスする部分では、CVS_RSHの設定ができるので、上記で作成したjenkins-ssh を指定すればよい。

人気の投稿

ブログ アーカイブ

自己紹介

ストックオプションを半分しか行使していなかったけど、パワハラをなぁなぁで済まそうとする会社から転職。アーリーリタイアを目指し、自分で稼ぐ術を模索中。

改正電気通信事業法に関する表記

・掲載内容

当サイトでは成果報酬型広告/クリック型広告の効果測定のため、利用者の方のアクセス情報を外部事業者に送信しております。
当該の情報は個人を特定する情報ではございません。また当該の情報が目的外利用される事は一切御座いません。

1.送信される情報の内容
  • 広告の表示日時
  • 広告のクリック日時
  • 広告の計測に必要なクッキー情報
  • 広告表示時及び広告クリック時のIPアドレス
  • 広告表示時及び広告クリック時に使用されたインターネット端末およびインターネットブラウザの種類
2.送信先となる事業者の氏名又は名称
  • グーグル合同会社
  • 楽天グループ株式会社
  • アマゾンジャパン合同会社
  • ヤフー株式会社
  • 株式会社ファンコミュニケーションズ
  • 株式会社もしも
3.利用目的

成果報酬型広告/クリック型広告の効果測定および不正防止のため

QooQ