之前每次登录服务器都是这样的。
1.先登录堡垒机
2.选择服务器
3.输入服务器名或编号
4.先切换到root用户
5.再切换到hdfs用户
具体登录过程如下图(红框的位置需要手动输入内容):
如此这样的话,每一次登录服务器,进行hadoop操作,都需要进行5步操作,如果密码不记得,还得拷贝密码,甚是麻烦,也非常的耽误时间,影响工作效率。
今天研究了一些Linux的expect自动登录功能,非常好用,在这里可以大显身手。先贴一下代码,其中的秘钥,用户名和密码需要替换成自己的。还有expect的内容和send的内容也要根据自己的实际情况进行替换。1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#!/usr/bin/expect
set user wangjunbo
set host 13.6.6.9
set password RFCQQ
spawn ssh -i /Users/Documents/company/xxx.pem $user@$host
expect "*passphrase*"
send "$password\r"
if { $argc == 0 } {
set seq 1
}
if { $argc == 1 } {
#puts "not two"
set seq [lindex $argv 0]
}
if { $seq != "lll" } {
expect "*ID>*"
if { $seq == 1 || $seq == 2 } {
send "hadoop00$seq\n"
} else {
send "$seq\n"
}
expect "ops*"
send "sudo su -\n"
if { $seq == 1 || $seq == 2 } {
expect "*root@hadoop*"
send "su - hdfs\n"
if { $seq == 1 } {
expect "*hdfs@hadoop*"
send "cd shell/new/\n"
} elseif { $seq == 2 } {
expect "*hdfs@hadoop*"
send "cd /data/work/shell/\n"
}
} elseif { $seq == "app001" || $seq == "app002" } {
expect "root*"
send "cd /data/apps/recommend/\n"
}
}
interact
expect eof
$argc == 0的意思是如果没有参数,那么就默认登录hadoop001服务器。
$argc == 1的意思是如果有一个参数,就去第一个参数[lindex $argv 0]作为登录服务器名。
“ if { $argc == 0 } { “ 后边的}{之间一定要有一个空格,否则会报错“extra characters after close-brace”。
将上边的内容修改后保存为/usr/local/bin/lg文件,可能还需要使切换到root用户(Mac用户使用sudo su -切换到root用户)。
修改权限1
chmod 777 /usr/local/bin/lg
如果不放到/usr/local/bin/目录下,在其它目录下执行,需要使用如下的方式1
./lg
而不能用如下的方式1
sh lg
然后使用直接在命令行使用lg进行登录:
下边是具体的效果:
整个过程就输入了一个lg,然后回车就可以了,是不是很方便。