Expect安装

[root@web02 scripts]# yum install expect

SSH密钥生成

[root@web02 scripts]# ssh-keygen -t dsa   <==生成密钥

Generating public/private dsa key pair.

Enter file in which to save the key (/root/.ssh/id_dsa):

Enter passphrase (empty for no passphrase):

Enter same passphrase again:

Your identification has been saved in /root/.ssh/id_dsa.

Your public key has been saved in /root/.ssh/id_dsa.pub.

The key fingerprint is:

d8:a6:e4:1f:8a:9a:25:f9:39:6c:74:1e:69:78:78:11 root@web02

The key's randomart image is:

+--[ DSA 1024]----+

|                 |

|      E          |

|       .         |

|      .o         |

|     oooS        |

|   .+oBo         |

|  oo.*o..        |

|   =+o.o .       |

|  oo+.. .        |

+-----------------+

 

密钥分发

[root@web02 scripts]# vi ssh_handout.expect  <==脚本编写

#!/usr/bin/expect -f

set ip [lindex $argv 0 ]    <==接受第一个参数,赋值ip

set password 118530  <==被分发主机密码

set timeout 10

cd ~

spawn ssh-copy-id -i .ssh/id_dsa.pub root@$ip  <==发送  .ssh/authorized_keys到目标主机

expect {

"*yes/no" { send "yes\r"; exp_continue}      <==遇见“YES/NO”  发送命令“YES”

"*password:" { send "$password\r" }          <==遇见“password” 发送命令“密码”

}

expect "#*"

#send "pwd\r"

#send  "exit\r"

expect eof

~

~

~

~

~

~

~

~

~

"ssh_handout.expect" 15L, 305C written

[root@web02 scripts]# ./ssh_handout.expect 192.168.162.130  <==测试

spawn ssh-copy-id -i .ssh/id_dsa.pub root@192.168.162.130

root@192.168.162.130's password:

Now try logging into the machine, with "ssh 'root@192.168.162.130'", and check in:

.ssh/authorized_keys   <==表示正确

to make sure we haven't added extra keys that you weren't expecting.

expect: spawn id exp4 not open

while executing

"expect eof "

(file "./ssh_handout.expect" line 14)

[root@web02 ~]# ssh root@192.168.162.130      <==免密码登陆

Last login: Thu Jul 21 19:59:12 2016 from 192.168.162.131

[root@web01 ~]# logout

Connection to 192.168.162.130 closed.

[root@web02 ~]# scp data/a.txt root@192.168.162.130:/tmp/  <==免密码传送文件

a.txt                  100%   13     0.0KB/s   00:00

[root@web02 ~]# ssh root@192.168.162.130

Last login: Thu Jul 21 20:01:20 2016 from 192.168.162.131

[root@web01 ~]# ls /tmp/

a.txt  yum.log

[root@web01 ~]# logout

Connection to 192.168.162.130 closed.

[root@web02 ~]#

[root@web02 scripts]# vi handout.sh   <==分发到多个主机脚本

#aim:handout ssh to host

#!/bin/bash

#aim:handout ssh to host

#author:changyaoguo

#date:2016/07/21

. /etc/init.d/functions

for n in 128 129 130  132 133   <==每个主机的部分主机号

do

/server/scripts/ssh_handout.expect 192.168.162.$n >/dev/null 2>&1

action "ssh  192.168.162.$n" /bin/true

done

~

~

~

~

"handout.sh" [New] 10L, 245C written

[root@web02 scripts]# sh handout.sh       <==测试

ssh  192.168.162.128                                       [  OK  ]

ssh  192.168.162.129                                       [  OK  ]

ssh  192.168.162.130                                       [  OK  ]

ssh  192.168.162.132                                       [  OK  ]

ssh  192.168.162.133                                       [  OK  ]

希望点个赞!!!!

ssh+expect批量分发的更多相关文章

  1. ssh密钥批量分发

    #################以下所有的命令脚本都是在centos7系统上实现,centos6略有不同 客户端使用公钥连接服务器的步骤: 提起ssh我们就能想到的是远程连接,平时我们都是通过密码来 ...

  2. expect批量分发公钥

    sshkey.exp #!/usr/bin/expect# 由于是多台服务器,需要在shell脚本中循环调用该脚本 if { $argc != 2 } { send_user "usage: ...

  3. expect批量分发密钥对

    vim shell.exp #!/usr/bin/expect set timeout 10 set hostname [lindex $argv 0] set username [lindex $a ...

  4. SSH KEY 批量分发

    代码 #!/bin/sh . /etc/init.d/functions ];then echo "sh $0 arg0" exit fi for ip in 172.23.216 ...

  5. 【SSH项目实战三】脚本密钥的批量分发与执行

    [SSH项目实战]脚本密钥的批量分发与执行 标签(空格分隔): Linux服务搭建-陈思齐 ---本教学笔记是本人学习和工作生涯中的摘记整理而成,此为初稿(尚有诸多不完善之处),为原创作品,允许转载, ...

  6. 【SSH项目实战】脚本密钥的批量分发与执行【转】

    [TOC] 前言 <项目实战>系列为<linux实战教学笔记>第二阶段内容的同步教学配套实战练习,每个项目循序衔接最终将组成<Linux实战教学笔记>第二阶段核心教 ...

  7. ssh密钥分发之二:使用sshpass配合ssh-kopy-id编写脚本批量分发密钥:

    使用sshpass配合ssh-kopy-id编写脚本批量分发密钥: 首先sshpass是一个ssh连接时的免交互工具,首先要安装一下: yum install sshpass -y 接下来我们就可以使 ...

  8. (转)SSH批量分发管理&非交互式expect

    目录 1 SSH批量分发管理 1.1 测试环境 1.2 批量管理步骤 1.3 批量分发管理实例 1.3.1 利用sudo提权来实现没有权限的用户拷贝 1.3.2 利用sudo提权开发管理脚本 1.3. ...

  9. (转)Linux SSH批量分发管理

    Linux SSH批量分发管理 原文:http://blog.51cto.com/chenfage/1831166 第1章 SSH服务基础介绍 1.1 SSH服务 1.1.1SSH介绍 SSH是Sec ...

随机推荐

  1. STL set 用法

      c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许. ...

  2. Django分析之使用redis缓存服务器

    时间长没有更新了,这段时间一直忙着一个项目,今天就记录一个现在经常会用到的技术吧. redis相信大家都很熟悉了,和memcached一样是一个高性能的key-value数据库,至于什么是缓存服务器, ...

  3. 深入分析Java ClassLoader原理

    一.什么是ClassLoader? 大家都知道,当我们写好一个Java程序之后,不是管是CS还是BS应用,都是由若干个.class文件组织而成的一个完整的Java应用程序,当程序在运行时,即会调用该程 ...

  4. About_Return

    返回值:return return 表示从被调函数返回到主调函数继续执行,返回时可附带一个返回值,由return后面的参数指定. return通常是必要的,因为函数调用的时候计算结果通常是通过返回值带 ...

  5. Django入门实践(3)

    Django简单应用 前面简单示例说明了views和Template的工作过程,但是Django最核心的是App,涉及到App则会和Model(数据库)打交道.下面举的例子是创建一个简单应用wiki ...

  6. css实现 当鼠标移到input的时候,input框出现阴影,当移动到button的时候,input框的阴影消失,button框出现阴影

    <meta charset="utf-8" /> <style type="text/css"> div{overflow: hidde ...

  7. split函数的实现

    split作为字符串分割函数非常有用,但在C++里面没有这个函数.自己实现一个分割函数: 1.遇到多个分隔符连在一起,则不做分割 2.()内的分隔符不起作用 3.如果只有(,没有)不影响分隔符 #in ...

  8. Graph Cuts初步理解

    一些知识点的初步理解_8(Graph Cuts,ing...) Graph cuts是一种十分有用和流行的能量优化算法,在计算机视觉领域普遍应用于前背景分割(Image segmentation).立 ...

  9. poj1700-Crossing River(贪心算法)

    一,题意: 只有一艘船,能乘2人,船的运行时间为2人中较多一人的时间,过去后还需一个人把船划回来,问把n个人运到对岸,最少需要多久.二,思路步骤: 想办法先把用时最多的2人,运过去,再把剩下来的人中用 ...

  10. Sublime Text 3 杂记

    Sublime Text 是一个功能强大的代码编辑器(收费,但可无限期试用).由程序员Jon Skinner于2008年1月份所开发出来,它最初被设计为一个具有丰富扩展功能的Vim.Sublime T ...