https://blog.csdn.net/linghuchong_huashan/article/details/77885841
问题场景: hadoop集群部署在虚拟机上,每次开机都要重新启动集群,所以想写一个脚本来意见启动所有服务。但是,写成如下脚本,提示执行成功,但登录远程主机jps查看,本地能启动该进程,远程的主机并没有zookeeper进程。
#!/bin/sh
echo "start zookeeper"
/opt/cdh-5.3.6/zookeeper-3.4.5/bin/zkServer.sh start
echo $?
ssh 172.16.217.11 "/opt/cdh-5.3.6/zookeeper-3.4.5/bin/zkServer.sh start"
echo $?
ssh 172.16.217.12 "/opt/cdh-5.3.6/zookeeper-3.4.5/bin/zkServer.sh start"
echo "$?"
问题原因: shell脚本执行的过程中,登录shell 和非登录shell 读取的环境配置文件不同。
登录shell 会读取 /etc/profile, ~/.bash_profile,~/.bash_login ,~/.profile等文件,而非登录shell 读取的脚本有 /etc/bashrc 和 ~/.bashrc ,像java,path 这些环境变量读取不到。
解决方法:
- 将/etc/profile文件写入 ~/.bashrc ; cat /etc/profile >~/.bashrc
- 把profile的配置信息echo到.bashrc中 echo ‘source /etc/profile’ >> ~/.bashrc