ToB企服应用市场:ToB评测及商务社交产业平台

标题: SSH密钥认证:实现远程服务器免密登录的两种方法|Linux scp命令详解:高效 [打印本页]

作者: 愛在花開的季節    时间: 2024-7-25 23:50
标题: SSH密钥认证:实现远程服务器免密登录的两种方法|Linux scp命令详解:高效
简介: 服务器之间常常需要有一些跨服务器的利用,此时就需要我们在一台服务器上登录到别的一台服务器,若是人为利用时我们都可以每次输入密码进行远程登录,但要是程序需要跨服务器时,每次输入密码就不现实了,以是我们需要免密登录
服务器之间常常需要有一些跨服务器的利用,此时就需要我们在一台服务器上登录到别的一台服务器,若是人为利用时我们都可以每次输入密码进行远程登录,但要是程序需要跨服务器时,每次输入密码就不现实了,以是我们需要免密登录
SSH远程登录

1.1 .ssh远程登录利用

这里先看看正常使用 ssh 毗连]其他服务器的利用。预备了两台服务器 ip 分别为:192.168.150.175、192.168.150.148。这里使用 175 登录 148。
可以看到网络正常,可以 ping 通

然后利用 ssh 开始登录,此时就需要我们输入密码了,这个密码就是我们服务器 root 的密码了。
注意:若是第一次登录这台服务器会弹出一个问题:问你是否需要继续毗连此服务器,输入 yes 即可。

正常输入密码后即可实现 ssh 登录了。
ssh 登录这样就算 ok 了,但其实我们还是比较关心怎样免密进行 ssh 登录。
1.2.ssh免密登录方式一

其实很简单,只需要三步即可:
  1. ssh-keygen
复制代码
实行该命令然后对于弹出提示直接三次回车即可。这个命令本质上就是生成公钥和私钥的。我们也无需为他们订定特殊的存放位置回车就是都用默认的即可。通过下面的图可以看出,公钥在 / root/.ssh/id_rsa.pub,私钥在 / root/.ssh/id_rsa


  1. ssh-copy-id -i /root/.ssh/id_rsa.pub root@192.168.150.148
复制代码
使用这个命令可以把本机的公钥 copy 到 192.168.150.148 上,命令有点类似 scp,以是这里也是需要输入密码的


如下图我们可以看到,无需输入密码,直接 ssh 就成功了

认真看过第二种方式就会知道,第二种方式必须要知道服务器的密码,而且还是 root 密码,这个在工作中可能有点难度,以是我们真正使用这个方式比较靠谱吧。
1.3.ssh免密登录方式二(推荐)

1. 生成本机的公钥私钥
  1. ssh-keygen
复制代码
这个与方式一内里的的第一步没有任何区别,实行下面的命令三次回车即可
  1. vim /root/.ssh/id_rsa.pub
  2. # 复制公钥信息,下面是笔者的公钥信息
  3. ssh-rsa AAAAB3xxxxx2mz3zEOo39w03RjzFWIhqbxxxxxxxxxxxxxxxxxx root@bogon
复制代码

什么?没有这个文件,那就在当地实行下下面这个命令
  1. ssh localhost
复制代码
这样当地就会产生这个文件了,然后我们将 2 内里拿到的公钥存放进来即可,注意若是该文件不为空,就换行新增本次的公钥就行,不要去覆盖别的公钥,否则会造成其他服务器登录这台服务器时免密失败。

其实两种方式本质上没有区别,都是将公钥放到目的服务器上即可,一种接纳 scp 的方式,一种是直接登录服务器放到对应文件里即可。

2. Linux scp命令实现文件互传


2.1 语法

  1. scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
  2. [-l limit] [-o ssh_option] [-P port] [-S program]
  3. [[user@]host1:]file1 [...] [[user@]host2:]file2
复制代码
简易写法:
  1. scp [可选参数] file_source file_target
复制代码
参数说明:

2.2 实例

2.2.1、从当地复制到远程

命令格式:
  1. scp local_file remote_username@remote_ip:remote_folder
  2. 或者
  3. scp local_file remote_username@remote_ip:remote_file
  4. 或者
  5. scp local_file remote_ip:remote_folder
  6. 或者
  7. scp local_file remote_ip:remote_file
复制代码
  root@目的服务器ip
  
应用实例:
  1. scp /home/space/music/1.mp3 root@ip地址:/home/root/others/music
  2. scp /home/space/music/1.mp3 root@10.80.1.253:/home/root/others/music/001.mp3
  3. scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music
  4. scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music/001.mp3
复制代码


复制目次命令格式:
  1. scp -r local_folder remote_username@remote_ip:remote_folder
  2. 或者
  3. scp -r local_folder remote_ip:remote_folder
复制代码

应用实例:
  1. scp -r /home/space/music/ root@www.runoob.com:/home/root/others/
  2. scp -r /home/space/music/ www.runoob.com:/home/root/others/
复制代码
上面命令将当地 music 目次复制到远程 others 目次下。
  1. #进入 对应目录
  2. scp -r mnt root@10.80.1.252:/www/algorithm/old_code
复制代码
2.2.2、从远程复制到当地

从远程复制到当地,只要将从当地复制到远程的命令的后 2 个参数调换次序即可,如下实例
应用实例:
  1. scp root@www.runoob.com:/home/root/others/music /home/space/music/1.mp3
  2. scp -r www.runoob.com:/home/root/others/ /home/space/music/
复制代码
2.3 说明

  1. #scp 命令使用端口号 4588
  2. scp -P 4588 remote@www.runoob.com:/usr/local/sin.sh /home/administrator
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4