使用 scp命令免登陆

多台服务器之间互相拷贝文件一般常用scp命令但是让人困扰的是还要输入密码,

能不能不输入密码直接拷贝?

所幸方法是有的,ssh服务是支持免登陆的,不过需要密钥文件

方法如下:

[root@WebServer3 ~]# ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
a2:1d:43:32:26:06:68:48:d5:62:16:6d:a2:c7:53:8c root@WebServer3

输入命令后直接都按回车就行。

第一提示是密钥保存位置

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

直接回车保存到默认地方 /root/.ssh/id_rsa

第二个提示是输入一个不同于你的password的密码。直接按回车,不输入密码,保持密码为空。

其中公共密钥保存在 ~/.ssh/id_rsa.pub 
私有密钥保存在 ~/.ssh/id_rsa 


拷贝密钥文件到目标服务器

[root@WebServer3 ~]#scp ~/.ssh/id_rsa.pub 192.168.0.23:/root/.ssh/authorized_keys


配置完毕,你在这台机器上用scp ssh sftp 命令访问目标机器的时候就不用输入密码了


参考文档:http://www.chinaunix.net/old_jh/4/343905.html

<think> 首先,用户的问题是:“在linux中怎么使用命令登陆sftp”。我需要用中文回答这个问题。 关键点是:用户在Linux中使用命令登录SFTP。SFTP(Secure File Transfer Protocol)通常用于通过SSH安全地传输文件。 在Linux中,登录SFTP的命令使用`sftp`命令。基本语法是:`sftp username@hostname`。用户需要替换`username`为他们的用户名和`hostname`为服务器的主机名或IP地址。 例如:`sftp user@example.com` 回答时,我应该提供清晰的步骤: 1. 打开终端。 2. 输入命令`sftp username@hostname`。 3. 系统会提示输入密码(如果设置了SSH密钥,可能会自动登录)。 4. 一旦登录成功,就可以使用SFTP命令如`ls`、`cd`、`get`、`put`等。 现在,根据规则,我必须在回答完问题后提出3-5个§§相关问题§§。这些问题必须以“§§相关问题§§”开头,并且不能换行分散。意思是整个部分在一行中输出。 从示例中: - 回答部分(包括代码或解释)。 - 然后直接输出“§§相关问题§§”,后跟1. 2. 3. 等列表。 在我的回答中: - 先解释如何登录SFTP。 - 然后提供示例命令。 - 最后输出“§§相关问题§§”和问题列表。 提出的问题应该基于用户的问题和我的回答。用户的问题是“怎么使用命令登陆sftp”,所以我应该提出相关的问题,如: 1. 如何设置SSH密钥以无密码登录SFTP? 2. SFTP有哪些常用命令? 3. 如何从SFTP下载或上传文件? 4. SFTP和SCP有什么区别? 5. 如何在命令行中指定端口号(如果默认端口不是22)? 我需要确保有3-5个问题。 回答结构: - 用中文解释登录SFTP的步骤。 - 提供示例命令。 - 然后结束回答部分。 - 立即输出“§§相关问题§§”(必须完整输出这个字符串)。 - 接着是编号的问题列表,用数字点格式,如“1. ··· \n2. ···”等。 在输出时,不要换行分散“§§相关问题§§”,意思是它应该在一行上,后面直接跟问题列表。 现在,构建回答: 1. **解释部分**:简述如何使用命令登录SFTP。 例如:在Linux中,使用`sftp`命令登录SFTP服务器。基本格式是 `sftp username@hostname`。输入命令后,系统会提示输入密码。 2. **示例**:给出一个代码块或简单命令示例。示例中使用了Python代码块,但这里是命令命令,所以我可以直接用文本或代码块。 在示例格式中,他们有Python代码块。我可以使用类似的格式,但这里是Shell命令使用代码块来显示命令: ```bash sftp user@example.com ``` 3. **结束解释**。 4. **输出“§§相关问题§§”**。 5. **问题列表**:3-5个相关问题。 相关问题想法: 1. 如何使用SSH密钥免密码登录SFTP? 2. SFTP支持哪些文件操作命令? 3. 如何指定不同的端口号登录SFTP服务器? 4. SFTP与FTP有什么区别? 5. 如何在SFTP中递归下载目录? 确保问题数量在3-5个。我选4个。 最终回答结构: - 中文解释。 - 代码块(如果需要)。 - §§相关问题§§ - 1. 问题1 - 2. 问题2 - 3. 问题3 - 4. 问题4 </think> 在Linux中,使用命令行登录SFTP(Secure File Transfer Protocol)是通过`sftp`命令实现的,该命令基于SSH协议提供安全的文件传输。以下是详细步骤: 1. **打开终端**:在Linux系统上启动终端应用程序。 2. **输入登录命令**:使用`sftp`命令后跟用户名和服务器地址。基本语法为: ```bash sftp username@hostname ``` 其中,`username`是您在SFTP服务器上的用户名,`hostname`是服务器的IP地址或域名(例如`sftp user@192.168.1.100`或`sftp user@example.com`)。 3. **输入密码**:命令执行后,系统会提示输入该用户的密码(密码输入时不会显示)。如果设置了SSH密钥认证,则可能无需密码直接登录。 4. **验证登录**:成功登录后,终端会显示`sftp>`提示符,表示您已进入SFTP会话,可以使用如`ls`(列出文件)、`cd`(切换目录)、`get`(下载文件)和`put`(上传文件)等命令。 **注意事项**: - 默认使用SSH端口22。如果服务器使用不同端口,需添加`-P`选项(大写P),如`sftp -P 2222 username@hostname`。 - 确保服务器已启用SFTP服务,并且您有合法的访问权限。 - 如果连接失败,检查网络连接或服务器状态(例如使用`ping hostname`测试)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

炼丹狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值