交互式shell 非交互式shell
发现问题是:自己写的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的配置,所谓我设置的环境变量是能够读取到的。
交互式shell:shell等待你的输入,并且执行你提交的命令。这种模式被称作交互式是因为shell与用户进行交互。这种模式也是大多数用户非常熟悉的:登录、执行一些命令、签退。当你签退后,shell也终止了
非交互式shell:shell不与你进行交互,而是读取存放在文件中的命令,并且执行它们。当它读到文件的结尾,shell也就终止了。
非交互式shell配置~/.bashrc文件环境变量就可以了。
~/.bashrc:该文件包含专用于某个用户的bash shell的bash信息,当该用户登录时以及每次打开新的shell时,该文件被读取
典型模式总结
为了更好的理清这几种模式,下面我们对一些典型的启动方式各属于什么模式进行一个总结:
- 登陆机器后的第一个shell:login + interactive
- 新启动一个shell进程,如运行
bash
:non-login + interactive - 执行脚本,如
bash script.sh
:non-login + non-interactive - 运行头部有如
#!/usr/bin/env bash
的可执行文件,如./executable
:non-login + non-interactive - 通过ssh登陆到远程主机:login + interactive
- 远程执行脚本,如
ssh user@remote script.sh
:non-login + non-interactive - 远程执行脚本,同时请求控制台,如
ssh user@remote -t 'echo $PWD'
:non-login + interactive - 在图形化界面中打开terminal:
- Linux上: non-login + interactive
- Mac OS X上: login + interactive
bash的每种模式会读取其所在列的内容,首先执行A,然后是B,C。而B1,B2和B3表示只会执行第一个存在的文件:
+----------------+--------+-----------+---------------+
| | login |interactive|non-interactive|
| | |non-login |non-login |
+----------------+--------+-----------+---------------+
|/etc/profile | A | | |
+----------------+--------+-----------+---------------+
|/etc/bash.bashrc| | A | |
+----------------+--------+-----------+---------------+
|~/.bashrc | | B | |
+----------------+--------+-----------+---------------+
|~/.bash_profile | B1 | | |
+----------------+--------+-----------+---------------+
|~/.bash_login | B2 | | |
+----------------+--------+-----------+---------------+
|~/.profile | B3 | | |
+----------------+--------+-----------+---------------+
|BASH_ENV | | | A |
+----------------+--------+-----------+---------------+