上百台linux的服务器互信,批量自动建立linux服务器之间的ssh互信

介绍:我们在部署无密码访问时,如果手工输入.很费时间.下面方法用于自动化生成authorized_keys,免去了手工数据.

方法: 利用expect编写sshkey.exp在远程主机上生成id_rsa,并重定向到本地.在利用noscp.exp.把文件复制到远程主机

步骤:(本方法在centos6.4 上验证通过)

1 本地执行

ssh-keygen -t rsa

2 编写脚本生成 authorized_keys (比如现在有cloud1 和 cloud2 服务器)

./sshkey.exp  cloud1 root root123 | grep ssh-rsa >> ~/.ssh/authorized_keys

./sshkey.exp  cloud2 root root123 | grep ssh-rsa >> ~/.ssh/authorized_keys

3 对于需要建立免密码输入的,把文件拷贝上去

./noscp.exp ~/.ssh/authorized_keys cloud1:~/.ssh root root123

./noscp.exp ~/.ssh/authorized_keys cloud2:~/.ssh root root123

4. 脚本说明

./sshkey.exp  主机名 用户名  密码  (在远程主机生成id_rsa)

./noscp.exp   本地文件 远程路径  远程用户密码   (无密码拷贝文件)

注意:

每个主机上必须安装 openssh-clients

#!/usr/bin/expect

#sshkey.exp

if {$argc<3} {

puts stderr "Usage: $argv0 host  user  passwd "

exit 1

}

set host [ lindex $argv 0 ]

set user  [ lindex $argv 1 ]

set pwd  [ lindex $argv 2 ]

set timeout 30

#spawn ssh  ${user}@${host} "rm -rf ~/.ssh/id_rsa*"

#

#expect {

# "*yes/no" { send "yes\r"; exp_continue }

# "*password:" { send "$pwd\r"; exp_continue  }

#}

spawn ssh  ${user}@${host} "ssh-keygen -t rsa"

expect {

"*yes/no" { send "yes\r"; exp_continue }

"*password:" { send "$pwd\r"; exp_continue  }

"Enter file in which to save the key*" { send "\n\r"; exp_continue }

"Overwrite*" { send "y\n"; exp_continue }

"Enter passphrase (empty for no passphrase):" { send "\n\r"; exp_continue }

"Enter same passphrase again:" { send "\n\r" }

}

spawn ssh  ${user}@${host} "cat ~/.ssh/id_rsa.pub"

expect {

"*yes/no" { send "yes\r"; exp_continue }

"*password:" { send "$pwd\r"  }

}

expect eof

#!/usr/bin/expect

#noscp.exp

if {$argc<4} {

puts stderr "Usage: $argv0 localfile  remotefile user passwd "

exit 1

}

set localfile [ lindex $argv 0 ]

set remotefile  [ lindex $argv 1 ]

set user  [ lindex $argv 2 ]

set pwd  [ lindex $argv 3 ]

set timeout 30

spawn scp ${localfile}  ${user}@${remotefile}

expect {

"*yes/no" { send "yes\r"; exp_continue }

"*password:" { send "$pwd\r" }

}

expect eof

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/528666.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

debian 编译linux内核源码,Debian下为本机编译内核模块的方法

改用Debian之后发现用之前在Red Hat下编译内核模块的Makefile不好使了&#xff0c;原因是在/lib/modules/uname -r/下没有了build目录&#xff0c;也没有内核的源代码。上网查了一些资料&#xff0c;说在Debian下编译内核需要安装内核头文件。apt-get install linux-headers-un…

linux服务器操作系统日志都有哪些,Linux操作系统服务器日志管理详解

Linux操作系统服务器日志管理详解Linux操作系统服务器日志管理详解日志对于安全来说&#xff0c;非常重要&#xff0c;他记录了系统每天发生的各种各样的事情&#xff0c;你可以通过他来检查错误发生的原因&#xff0c;或者受到攻击时攻击者留下的痕迹。日志主要的功能有&#…

linux7配置dns服务器,centOS7搭建DNS服务器配置详解

写在前言&#xff1a;DNS服务器中 named-checkconf -z /etc/named.conf 命令用来检查所有与DNS有关的配置文件&#xff0c;若有错误&#xff0c;会直接提示&#xff0c;可以代替相关的所有检查命令。通过yum安装所需的BIND软件&#xff0c;系统光盘中自带了BIND服务的安装文件。…

linux重新安装xrog文件,Linux下重新生成xorg.conf

较新版本的Linux系统都已经没有xorg.conf文件&#xff0c;但是有时候为了对显示做微调或为了支持多屏显示等原因&#xff0c;还需要手工生成一个xorg.c较新版本的Linux系统都已经没有xorg.conf文件&#xff0c;但是有时候为了对显示做微调或为了支持多屏显示等原因&#xff0c;…

linux获取weblogic版本,LINUX查看JDK和Weblogic版本命令

满意答案xjiank2014.05.03采纳率&#xff1a;50% 等级&#xff1a;12已帮助&#xff1a;4893人JDKA、查找目前所使用的linux下所使用的jdk安装后的目录&#xff1a;echo $JAVA_HOME&#xff1b;B、获得目前所使用的linux下所使用的jdk的版本java -version&#xff1b;C、获得…

如何知道linux的ssh秘钥是否匹配,SSH密钥验证

[SSH登录两种方式验证](一)&#xff1a;用户名密码验证 说明&#xff1a;1.客户机向服务器发送SSH连接请求2.服务器收到请求&#xff0c;发送一个公钥给客户机3.客户机收到公钥&#xff0c;对输入的用户名密码进行加密返回给服务器4.服务器收到加密信息利用私钥解密对比用户…

linux 拨号网关,用LINUX做在一张软盘上的拨号网关 (转)

用LINUX做在一张软盘上的拨号网关 (转)[more]用做在一张上的拨号网关作者&#xff1a;linix摘要&#xff1a;本文给出了如何用LINUX做一个仅需要一张软盘的拨号网关。可以用它作为或一般MODEM的拨号网关。这些年PC机的发展真可以说是日新月异&#xff0c;这当然是好事。但是我们…

linux之父ted演讲视频观后感,ted演讲的观后感3篇

ted演讲的观后感3篇ted演讲的观后感篇一&#xff1a;《这一次是TED演唱,因为演讲真的很恐怖!》观后感 一个天生口吃的女孩&#xff0c;站在TED的讲台上&#xff0c;她要说她的故事&#xff0c;唱她的歌。这令我感触不少。先说一说&#xff0c;看完这场演讲&#xff0c;我脑中闪…

linux延迟绑定,php延迟绑定和非延迟绑定解析

php版本&#xff1a; php5.6延迟绑定有: get_class($this), get_called_class(), new static(), static::非延迟绑定有&#xff1a;get_class(), __CLASS__, new self(), self::使用new static()时<?phpclass NewStatic{//该类的实例private $newStatic; //判断$newStatic是…

学linux需要关闭防火墙,一起学习linux 关闭防火墙命令

p>Linux还是比较常用的&#xff0c;于是我研究了一下Linux关闭防火墙命令&#xff0c;在这里拿出来和大家分享一下&#xff0c;希望你能学会Linux关闭防火墙命令 。1) 永久性生效&#xff0c;重启后不会复原开启&#xff1a; chkconfig iptables on关闭&#xff1a; chkconf…

linux centos7 r安装,如何在CentOS 7上安装R

R是一种快速增长的开源编程语言和免费环境&#xff0c;专门从事统计计算和图形表示。它得到R统计计算基金会的支持&#xff0c;主要由统计学家和数据挖掘人员用于开发统计软件和执行数据分析。本教程将教您如何在CentOS 7上安装R以及如何从官方综合R归档网络(CRAN)安装R软件包。…

C语言实践作业报告,c语言社会实践报告

资料简介c 语言社会实践报告c 语言社会实践报告随着个人素质的提升&#xff0c;越来越多的事务都会使用到报告&#xff0c;报告中提到的所有信息应该是准确无误的。 相信许多人会觉得报告很难写吧&#xff0c;下面是为大家的 c 语言社会报告&#xff0c;仅供参考&#xff0c;欢…

c语言程序设计电加热炉,基于80C52单片机的电加热数字恒温控制系统设计

1 控制方案设计温度场是一个梯度场&#xff0c;温度的上升或下降随时间缓慢变化。电加热炉温度控制过程可以用自然降温、程序升温和恒温保持3个分过程来描述。自然降温&#xff1a;停止加热&#xff0c;环境温度在整个过程中保持不变&#xff0c;受控温度场最终稳定为环境温度。…

c语言程序培训,编写简单的c语言程序(noi培训)

编写简单的C语言程序(NOI培训),刘汝佳,何为“简单”&#xff1f;,百度风格&#xff1a;简单可依赖简单不等于简陋我们的目标&#xff1a;用简单、直观、不容易出错的程序来完成任意复杂的功能&#xff0c;而不是把各种“高级的东西”堆砌在一起&#xff0c;然后把包括自己在内的…

c语言用链表编写简单程序,C语言单链表简单实现(简单程序复杂化)

PS: goto还是很好玩的。#include #include typedef struct _node{int value;struct _node *next;} Node;typedef struct _list{Node* head;}List;void add(List* plist,int number);void print(List* list);void deletel(List* list,int number);void freel(List* list);int ma…

C++语言程序设计上机指导(二级),C++语言程序设计上机指导(二级)

第1章 上机基础1.1 考试大纲1.2 考纲提示1.3 考试要求1.4 题型和分值1.5 考试环境1.6 上机操作步骤1.6.1 启动1.6.2 登录1.6.3 考试开始1.6.4 交卷第2章 C语言基础2.1 C语言概述2.1.1 C语言的基本符号2.1.2 C语言的词汇2.1.3 C程序的基本框架2.2 数据类型、表达式和基本运算2.2…

6s在c语言中的用法,C语言中assert的用法讲解

assert是指编写代码时做出一些假设&#xff0c;断言就是用于在代码中捕捉这些假设&#xff0c;可以将断言看作是异常处理的一种高级形式。下面是小编为大家整理的C语言assert的用法讲解&#xff0c;欢迎参考~assert宏的原型定义在中&#xff0c;其作用是如果它的条件返回错误&a…

cmd c语言 图形,CMD-C彩图隐写方案

1.前言本文提出了当前经典的彩图隐写方案&#xff0c;它具有聚类修改方向的特点&#xff0c;是第一个公认的彩色图隐写方案&#xff0c;为后续彩图隐写术和隐写分析工作提供了清晰的思路&#xff0c;具有深远的意义。2.背景现代灰度图像隐写方案是在最小化失真函数框架下设计的…

android 闪存软件测试,手机为什么这么卡:闪存I/O测试AndroBench

手机为什么这么卡&#xff1a;闪存I/O测试AndroBench软件名称&#xff1a;Androbench软件版本&#xff1a;4.0.1软件大小&#xff1a;1.01MB软件授权&#xff1a;免费适用平台&#xff1a;Android很多朋友买手机只是为了日常使用&#xff0c;卡顿是最影响日常使用的心情的问题了…

android 文件并发读写,Android下,rxJava+retrofit 并发上传文件和串行上传文件的效率为什么差不多?...

有个功能需要同时上传N个文件。代码如下&#xff1a;ApiService as ApiManager.getApiService();final ExecutorService es Executors.newFixedThreadPool(9);final int count Bimp.tempSelectBitmap.size();final CountDownLatch finishedLatch new CountDownLatch(count)…