linux执行远程命令找不到环境变量
问题:
当使用ssh执行远程命令或者远程服务器的运行脚本时,报错:can‘t find .....这里我碰到的是go里面的,见下图:
image
我配置的gopath在/home/go下面,本质的问题还是找不到自定义的环境变量;但是直接用ssh登录到远程服务器上面以后,再执行相应的脚本时成功的。
查阅资料发现,这两种方式使用的bash模式不同(bash:shell的一种,也是现在大部分的linux的发行版本,shell就简单理解成命令行解释器吧)
首先,先解释一下linux下面的四种bash模式:
- login shell:
When you log onto the system use password
表示当你登录使用用户名密码到服务器上的时候,会得到一个login shell
在终端使用--login会得到一个交互式的login shell
在脚本中使用--login会得到一个非交互式的login shell(非交互式:执行完脚本就退出)
使用su -切换用户会得到此用户login shell
- non-login shell
除了上面的情况,得到的都是non-login shell。不需要使用密码重复登录获取shell得到的都是non-login shell。比如:
window登录到linux,然后再使用图形化界面登录就不需要密码,是non-login shell
在当前的bash下面再执行一个bash指令,也是一个non-login shell。
简单来说,不需要用户名密码的都是non-login shell
- interactive
交互式
4.non-interactive
非交互式
其中1和2是或者的关系,3和4也是或者的关系
1和2的shell 模式决定了配置文件的加载方式!!!
一:使用ssh登录到服务器再执行脚本或者命令
使用的bash模式: interactive + login shell
加载的配置文件方式(按照先后顺序,找到退出)
/etc/profile
~/.bash_profile ~/.bash_login ~/.profile
二:使用ssh执行远程命令和脚本
使用的bash模式:non-interactive+non-login shell
加载的配置文件方式(按照先后顺序,找到退出)
~/.bashrc
出现的原因:
由于~/.bashrc中没有配置相关自定义的环境变量,所以找不到配置的gopath,默认在/root目录下面找,找不到所需的文件
解决问题:
可以在~/.bashrc里面配置自己所需要的环境变量
参考资料:
shell 模式参考资料:https://likegeeks.com/linux-environment-variables/