码迷,mamicode.com
首页 > 系统相关 > 详细

[shell实例]——用脚本实现向多台服务器批量复制文件(nmap、scp)

时间:2016-06-27 23:15:54      阅读:437      评论:0      收藏:0      [点我收藏+]

标签:

练习环境:

(1)所有服务器将防火墙和selinux关闭
(2)所有服务器的root密码设置为aixocm
(3)所有服务器都为10.0.100.*网段,并保证能够和其它主机通信
(4)所有服务器确保sshd服务已经启动(开放默认的22端口)

 

脚本要求实现:

将本机/etc目录下以conf为扩展名的文件打包压缩为tar.bz2,然后将此文件复制一份到10.0.100.1-->10.0.100.254地址段上所有开启的主机,具体路径为/tmp/sjjy/文件。在使用scp复制时无需手动输入密码。

脚本的大概思路:

(1)Tar_etc( )函数:实现对/etc下所有*.conf目录的打包,并判断是否打包成功。

(2)Nmap_ip( )函数:实现扫描已开启的主机。用nmap命令实现。并将这些主机IP写到/mydate/ip.txt文件中。

(3)Scp_ip( )函数:实现将压缩包发送到各个主机的指定目录下。 利用了#expect命令来实现的输入。

 

#!/bin/bash
#============================================
#function-->Tar_etc 打包/etc/*.conf下的文件
#============================================
Tar_etc()
{
    tar jcvf /tmp/lyj.tar.bz2 /etc/*.conf  &> /dev/null
    if [ $? -eq 0 ]
    then
       echo "压缩包打包完成"
    else
       echo "压缩包打包失败请检查"
    fi   
}
#=========================================
#function-->Nmap_ip 扫描网段内开启的主机
#=========================================
Nmap_ip()
{
    [ -f /mydate/ip.txt ]
    if [ $? -eq 0 ]
    then
        cat /dev/null >/mydate/ip.txt
    else
        touch /mydate/ip.txt
    fi
  nmap -n -sP 10.0.100.1-254 | grep 10.0.100 | awk ‘{print $5}‘ >/mydate/ip.txt 
}
#======================================
#function-->Scp_ip 复制文件到各个主机
#======================================
Scp_ip()
{
cat /mydate/ip.txt | while read line
do
(
   /usr/bin/expect << EOF
   set time 20
   spawn scp /tmp/lyj.tar.bz2 root@$line:/tmp/sjjy
   expect {
        "*yes/no*"
          { send "yes\r";exp_continue }
        "*password:"
          { send "aixocm\r"} 
   }
   expect eof
EOF
) &>/dev/null
 
   if [ $? -eq 0 ]
   then
       echo "复制文件到$line成功!"
   else 
       echo "复制文件到$line失败!"
   fi
done
}

Tar_etc
Nmap_ip
Scp_ip

 

[shell实例]——用脚本实现向多台服务器批量复制文件(nmap、scp)

标签:

原文地址:http://www.cnblogs.com/snsdzjlz320/p/5620597.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!