20.31 expect腳本同步文件;20.32 expect腳本指定host和要同步的文件;20.33 構建文件分發系統;20.34 批量遠程執行命令shell
20.31 expect腳本同步文件
vim
自動同步文件安全
1. 同步遠程機器hao2上/tmp/12.txt文件 到本機/tmp/下 :bash
[root@hao-01 ~]# vim 4.expectssh
添加內容:ide
#!/usr/bin/expect網站
set passwd "admin"spa
spawn rsync -av root@192.168.211.129:/tmp/12.txt /tmp/blog
expect {ip
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}expect eof
2. 增長4.expect腳本x權限 :
[root@hao-01 ~]# chmod a+x 4.expect
3. 執行4.expect腳本(自動同步文件) :
[root@hao-01 ~]# ./4.expect
20.32 expect腳本指定host和要同步的文件
1. 執行腳本須要:指定host(主機ip)和要同步的文件
[root@hao-01 ~]# vim 5.expect
添加內容:
#!/usr/bin/expect
set passwd "admin"
set host [lindex $argv 0]
set file [lindex $argv 1]
spawn rsync -av $file root@$host:$file
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof
2. 增長5.expect腳本x權限 :
[root@hao-01 ~]# chmod a+x 5.expect
3. 執行5.expect腳本(執行一次只能同步一個文件!) :
[root@hao-01 ~]# ./5.expect 192.168.211.128 "tmp/12.txt"
20.33 構建文件分發系統
shell項目-分發系統-構建文件分發系統
1. 需求背景對於大公司而言,確定時不時會有網站或者配置文件更新,並且使用的機器確定也是好多臺,少則幾臺,多則幾十甚至上百臺。因此,自動同步文件是相當重要的。
2. 實現思路首先要有一臺模板機器,把要分發的文件準備好,而後只要使用expect腳本批量把須要同步的文件分發到目標機器便可。
3. 核心命令rsync -av --files-from=list.txt / root@host:/
文件分發系統的實現
1. 建立rsync.expect核心腳本 :
(從本地/根目錄 到遠程/根目錄)
[root@hao-01 ~]# vim rsync.expect
(遠程ip機器密碼須要和本地一致;也能夠作用戶認證,便可不用密碼一致,安全)
添加內容:
#!/usr/bin/expect
set passwd "admin"
set host [lindex $argv 0]
set file [lindex $argv 1]
spawn rsync -avR --files-from=$file / root@$host:/
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect eof
2. 建立本地同步文件列表文件 :
(本地同步到遠程機器的文件;絕對路徑)
[root@hao-01 ~]# vim /tmp/file.list
添加內容:
/tmp/12.txt
/root/1.txt
3. 建立遠程機器ip列表文件 :
(遠程ip機器密碼須要和本地一致;也能夠作用戶認證,便可不用密碼一致,安全)
[root@hao-01 ~]# vim /tmp/ip.list
添加內容:
192.168.211.129
127.0.0.1
4. 建立 rsync.sh循環腳本 :
(對應指定: 同步到遠程機器ip列表文件 本地同步文件列表文件)
[root@hao-01 ~]# vim rsync.sh
添加內容:
#!/bin/bash
for ip in `cat /tmp/ip.list`
do
./rsync.expect $ip /tmp/file.list
done
5. 增長rsync.sh腳本x權限 :
[root@hao-01 ~]# chmod a+x rsync.sh
6. 執行rsync.sh腳本
[root@hao-01 ~]# sh -x rsync.sh
20.34 批量遠程執行命令
1. 建立exe.expect核心腳本:
[root@hao-01 ~]# chmod a+x exe.expect
添加內容:
#!/usr/bin/expect
set host [lindex $argv 0]
set passwd "admin"
set cm [lindex $argv 1]
spawn ssh root@$host
expect {
"yes/no" { send "yes\r"}
"password:" { send "$passwd\r" }
}
expect "]*"
send "$cm\r"
expect "]*"
send "exit\r"
2. 增長exe.expec腳本x權限 :
[root@hao-01 ~]# chmod a+x exe.expec
3. 建立exe.sh腳本 :
(設定 訪問遠程機器執行的命令)
[root@hao-01 ~]# vim exe.sh
#/bin/bash
for ip in `cat /tmp/ip.list`
do
./exe.expect $ip "ls"
done
4. 執行exe.sh腳本 :
[root@hao-01 ~]# sh exe.sh