问题:
使用anible的过程中经常出现以下报错:
/bin/sh: rabbitmqctl: command not foundnon-zero return code
登入服务器执行命令却没有报错
原因:环境变量配置在了/etc/profile中,但是SSH远程执行脚本时实际上执行的是non-login shell,而non-login shell不会读取/etc/profile配置文件。
单来说,用SSH客户端(比如Putty)登陆Linux系统时,要求输入用户名/密码登录或根据SSH key登录时,就是login shell。
而在A机器上使用SSH免密码登录B机器,在B机器上执行Shell脚本,就是non-login shell。
用Ansible在目标机器上远程执行Shell脚本时,也是non-login shell,因为Ansible是基于SSH的。
login shell加载顺序
/etc/profile-->~.bash_profile-->/etc/bashrc-->~.bashrc
mon-login shell加载顺序
/etc/bashrc-->~.bashrc
解决方法:
方式1:执行命令前source /etc/profile && command
方式2:在yaml中的指定环境变量
---
- hosts: all
gather_facts: no
environment:
PATH: /usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin
tasks:
....