SSH密钥认证:实现远程服务器免密登录的两种方法|Linux scp命令详解:高效实现文件与目录的远程传输
发布时间 - 2025-07-20 00:00:00 点击率:次简介: 服务器之间经常需要有一些跨服务器的操作,此时就需要我们在一台服务器上登录到另外一台服务器,若是人为操作时我们都可以每次输入密码进行远程登录,但要是程序需要跨服务器时,每次输入密码就不现实了,所以我们需要免密登录
服务器之间经常需要有一些跨服务器的操作,此时就需要我们在一台服务器上登录到另外一台服务器,若是人为操作时我们都可以每次输入密码进行远程登录,但要是程序需要跨服务器时,每次输入密码就不现实了,所以我们需要免密登录
SSH远程登录1.1 .ssh远程登录操作这里先看看正常使用 ssh 连接]其他服务器的操作。准备了两台服务器 ip 分别为:192.168.150.175、192.168.150.148。这里使用 175 登录 148。
先 ping 测试下看看网络是否通畅可以看到网络正常,可以 ping 通
然后操作 ssh 开始登录,此时就需要我们输入密码了,这个密码就是我们服务器 root 的密码了。
注意:若是第一次登录这台服务器会弹出一个问题:问你是否需要继续连接此服务器,输入 yes 即可。
正常输入密码后即可实现 ssh 登录了。
ssh 登录这样就算 ok 了,但其实我们还是比较关心如何免密进行 ssh 登录。
1.2.ssh免密登录方式一其实很简单,只需要三步即可:
生成公钥、私钥代码语言:javascript代码运行次数:0运行复制ssh-keygen
执行该命令然后对于弹出提示直接三次回车即可。这个命令本质上就是生成公钥和私钥的。我们也无需为他们制定特殊的存放位置回车就是都用默认的即可。通过下面的图可以看出,公钥在 / root/.ssh/id_rsa.pub,私钥在 / root/.ssh/id_rsa
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. 生成本机的公钥私钥
代码语言:javascript代码运行次数:0运行复制ssh-keygen
这个与方式一里面的的第一步没有任何区别,执行下面的命令三次回车即可
打开本地公钥文件复制公钥信息代码语言:javascript代码运行次数:0运行复制vim /root/.ssh/id_rsa.pub# 复制公钥信息,下面是笔者的公钥信息ssh-rsa AAAAB3xxxxx2mz3zEOo39w03RjzFWIhqbxxxxxxxxxxxxxxxxxx root@bogon将公钥存放到目标服务器的这个文件里:/root/.ssh/authorized_keys
什么?没有这个文件,那就在本地执行下下面这个命令
代码语言:javascript代码运行次数:0运行复制ssh localhost
这样本地就会产生这个文件了,然后我们将 2 里面拿到的公钥存放进来即可,注意若是该文件不为空,就换行新增本次的公钥就行,不要去覆盖别的公钥,不然会造成其他服务器登录这台服务器时免密失败。
测试免密登录其实两种方式本质上没有区别,都是将公钥放到目标服务器上即可,一种采用 scp 的方式,一种是直接登录服务器放到对应文件里即可。
scp [-1241246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file][-l limit] [-o ssh_option] [-P port] [-S program][[user@]host1:]file1 [...] [[user@]host2:]file2
简易写法:
代码语言:javascript代码运行次数:0运行复制scp [可选参数] file_source file_target
参数说明:
-1: 强制 scp 命令使用协议 ssh1-2: 强制 scp 命令使用协议 ssh2-4: 强制 scp 命令只使用 IPv4 寻址-6: 强制 scp 命令只使用 IPv6 寻址-B: 使用批处理模式(传输过程中不询问传输口令或短语)-C: 允许压缩。(将 - C 标志传递给 ssh,从而打开压缩功能)-p:保留原文件的修改时间,访问时间和访问权限。-q: 不显示传输进度条。-r: 递归复制整个目录。-v:详细方式显示输出。scp 和 ssh(1) 会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。-c cipher: 以 cipher 将数据传输进行加密,这个选项将直接传递给 ssh。-F ssh_config: 指定一个替代的 ssh 配置文件,此参数直接传递给 ssh。-i identity_file: 从指定文件中读取传输时使用的密钥文件,此参数直接传递给 ssh。-l limit: 限定用户所能使用的带宽,以
Kbit/s 为单位。-o ssh_option: 如果习惯于使用 ssh_config(5) 中的参数传递方式,-P port:注意是大写的 P, port 是指定数据传输用到的端口号-S program: 指定加密传输时所使用的程序。此程序必须能够理解 ssh(1) 的选项。2.2 实例2.2.1、从本地复制到远程命令格式:
代码语言:javascript代码运行次数:0运行复制scp local_file remote_username@remote_ip:remote_folder 或者 scp local_file remote_username@remote_ip:remote_file 或者 scp local_file remote_ip:remote_folder 或者 scp local_file remote_ip:remote_file第 1,2 个指定了用户名,命令执行后需要再输入密码,第 1 个仅指定了远程的目录,文件名字不变,第 2 个指定了文件名;第 3,4 个没有指定用户名,命令执行后需要输入用户名和密码,第 3 个仅指定了远程的目录,文件名字不变,第 4 个指定了文件名;
应用实例:
scp /home/space/music/1.mp3 root@ip地址:/home/root/others/music scp /home/space/music/1.mp3 root@10.80.1.253:/home/root/others/music/001.mp3 scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music/001.mp3
复制目录命令格式:
scp -r local_folder remote_username@remote_ip:remote_folder 或者 scp -r local_folder remote_ip:remote_folder第 1 个指定了用户名,命令执行后需要再输入密码;第 2 个没有指定用户名,命令执行后需要输入用户名和密码;
应用实例:
代码语言:javascript代码运行次数:0运行复制scp -r /home/space/music/ root@www.runoob.com:/home/root/others/ scp -r /home/space/music/ www.runoob.com:/home/root/others/
上面命令将本地 music 目录复制到远程 others 目录下。
代码语言:javascript代码运行次数:0运行复制#进入 对应目录scp -r mnt root@10.80.1.252:/www/algorithm/old_code2.2.2、从远程复制到本地
从远程复制到本地,只要将从本地复制到远程的命令的后 2 个参数调换顺序即可,如下实例
应用实例:
代码语言:javascript代码运行次数:0运行复制scp root@www.runoob.com:/home/root/others/music /home/space/music/1.mp3 scp -r www.runoob.com:/home/root/others/ /home/space/music/2.3 说明如果远程服务器防火墙有为 scp 命令设置了指定的端口,我们需要使用 -P 参数来设置命令的端口号,命令格式如下:代码语言:javascript代码运行次数:0运行复制
#scp 命令使用端口号 4588scp -P 4588 remote@www.runoob.com:/usr/local/sin.sh /home/administrator使用 scp 命令要确保使用的用户具有可读取远程服务器相应文件的权限,否则 scp 命令是无法起作用的。参考链接 https://www.runoob.com/linux/linux-comm-scp.htmlhttps://developer.aliyun.com/article/1132156#slide-7
# linux
# 区别
# JavaScript
# 递归
# copy
# https
# ssh
# 在这里
# 公钥
# 输入密码
# 插入图片
# 一台
# 时就
# 就会
# 远程登录
# 就不
# 端口号
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】
,在苏州找工作,上哪个网站比较好?
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
Laravel怎么判断请求类型_Laravel Request isMethod用法
使用豆包 AI 辅助进行简单网页 HTML 结构设计
Bootstrap整体框架之JavaScript插件架构
phpredis提高消息队列的实时性方法(推荐)
三星网站视频制作教程下载,三星w23网页如何全屏?
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
Laravel如何使用Blade组件和插槽?(Component代码示例)
详解vue.js组件化开发实践
如何制作一个表白网站视频,关于勇敢表白的小标题?
php打包exe后无法访问网络共享_共享权限设置方法【教程】
javascript基于原型链的继承及call和apply函数用法分析
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
Laravel如何创建自定义Artisan命令?(代码示例)
google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤
Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧
中山网站制作网页,中山新生登记系统登记流程?
如何在阿里云ECS服务器部署织梦CMS网站?
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
佛山网站制作系统,佛山企业变更地址网上办理步骤?
Laravel如何实现一对一模型关联?(Eloquent示例)
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
Laravel如何实现API版本控制_Laravel版本化API设计方案
详解阿里云nginx服务器多站点的配置
jQuery 常见小例汇总
Laravel怎么实现验证码(Captcha)功能
网站制作价目表怎么做,珍爱网婚介费用多少?
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
C++时间戳转换成日期时间的步骤和示例代码
如何用狗爹虚拟主机快速搭建网站?
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
黑客如何利用漏洞与弱口令入侵网站服务器?
如何在搬瓦工VPS快速搭建网站?
中山网站推广排名,中山信息港登录入口?
Laravel如何实现文件上传和存储?(本地与S3配置)
Laravel怎么调用外部API_Laravel Http Client客户端使用
如何在企业微信快速生成手机电脑官网?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
Linux网络带宽限制_tc配置实践解析【教程】
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
WEB开发之注册页面验证码倒计时代码的实现

