设为首页 收藏本站
查看: 1005|回复: 0

shell编程【分发系统】

[复制链接]

尚未签到

发表于 2018-8-28 10:21:54 | 显示全部楼层 |阅读模式
  shell编程【分发系统】
  原文地址:http://www.apelearn.com/bbs/thread-8113-1-1.html
  第一部分:expect讲解
  expect可以让我们实现自动登录远程机器,并且可以实现自动远程执行命令。当然若是使用不带密码的密钥验证同样可以实现自动登录和自动远程执行命令。但当不能使用密钥验证的时候,我们就没有办法了。所以,这时候只要知道对方机器的账号和密码就可以通过expect脚本实现登录和远程命令。
  使用expect之前,需要先安装expect:
  yum install -y expect
  确认expect包安装:
  [root@daixuan ~]# rpm -qa  | grep expect
  expect-5.44.1.15-5.el6_4.i686
  1. 自动远程登录,并执行命令
  首先来看一个登录后不退出的脚本:
  [root@daixuan ~]# mkdir shell
  [root@daixuan ~]# cd shell
  [root@daixuan shell]# vim 1.expect
#! /usr/bin/expect  
set host "192.168.101.108"
  
set passwd "daixuan"
  
spawn ssh  root@$host
  
expect {
  
"yes/no" { send "yes\r"; exp_continue}
  
"assword:" { send "$passwd\r" }
  
}
  
interact
  [root@daixuan shell]# chmod +x 1.expect
  [root@daixuan shell]# ./1.expect     #这里从101.230成功远程登录101.108
  spawn ssh root@192.168.101.108
  The authenticity of host '192.168.101.108 (192.168.101.108)' can't be established.
  RSA key fingerprint is 6a:b8:52:23:8e:38:00:91:b4:30:bc:94:62:f9:fc:8e.
  Are you sure you want to continue connecting (yes/no)? yes
  Warning: Permanently added '192.168.101.108' (RSA) to the list of known hosts.
  root@192.168.101.108's password:
  Last login: Fri Feb 12 20:14:27 2016
  [root@daixuan ~]# ifconfig
  eth0      Link encap:Ethernet  HWaddr 00:0C:29:0B:C6:57
  inet addr:192.168.101.108  Bcast:192.168.101.255  Mask:255.255.255.0[root@daixuan ~]# logout
  Connection to 192.168.101.108 closed.
  [root@daixuan shell]# ifconfig
  eth0      Link encap:Ethernet  HWaddr 00:0C:29:72:15:4F
  inet addr:192.168.101.230  Bcast:192.168.101.255  Mask:255.255.255.0
  2、再来看一个登陆后,执行命令然后退出的脚本:
  [root@daixuan shell]# vim 2.expect
#!/usr/bin/expect  
set user "root"
  
set passwd "daixuan"
  

  
spawn ssh $user@192.168.11.108
  

  
expect {
  
"yes/no" { send "yes\r"; exp_continue}
  
"password:" { send "$passwd\r" }
  
}
  
expect "]*"
  
send "touch /tmp/12.txt\r"
  
expect "]*"
  
send "echo 1212 > /tmp/12.txt\r"
  
expect "]*"
  
send "exit\r"
  [root@daixuan shell]# chmod +x 2.expect
  [root@daixuan shell]# ./2.expect
  spawn ssh root@192.168.101.108
  root@192.168.101.108's password:
  Last login: Fri Feb 12 20:52:12 2016 from www.test.com
  [root@daixuan ~]# touch /tmp/12.txt
  [root@daixuan ~]# echo 1212 > /tmp/12.txt
  [root@daixuan ~]# [root@daixuan shell]#
  登录101.108 查看
  [root@daixuan ~]# cat /tmp/12.txt
  1212
  3. 我们还可以传递参数
  [root@daixuan shell]# vim 3.expect
#!/usr/bin/expect  
set user [lindex $argv 0]
  
set host [lindex $argv 1]
  
set passwd "daixuan"
  
set cm [lindex $argv 2]
  
spawn ssh $user@$host
  
expect {
  
"yes/no" { send "yes\r"}
  
"password:" { send "$passwd\r" }
  
}
  
expect "]*"
  
send "$cm\r"
  
expect "]*"
  
send "exit\r"
  [root@daixuan shell]# chmod x 3.expect
  执行: ./3.expect root 192.168.101.108 w
  [root@daixuan shell]# ./3.expect root 192.168.101.108 w
  spawn ssh root@192.168.101.108
  root@192.168.101.108's password:
  Last login: Fri Feb 12 22:30:59 2016 from 192.168.101.105
  [root@daixuan ~]# w
  22:31:21 up  2:57,  4 users,  load average: 0.00, 0.00, 0.00

  USER     TTY      FROM              LOGIN@  >  root     tty1     -                20:14   58:58   0.09s  0.09s -bash
  root     pts/0    192.168.101.105  21:33   10:46   0.16s  0.04s bash
  4. 自动同步文件
  [root@daixuan shell]# vim 4.expect
#!/usr/bin/expect  
set passwd "daixuan"
  
spawn rsync -av root@192.168.101.108:/tmp/12.txt /tmp/
  
expect {
  
"yes/no" { send "yes\r"}
  
"password:" { send "$passwd\r" }
  
}
  
expect eof #这里必须有expect eof,否则只是登陆但不同步数据
  [root@daixuan shell]# chmod +x 4.expect
  [root@daixuan shell]# ./4.expect
  [root@daixuan shell]# cat /tmp/12.txt   #数据1212已经同步过来了
  1212
  5. 指定host和要同步的文件
  [root@daixuan shell]# vim 5.expect
#!/usr/bin/expect  
set passwd "daixuan"
  
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
  [root@daixuan shell]# chmod +x 5.expect
  新建本地101.230的文件:/tmp/12.txt,内容为空
  执行: ./5.expect 192.168.101.108 /tmp/12.txt
  同步之后,101.108服务器上的/tmp/12.txt内容也为空
  第二部分:构建文件分发系统
  1. 需求背景
  对于大公司而言,肯定时不时会有网站或者配置文件更新,而且使用的机器肯定也是好多台,少则几台,多则几十甚至上百台。所以,自动同步文件是至关重要的。
  2. 实现思路
  首先要有一台模板机器,把要分发的文件准备好,然后只要使用expect脚本批量把需要同步的文件分发到目标机器即可。
  3. 核心命令
  rsync -av --files-from=list.txt  /  root@host:/
  4. 文件分发系统的实现
  cat  rsync.expect
#!/usr/bin/expect  
set passwd "daixuan"
  
set host [lindex $argv 0]
  
set file [lindex $argv 1]
  
spawn rsync -av --files-from=$file / root@$host:/
  
expect {
  
"yes/no" { send "yes\r"}
  
"password:" { send "$passwd\r" }
  
}
  
expect eof
  此外,还需要定义:
  ip.list (定义需要同步的IP)
  file.list (需要使用绝对路径)
  cat rsync.sh
#!/bin/bash  
for ip in `cat ip.list`
  
do
  
    echo $ip
  
    ./rsync.expect $ip list.txt
  
done
  5. 命令批量执行脚本
  cat exe.expect
#!/usr/bin/expect  
set host [lindex $argv 0]
  
set passwd "daixuan"
  
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"
  cat exe.sh
#!/bin/bash  
for ip in `cat ip.list`
  
do
  
    echo $ip
  
    ./exe.expect $ip "w;free -m;ls /tmp"
  
done



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-557614-1-1.html 上篇帖子: shell批量操作循环 下篇帖子: Shell脚本之IP网络地址和广播地址计算
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表