问题

很多问题都是由于双眼号引起的,但是shell标准确很喜欢让开发者加上双眼号。
脚本通过ssh远程操作其它相器,正常情况下脚本会将我本机的脚本变量带到远程机器上,这个脚本一直远行正常。
然后看到一个shell的变量使用规范,要在大部分重要的变量是加上又眼号,我就这么干了,然后就出问题了。

正常场景

我在本机:192.168.1.100上执行脚本,并登陆:192.168.1.200上操作一下,正常应该打印出:test-abcd,但是由于变量失效,则打印为空。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#!/bin/bash
nodes(
192.168.1.101
192.168.1.102
192.168.1.200
)

myVar="test-abcd"
startNodes() {
local nodes=("$@")
for node in "${nodes[@]}"; do
{
echo "[info]: start node: $node"
# 处理,去掉"EOF",改成 EOF,就正常
ssh -p 22008 -Tq java-tron@"$node"<<"EOF"
# 正常打印出 test-abcd
echo $myVar
exit
# 这个EOF必须在这个位置,左边不要有空格或缩进
EOF
}&
done
wait
}

原因,是由于 EOF 改成了 "EOF",导致变量解决失败。去掉"EOF"的双眼号,正常。
上面这段shell,也是并行ssh到远程的代码,也可以直接复制去使用,wait 标识是表示线处理完成之后,在wait处等待所有线程处理完毕后,往下执行,如果不需等待,就去掉wait。