Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1445744
  • 博文数量: 244
  • 博客积分: 3353
  • 博客等级: 中校
  • 技术积分: 3270
  • 用 户 组: 普通用户
  • 注册时间: 2011-11-09 17:56
文章分类

全部博文(244)

文章存档

2023年(7)

2022年(7)

2021年(4)

2020年(1)

2019年(2)

2017年(2)

2016年(3)

2015年(11)

2014年(20)

2013年(10)

2012年(176)

分类: 系统运维

2012-06-21 22:15:05

ssh自动登录

ssh-keygen -t rsa
ls /root/.ssh
scp /root/.ssh/id_rsa.pub serverB:/root/.ssh/authorized_keys
#!/bin/sh
#先执行如下过程进行自动登录设置
#
#ssh-keygen -t rsa
#ls /root/.ssh
#
#scp /root/.ssh/id_rsa.pub serverB:/root/.ssh/authorized_keys
#执行任务定制
#crontab-e
#增加
#*/1 * * * * sh /opt/jh_sync.sh
#
#
rsync -vzrtopg --rsh=ssh root@192.168.3.31:/usr/bj_app/news/$(date +%Y%m%d) /opt/abc
#
rsync -vzrtopg --rsh=ssh root@192.168.3.31:/usr/bj_app/news/$(date +%Y%m%d) /opt/news
rsync -vzrtopg --rsh=ssh root@192.168.3.31:/usr/bj_app/blockpics/$(date +%Y.%m.%d) /opt/blockpics
#

在客户端机器上通过下面命令生成个人的私钥和公钥 :

1.生成公钥

ssh-keygen -t rsa

2.将生成的公钥复制到远端linux

scp ~/.ssh/id_rsa.pub root@linux2:/root

3.远端linux上, 将复制过来的公钥生成授权key

cat id_rsa.pub >~/.ssh/authorized_keys

4.修改权限

chmod 600 ~/.ssh/authorized_keys

 


 

ssh自动登录脚本

  1. #!/bin/bash
  2. /usr/bin/expect <<\EOF
  3. set timeout 60
  4. set pwd "该机器的密码"
  5. spawn ssh 10.10.10.1
  6. expect {
  7. "\[#$\]" {send "\r" } ### 假如有了ssh 公钥之类的,直接回车。当然普通用户下边还可能需要sudo,自己处理一下吧。
  8. "not know" {send_user "[exec echo \"not know\"]";exit}
  9. "(yes/no)?" {send "yes\r";exp_continue} #continue的意义,靠猜测也能差不多知道了吧?可以Man expect
  10. "password:" {send "$pwd\r"}
  11. "Permission denied, please try again." {
  12. send_user "[exec echo \"Error:Password is wrong\"]"
  13. exit }
  14. }
  15. EOF
  16. exit

1. 自动ssh/scp方法==

A为本地主机(即用于控制其他主机的机器) ;
B为远程主机(即被控制的机器Server), 假如ip为192.168.60.110;
A和B的系统都是Linux

在A上运行命令:
# ssh-keygen -t rsa (连续三次回车,即在本地生成了公钥和私钥,不设置密码)
# ssh "mkdir .ssh" (需要输入密码)
# scp ~/.ssh/id_rsa.pub :.ssh/id_rsa.pub (需要输入密码)

在B上的命令:
# touch /root/.ssh/authorized_keys (如果已经存在这个文件, 跳过这条)
# cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys (将id_rsa.pub的内容追加到authorized_keys 中)

回到A机器:
# ssh (不需要密码, 登录成功)


2. 控制n个机器如上所述自动登录
那就需要n对钥匙(密钥和公钥), ssh-keygen 命令可以随意更改钥匙对的名字, 比如:
# ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsa_192.168.60.110

这样私钥和公钥的名字分别就是: id_rsa_192.168.60.110和 id_rsa_192.168.60.110.pub;然后将 id_rsa_192.168.60.110.pub 文件的内容, 追加到sever的 ~/.ssh/authorized_keys文件中,最后, 在本地用ssh命令的 -i 参数指定本地密钥, 并登录:
# ssh -i /root/.ssh/id_rsa_192.168.60.110

scp也是一样的
# scp -i /root/.ssh/id_rsa_192.168.60.110 filename :/home/someone

在文件.bashrc中加下两行,每次做同样的操作就不用敲入这样长的命令了:
alias sshcell='ssh -i /root/.ssh/id_rsa_192.168.60.110 '
alias scpcell='scp -i /root/.ssh/id_rsa_192.168.60.110 filename :/home/someone'

这样,直接键入一下指令实现ssh和scp自动登录:
# sshcell
# scpcell


3. 自动ssh/scp脚本
如果需要从A,到B,然后才能够到C,那么需要ssh和scp两次,是比较麻烦的。
ssh自动登录:
#!/usr/bin/expect -f
set timeout 30
spawn ssh weiqiong@B
expect "password:"
send "pppppp\r"
expect "]*"
send "ssh weiqiong@C\r"
expect "password:"
send "pppppp\r"
interact


scp从A拷贝文件到C:
#!/usr/bin/expect -f
set timeout 300
set file [lindex $argv 0]
spawn scp $file weiqiong@B:/home/weiqiong
expect "password:"
send "pppppp\r"
expect "]*"
spawn ssh weiqiong@B
expect "password:"
send "pppppp\r"
expect "]*"
send "scp $file weiqiong@C:/home/weiqiong\r"
expect "password:"
send "pppppp\r"
expect "]*"
exit
interact

scp从C拷贝文件到A:
#!/usr/bin/expect -f
set timeout 300
set file [lindex $argv 0]
spawn ssh weiqiong@B
expect "password:"
send "pppppp\r"
expect "]*"
send "scp weiqiong@C:/home/weiqiong/$file .\r"
expect "password:"
send "pppppp\r"
expect "]*"
send "exit\r"
expect "]*"
spawn scp weiqiong@B:/home/weiqiong/$file .
expect "password:"
send "pppppp\r"
interact

4. 建立ssh/scp通道
比如说我的机器是A,中间服务器为B,目标服务器是C

从A可以ssh到B,从B可以ssh到C,但是A不能直接ssh到C

现在展示利用ssh通道技术从A直接传输文件到C

1. ssh -L1234:C:22 userid@B

input B's password

(1234是本机A的空闲端口,该指令需要A机器上的root用户权限,实际上是在本机1234端口建立了一个通道)


2. 打开一个新的console,键入:

scp -P1234 filename userid@localhost:

input C's password
 
阅读(2485) | 评论(0) | 转发(0) |
0

上一篇:shell循环学习03

下一篇:自己的新浪博客

给主人留下些什么吧!~~