chef cookbookができるまで
YUKI "Piro" Hiroshi edited this page Apr 21, 2014
·
8 revisions
まず必要なパッケージをインストールする。 Ubuntu 12.04LTSの場合は、libgecode-devをあらかじめインストールしておかないとberksのインストールに失敗するようだった。
% sudo apt-get install libgecode-dev
cookbooksを置くディレクトリを作成し、そこで作業する。
% md -p chef
% cd chef
knife soloとberksをインストールする準備を整え、インストールする。
% vi Gemfile
% cat Gemfile
# -*- ruby -*-
source "https://rubygems.org/"
gem "knife-solo"
gem "berkshelf"
% git add Gemfile
% git commit -m "Add Gemfile"
% bundle install --path vendor/bundle
knife soloでその作業ディレクトリを初期化する。
この操作により、いくつかのファイルとディレクトリが自動的に用意される。
% bundle exec knife solo init .
% git add .chef
% git commit -m "Add knife solo configuration file"
依存することになるcookbooksをインストールする準備を整える。
% vi Berksfile
% cat Berksfile
# -*- ruby -*-
source "http://api.berkshelf.com/"
local_cookbooks_dir = "cookbooks"
cookbook "groonga", :git => "https://github.com/groonga/chef-cookbooks.git", :rel => "groonga"
cookbook "droonga", :git => "https://github.com/droonga/chef-cookbooks.git", :rel => "droonga"
% git commit Berksfile -m "Add groonga and droonga to the list of dependencies"
% bundle exec berks install
2度目以降の実行では、berks updateする。
% bundle exec berks update
プロジェクト固有の情報を置いておくcookbookを作成する。
% knife cookbook create wikipedia-search -o site-cookbooks
管理対象のノードを初期化する。
この操作により、管理対象のノード用の設定ファイルも自動的に用意される。
(ユーザ名、ホスト名は実際のケースに合わせる。ここではあらかじめ準備しておいたVagrantの検証用環境を指定している。)
% bundle exec knife solo prepare vagrant@node0
ノードに対して、droonga-engineをセットアップするように設定する。
% vi nodes/node0.json
% cat nodes/node0.json
{
"run_list": [
"droonga::engine"
]
}
この時、ホスト名が名前解決できない環境(検証用環境や、ノードの入れ替わりが激しい環境など)では、セットアップが完了した後でそのノード自身が自分に対してメッセージを配送できない。
なので、そのノード自身のループバックIPアドレスを、ホスト名の代わりとして使うように設定する。
% vi nodes/node0.json
% cat nodes/node0.json
{
"droonga": {
"engine": {
"host": "127.0.0.1"
}
},
"run_list": [
"droonga::engine"
]
}
準備が整ったので、ノードをセットアップする。
% bundle exec knife solo cook node0
droonga-engineが起動しているかどうかを確認する。
% ssh node0
% git clone https://github.com/droonga/droonga-client-ruby.git
% cd droonga-client-ruby
% bundle install --path vendor/
% vi add.json
% cat add.json
{
"type": "add",
"dataset": "Droonga",
"body": {
"table": "User",
"key": "key",
"values": {
}
}
}
% bundle exec bin/droonga-request --host node0 --port 10031 --tag droonga add.json
レスポンスが返ってきていれば、Droonga Engineが機能している。