我在其中一个食谱中有这个块,该块包含在其他食谱中。
bash 'setup' do
cwd "#{node[:'python-virtualenv'][:home]}"
user 'ubuntu'
environment "HOME" => "#{node[:'python-virtualenv'][:home]}"
code <<-EOH
sudo add-apt-repository -y ppa:fkrull/deadsnakes
sudo apt-get update
sudo apt-get -yq install python3.5
curl -s https://bootstrap.pypa.io/get-pip.py | sudo python3.5
sudo pip3.5 install virtualenv virtualenvwrapper
echo "export WORKON_HOME=#{node[:'python-virtualenv'][:home]}.virtualenvs/" > #{node[:'python-virtualenv'][:home]}.bash_profile
echo "export VIRTUALENVWRAPPER_PYTHON=$(which python3.5)" > #{node[:'python-virtualenv'][:home]}.bash_profile
echo "source /usr/local/bin/virtualenvwrapper.sh" >> #{node[:'python-virtualenv'][:home]}.bash_profile
EOH
end
日志说这个块被执行了,但是当我ssh进入实例时,它没有安装。
这是日志的相关部分
[2018-03-07T09:59:33+00:00] INFO: Processing bash[setup] action run (app::default line 12)
[2018-03-07T09:59:40+00:00] INFO: bash[setup] ran successfully
将set -e
添加到 shell 脚本的顶部,您可能会看到它在其中一个中间命令上失败。为什么你以非root用户的身份运行,然后尝试使用sudo
?总的来说,这似乎是一个非常奇怪的 shell 脚本。可能还想添加set -x
以帮助调试。