Chinaunix首页 | 论坛 | 博客
  • 博客访问: 451672
  • 博文数量: 96
  • 博客积分: 4130
  • 博客等级: 上校
  • 技术积分: 1149
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-11 12:32
文章分类

全部博文(96)

文章存档

2011年(19)

2010年(75)

2009年(1)

2008年(1)

我的朋友

分类: LINUX

2010-12-05 00:03:35

SCP命令是在linux中用来跨服务器拷贝文件的常用工具,用法非常简单;如下:

scp -options [[user@]host1:]file1 [[user@]host2:]file2

options里面我们一般用得很少,主要用-v来查看命令执行过程中的详细信息,这在复制失败时差错非常有用;

另外一个常用option就是-r,用以深度复制,包括子目录下面的所有目录和文件;

上面的语法可以灵活使用,他可以在host1和host2之间互相copy,而不仅限于从host1中copy文件到host2;

该命令虽然好用,但是由于采用的是ssh协议来对传输内容进行加密,而且在访问另外服务器时需要手工输入密码;下面我们就介绍一种方法来避免每次都输入密码,也即我们常说的服务期间打通通道

1、用命令ssh-keygen -t rsa在serverA中生成密钥对,-t rsa表示采用RSA算法来生成密钥对,也可以用DSA算法来生成,支持的算法集可以参考openssh的文档;至于ssh-keygen的详细命令参数这里不做详细介绍,有兴趣的可以参考man或help;

生成的密钥对默认存放在~/.ssh/目录中,id_rsa.pub中存放公钥,id_rsa存放私钥;

注意:在生成密钥对的时候系统会提示输入密钥对的密码,这里请直接回车,不要输入密码,否则后面打通通道之后仍然需要密码,只不过是用这里设置的密码而已;

2、将id_rsa.pub中的公钥拷贝出来,追加到serverB中的~/.ssh/authorized_keys文件中;

这样就大功告成啦,以后从serverA到serverB就无需每次输入密码了,基于ssh协议的ssh、scp、sftp等命令均会受益;

PS:中间过程中可能需要设置.ssh目录下面的各文件的权限,视具体情况而定;

from:http://blog.csdn.net/sfdev/archive/2009/03/26/4025952.aspx

阅读(572) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~