我使用Ansible将/etc/bash.bashrc
和$HOME/.bashrc
附加到变量。
Ansible完成后,这两个文件如下所示。
在/etc/bash.bashrc
:
...
export VAR1="some text comes here"
...
在$HOME/.bashrc
:
...
export VAR2="other text comes here"
...
所以,Ansible完美地完成了它的工作。
Vagrantfile中的shell脚本,在Ansible完成后运行:
$init = <<-SCRIPT
whoami
echo $HOME
cat /etc/bash.bashrc
cat $HOME/.bashrc
source /etc/bash.bashrc
source $HOME/.bashrc
echo "VAR1 :: $VAR1"
echo "VAR2 :: $VAR2"
SCRIPT
config.vm.provision :init, type: :shell, inline: $init, privileged: false
即使在两个文件中设置了两个变量,然后两个文件都来源,输出也是:
vagrant
/home/vagrant
---> /etc/bash.bashrc contains the export
---> $HOME/.bashrc contains the export as well
VAR1 ::
VAR2 ::
正如我们所见,未设置两个变量并提供空字符串。
我用$HOME/.profile
尝试过,但效果相同。
你知道如何继续吗?
答案 0 :(得分:1)
/etc/bash.bashrc
和source $HOME/.bashrc
包含变量赋值是不够的。变量赋值实际上必须有机会被执行。
如果查看两个脚本的源代码(Debian下面的示例),它们包含在非交互式shell中调用时会中断执行的行:
/etc/bash.bashrc
# If not running interactively, don't do anything
[ -z "$PS1" ] && return
$HOME/.bashrc
# If not running interactively, don't do anything
case $- in
*i*) ;;
*) return;;
esac
因此,即使您明确地获取这些文件,如果在这些条件之后插入行export VAR1="some text comes here"
或export VAR2="other text comes here"
,它们将永远不会被执行,因为配置脚本作为非交互式shell运行。
您实际上并没有显示如何插入变量赋值行,但是您说&#34; 追加&#34;他们。如果您使用Ansible的lineinfile
模块,则可以添加insertbefore
参数以确保在脚本退出之前放置这些行。