亦余心之所善兮,虽九死其犹未悔。这篇文章主要讲述Ansible设置远程环境变量问题相关的知识,希望能为你提供帮助。
一、问题背景
SSH远程执行脚本报错"command not found",且环境变量不生效,执行env命令后发现打印出来的环境变量少了很多。
原因是之前将环境变量配置在了/etc/profile中,但是SSH远程执行脚本时实际上执行的是non-login shell,而non-login shell不会读取/etc/profile配置文件。
二、关于login shell和non-login shell
简单来说,用SSH客户端(比如Putty)登陆Linux系统时,要求输入用户名/密码登录或根据SSH key登录时,就是login shell。
而在A机器上使用SSH免密码登录B机器,在B机器上执行Shell脚本,就是non-login shell。
【Ansible设置远程环境变量问题】用Ansible在目标机器上远程执行Shell脚本时,也是non-login shell,因为Ansible是基于SSH的。
Linux环境配置文件,以CentOS7为例:
/etc/profile
/etc/bashrc
~/.bash_profile
~/.bashrc
注意:~/.bash_profile引入了~/.bashrc,而~/.bashrc引入了/etc/bashrc,因此login shell可以读取到所有配置文件的环境变量
1. /etc
下的是系统环境配置,对所有用户有效,但是/etc/profile只对login shell有效,而/etc/bashrc对login shell和non-login shell都有效。
2.~下的是当前用户环境配置,当前用户环境配置会继承/etc系统环境配置。
login shell加载环境变量的顺序:①/etc/profile ②~/.bash_profile ③~/.bashrc ④/etc/bashrc
nologin shell加载环境变量的顺序: ①/etc/bashrc ②~/.bashrc
三、解决non-login shell的环境配置问题
方法一:将login-shell和non-login shell都需要的环境配置放在~/.bashrc或/etc/bashrc中,其它配置放在~/.bash_profile或/etc/profile中。
方法二:如果环境配置只放在~/.bash_profile或/etc/profile中,需要执行non-login shell时先source ~/.bash_profile再执行命令。
方法三:更改ansible配置文件并添加hosts参数
①在ansible配置文件添加become_method=su,become_flags=-lsudo对应的flag为-i如果我登录的用户就是我希望用来执行命令的用户还需要设置become_allow_same_user=True
②在hosts里配置
ansible_become=true
ansible_become_user=
ansible_become_pass=
?
推荐阅读
- Ansible的配置文件
- 如何使用NodeJS构建Discord机器人(实现指南)
- NextJS是什么(使用Next开发更快网站的示例)
- 8个很酷的CSS提示和技巧(这样做效果更好)
- 使用这些最佳NodeJS模板引擎合集构建任何视图
- 每个Web开发人员都必须拥有的Chrome扩展程序合集
- 如何在Javascript中比较日期(方法和注意事项)
- 如何自定义TailwindCSS美化网站提供独特的外观()
- 顶级深度学习算法有哪些(你应该知道这些)