ansible 是基于模块工作,在执行source是是调用shell模块,但是通过按ansible调用shell会有不可执行的命令,如 :tail 、top等动态或者有交互工作的命令。
其中容易混淆一点 source 不是动态,也不是交互动作,但并不执行重置/etc/profile(全局变量)。我们换一个思路变量是怎么读取(在不做命令的前提下),比如:开机过程中,用户切换中;其中用户切换会读取用户自定义的环境变量(隐藏文件。bash_profile 、.bashrc)。我们再去思考ansible就像是登录了另外一台机器,根据指定的模块动作来完成相对应的任务,所以可以引出我们在不做重启机器的情况需要通过ansible自定义环境变量,可以写入至用户的.bash_profile,使其直接生效。(这句话有点长需要思考)但不能写入root用户下必须是创建的其他用户,比如在我们通过用ansible部署es服务(elasticsearch),必须由普通用户执行时,如因环境变量未生效,导致没有jdk环境,服务则不能正常启动。相对应的jdk环境变量就需要写入到/home/elasticsearch(所创建的用户)/.bash_profile下。
总结 aisible 在source 执行环境变量中必须有重读环境变量配置文件的动作,这个动作可以是重启,切换用户,手动source等。批量部署是可先创建普通用户,将环境变量写入到自定义变量文件中(.bash_profile)完成切换用户动作。