ssh远程连接主机执行脚本失败,原因:无法获取全局环境变量,解决:

发现问题是:自己写的zookeeper的一键启动脚本一直启动不了zookeeper集群

于是把这个命令单拎出来执行:通过ssh远程连接主机192.168.88.110执行zookeeper服务zkServer.sh

ssh 192.168.88.110 "/export/server/zookeeper/bin/zkServer.sh start"

虽然显示STARTED,但是到192.168.88.110上用jps查看,发现还是没有启动

如果是登录到192.168.88.110 上,再执行zkServer.sh start命令,发现又可以启动zookeeper

ssh 192.168.88.110    # 配了免密登录

/export/server/zookeeper/bin/zkServer.sh start

jps

后面查了下资料,发现是ssh远程连接主机执行脚本无法获取全局环境变量

把脚本里面命令,前面加上source /etc/profile ,让shell程序自己加载环境变量

ssh 192.168.88.110 "source /etc/profile;/export/server/zookeeper/bin/zkServer.sh start"

然后就可以了。

原因:

通过ssh执行远程的命令或者脚本和通过ssh登录到远程主机后在执行脚本这两种方式的bash模式不同。

通过ssh远程执行脚本命令,这个方式使用的是bash的non-login + non-interactive模式。是不会读取/etc/profile中的配置。

通过SSH登录后再执行脚本,这种方式使用的是Bash的interactive + login shell模式。
这种模式下回读取优先读取/etc/profile的配置,所谓我设置的环境变量是能够读取到的。

4月27日补充:

交互式shell:shell等待你的输入,并且执行你提交的命令。这种模式被称作交互式是因为shell与用户进行交互。这种模式也是大多数用户非常熟悉的:登录、执行一些命令、签退。当你签退后,shell也终止了

非交互式shell:shell不与你进行交互,而是读取存放在文件中的命令,并且执行它们。当它读到文件的结尾,shell也就终止了。

非交互式shell配置~/.bashrc文件环境变量就可以了。

~/.bashrc:该文件包含专用于某个用户的bash shell的bash信息,当该用户登录时以及每次打开新的shell时,该文件被读取

参考:

https://www.jianshu.com/p/14e3ba5da65b

https://blog.csdn.net/whitehack/article/details/51705889

更详细的解释和解决方法可以参考上面的文章

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值