簡単なカスタム レシピの GitHub リポジトリを作成しました。
my-cookbook/
|- recipes/
|- appsetup.rb
カスタム シェフ レシピにレポを次のように追加しました。https://github.com/my-github-user/my-github-repo.git
my-cookbook::appsetup
セットアップの「サイクル」に追加しました。
構文をめちゃくちゃにするとロードに失敗するため、実行されていることがわかります。
これは私のappsetup.rbです:
node[:deploy].each do |app_name, deploy|
script "install_composer" do
interpreter "bash"
user "root"
cwd "#{deploy[:deploy_to]}/current"
code "curl -sS https://getcomposer.org/installer | php && php composer.phar install --no-dev"
end
end
ubuntu ユーザーで SSH 経由でインスタンスにログインすると、composer がインストールされません。
また、次のことを試してみましたが、役に立ちませんでした(nodejsのインストール):
node[:deploy].each do |app_name, deploy|
execute "installing node" do
command "add-apt-repository --yes ppa:chris-lea/node.js && apt-get update && sudo apt-get install python-software-properties python g++ make nodejs"
end
end
ノードはインストールされず、ログにエラーはありません。ログ内のクックブックへの唯一の参照は次のとおりです。
[2014-03-31T13:26:04+00:00] INFO: OpsWorks Custom Run List: ["opsworks_initial_setup", "ssh_host_keys", "ssh_users", "mysql::client", "dependencies", "ebs", "opsworks_ganglia::client", "opsworks_stack_state_sync", "mod_php5_apache2", "my-cookbook::appsetup", "deploy::default", "deploy::php", "test_suite", "opsworks_cleanup"]
...
2014-03-31T13:26:04+00:00] INFO: New Run List expands to ["opsworks_initial_setup", "ssh_host_keys", "ssh_users", "mysql::client", "dependencies", "ebs", "opsworks_ganglia::client", "opsworks_stack_state_sync", "mod_php5_apache2", "my-cookbook::appsetup", "deploy::default", "deploy::php", "test_suite", "opsworks_cleanup"]
...
[2014-03-31T13:26:05+00:00] DEBUG: Loading Recipe my-cookbook::appsetup via include_recipe
[2014-03-31T13:26:05+00:00] DEBUG: Found recipe appsetup in cookbook my-cookbook
どこかで重要なステップが欠落していますか? レシピは明確に認識されて読み込まれますが、実行されていないようです。
(以下は架空の名前です: my-github-user、my-github-repo、my-cookbook)