当前位置: 首页 > news >正文

上位机知识篇---SSHSCP密钥与密钥对


文章目录

  • 前言
  • 第一部分:SCP(Secure Copy Protocol)
    • 功能
    • 使用方法
      • 1.从本地复制到远程主机
      • 2.从远程主机复制到本地
      • 3.复制整个目录
      • 4.指定端口
      • 5.压缩传输
  • 第二部分:SSH(Secure Shell)
    • 功能
    • 使用方法
      • 1.远程登录
      • 2.指定端口
      • 3.执行远程命令
      • 4.使用密钥认证
      • 5.SSH配置文件
      • 6.端口转发
  • scp\ssh总结
  • 第三部分:密钥与密钥对
    • 基本概念
      • 1.密钥(Key)
      • 2.密钥对(Key Pair)
      • 3.生成密钥对
        • 生成RSA密钥对
        • 生成ED25519密钥对
      • 4.密钥对存储
        • 生成的文件
        • 设置密钥密码
      • 5.使用密钥对
      • 6.使用密钥登录远程主机
      • 7.SSH配置文件简化登录
      • 8.使用密钥进行Git操作
      • 9.使用SSH协议克隆仓库
      • 10.密钥管理
        • 备份密钥对
        • 更改密钥密码
        • 删除或替换密钥对:
  • 密钥、密钥对总结
  • 总结


前言

以上就是今天要讲的内容,本文仅仅简单介绍了SCP、SSH、密钥、密钥对。


第一部分:SCP(Secure Copy Protocol)

功能

SCP(Secure Copy Protocol)是一种基于SSH协议的文件传输工具,用于在本地和远程主机之间安全地复制文件。它利用SSH的加密机制,确保数据传输的安全性。

使用方法

1.从本地复制到远程主机

scp /path/to/local/file username@remote_host:/path/to/remote/directory

/path/to/local/file:本地文件路径。
username@remote_host:远程主机的用户名和地址。
/path/to/remote/directory:远程主机上的目标目录。

2.从远程主机复制到本地

scp username@remote_host:/path/to/remote/file /path/to/local/directory

username@remote_host:/path/to/remote/file:远程主机上的文件路径。
/path/to/local/directory:本地目标目录。

3.复制整个目录

使用 -r 选项递归复制目录:

scp -r /path/to/local/directory username@remote_host:/path/to/remote/directory

4.指定端口

如果SSH服务使用非默认端口(默认22),使用 -P 选项指定端口:

scp -P 2222 /path/to/local/file username@remote_host:/path/to/remote/directory

5.压缩传输

使用 -C 选项启用压缩,加快传输速度:

scp -C /path/to/local/file username@remote_host:/path/to/remote/directory

第二部分:SSH(Secure Shell)

功能

SSH(Secure Shell)是一种加密网络协议,用于安全地访问和管理远程主机。它提供加密的通信通道,支持远程登录、命令执行和文件传输。

使用方法

1.远程登录

ssh username@remote_host

username:远程主机的用户名。
remote_host:远程主机的地址。

2.指定端口

如果SSH服务使用非默认端口,使用 -p 选项指定端口

ssh -p 2222 username@remote_host

3.执行远程命令

可以在登录时直接执行命令:

ssh username@remote_host "command"

例如:

ssh username@remote_host "ls -l /path/to/directory"

4.使用密钥认证

使用SSH密钥对进行认证,避免每次输入密码

生成密钥对:

ssh-keygen -t rsa -b 4096

将公钥复制到远程主机:

ssh-copy-id username@remote_host

使用密钥登录:

ssh -i /path/to/private/key username@remote_host

5.SSH配置文件

使用 ~/.ssh/config 文件简化连接:
Host myserver
HostName remote_host
User username
Port 2222
IdentityFile /path/to/private/key
然后可以通过别名连接:

ssh myserver

6.端口转发

本地端口转发:

ssh -L local_port:remote_host:remote_port username@remote_host

远程端口转发:

ssh -R remote_port:local_host:local_port username@remote_host

scp\ssh总结

SCP:用于安全地复制文件,支持目录和压缩传输
SSH:用于安全地远程登录和执行命令,支持端口转发和密钥认证
两者都基于SSH协议,确保数据传输的安全性。

第三部分:密钥与密钥对

基本概念

1.密钥(Key)

密钥是用于加密和解密数据的字符串,分为公钥和私钥

公钥(Public Key):可以公开,用于加密数据或验证签名
私钥(Private Key):必须保密,用于解密数据或生成签名

2.密钥对(Key Pair)

密钥对由公钥和私钥组成,通常用于非对称加密
公钥和私钥在数学上相关,但无法从公钥推导出私钥。

3.生成密钥对

使用 ssh-keygen 生成密钥对:
ssh-keygen 是生成SSH密钥对的常用工具。

生成RSA密钥对
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

-t rsa:指定密钥类型为RSA
-b 4096:指定密钥长度为4096位
-C “your_email@example.com”:添加注释,通常为邮箱

生成ED25519密钥对
ssh-keygen -t ed25519 -C "your_email@example.com"

-t ed25519:指定密钥类型为ED25519。

4.密钥对存储

生成过程中会提示输入存储路径和文件名,默认路径为 **~/.ssh/id_rsa(RSA)**或 ~/.ssh/id_ed25519(ED25519)

生成的文件

id_rsa 或 id_ed25519:私钥文件
id_rsa.pub 或 id_ed25519.pub:公钥文件

设置密钥密码

生成过程中会提示设置密钥密码(passphrase),增加安全性。
每次使用密钥时需输入密码。

5.使用密钥对

将公钥添加到远程主机:

使用 ssh-copy-id 将公钥复制到远程主机~/.ssh/authorized_keys 文件中:

ssh-copy-id -i ~/.ssh/id_rsa.pub username@remote_host

手动复制公钥:
复制公钥内容:

cat ~/.ssh/id_rsa.pub

将内容粘贴到远程主机的 ~/.ssh/authorized_keys 文件中。

6.使用密钥登录远程主机

使用私钥进行SSH登录:

ssh -i ~/.ssh/id_rsa username@remote_host

如果私钥文件为默认路径(~/.ssh/id_rsa 或 ~/.ssh/id_ed25519),可省略 -i 选项:

ssh username@remote_host

7.SSH配置文件简化登录

编辑 ~/.ssh/config 文件,添加以下内容:

Host myserver
HostName remote_host
User username
IdentityFile ~/.ssh/id_rsa

然后使用别名登录:

ssh myserver

8.使用密钥进行Git操作

将**公钥添加到Git服务(如GitHub、GitLab)**的SSH密钥设置中。

9.使用SSH协议克隆仓库

git clone git@github.com:username/repository.git

10.密钥管理

备份密钥对

~/.ssh 目录下的私钥和公钥文件备份到安全位置。

更改密钥密码

使用 ssh-keygen 更改密钥密码:

ssh-keygen -p -f ~/.ssh/id_rsa
删除或替换密钥对:

删除旧的密钥文件生成新的密钥对
更新远程主机和Git服务中的公钥

密钥、密钥对总结

  1. 密钥对:由公钥和私钥组成,用于非对称加密
  2. 生成密钥对:使用 ssh-keygen 生成RSA或ED25519密钥对
  3. 使用密钥对:将公钥添加到远程主机,使用私钥进行SSH登录或Git操作。
  4. 密钥管理:备份、更改密码、删除或替换密钥对。
  5. 通过密钥对认证,可以提高安全性并简化远程登录和文件传输操作

总结

以上就是今天要讲的内容,本文仅仅简单介绍了SCP、SSH、密钥、密钥对。

相关文章:

上位机知识篇---SSHSCP密钥与密钥对

文章目录 前言第一部分:SCP(Secure Copy Protocol)功能使用方法1.从本地复制到远程主机2.从远程主机复制到本地3.复制整个目录4.指定端口5.压缩传输 第二部分:SSH(Secure Shell)功能使用方法1.远程登录2.指…...

智慧物流新引擎:ARM架构工控机在自动化生产线中的应用

工业自动化程度的不断提升,对高性能、低功耗和高可靠性的计算设备需求日益增长。ARM架构工控机因其独特的优势,在多个工业领域得到了广泛应用。本文将深入探讨ARM架构工控机的特点及其在具体工业场景中的应用。 ARM架构工控机的主要优势 高效能与低功耗…...

[MySQL]2-MySQL索引

目录 1.索引🌟 1.1索引结构 B树 B树 聚簇索引(一级索引)与非聚簇索引(二级索引) 回表操作 1.2索引碎片 清理索引碎片的方法 1.3索引匹配方式🌟 在数据列上使用函数或者计算会导致索引失效的原因 …...

DeepSeek冲击下,奥特曼刚刚给出对AGI的「三个观察」,包括成本速降

来源 | 机器之心 今天凌晨,OpenAI CEO 再次发布长文,重申自己对于 AGI 的三个观察。 核心观点如下: 1. 人工智能模型的智能大致等于用于训练和运行该模型的资源的对数。 2. 使用一定水平的人工智能的成本每 12 个月就会下降约 10 倍&#x…...

新数据结构(8)——包装类

基本数据类型(轻点) Java基本数据类型在内存中占用固定的大小,并且直接存储值,而不是对象的引用 整数类型 byte:8位,存储范围从-128到127 short:16位,存储范围从-32,768到32,767 …...

P5:使用pytorch实现运动鞋识别

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 我的环境 语言环境:python 3.7.12 编译器:pycharm 深度学习环境:tensorflow 2.7.0 数据:本地数据集-运动鞋 一…...

讲解下SpringBoot中MySql和MongoDB的配合使用

在Spring Boot中,MySQL和MongoDB可以配合使用,以充分发挥关系型数据库和非关系型数据库的优势。MySQL适合处理结构化数据,而MongoDB适合处理非结构化或半结构化数据。以下是如何在Spring Boot中同时使用MySQL和MongoDB的详细讲解。 1. 添加依…...

《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API在化工行业的双向对接方案

一、项目背景 化工行业生产过程复杂,设备运行条件恶劣,对设备状态监测、生产数据采集和质量控制的要求极高。通过开源Odoo MES系统与SKF Observer Phoenix API的双向对接,可以实现设备状态的实时监测、生产数据的自动化采集以及质量数据的同步…...

数据结构与算法之数组: LeetCode 905. 按奇偶排序数组 (Ts版)

按奇偶排序数组 https://leetcode.cn/problems/sort-array-by-parity/description/ 描述 给你一个整数数组 nums,将 nums 中的的所有偶数元素移动到数组的前面,后跟所有奇数元素。 返回满足此条件的 任一数组 作为答案。 示例 1 输入:n…...

【STM32】HAL库Host MSC读写外部U盘及FatFS文件系统的USB Disk模式

【STM32】HAL库Host MSC读写外部U盘及FatFS文件系统的USB Disk模式 在先前 分别介绍了FatFS文件系统和USB虚拟U盘MSC配置 前者通过MCU读写Flash建立文件系统 后者通过MSC连接电脑使其能够被操作 这两者可以合起来 就能够实现同时在MCU、USB中操作Flash的文件系统 【STM32】通过…...

docker nginx 配置文件详解

在平常的开发工作中,我们经常需要访问静态资源(图片、HTML页面等)、访问文件目录、部署项目时进行负载均衡等。那么我们就会使用到Nginx,nginx.conf 的配置至关重要。那么今天主要结合访问静态资源、负载均衡等总结下 nginx.conf …...

如何实现华为云+deepseek?

在华为云上实现跨账号迁移数据或部署DeepSeek模型,可以通过以下步骤完成: 跨账号数据迁移 创建委托:在源账号中创建一个委托(Agency),授予目标账号访问数据的权限。 复制镜像:在源账号中&…...

【学习笔记】计算机网络(三)

第3章 数据链路层 文章目录 第3章 数据链路层3.1数据链路层的几个共同问题3.1.1 数据链路和帧3.1.2 三个基本功能3.1.3 其他功能 - 滑动窗口机制 3.2 点对点协议PPP(Point-to-Point Protocol)3.2.1 PPP 协议的特点3.2.2 PPP协议的帧格式3.2.3 PPP 协议的工作状态 3.3 使用广播信…...

稀土抑烟剂——为汽车火灾安全增添防线

一、稀土抑烟剂的基本概念 稀土抑烟剂是一类基于稀土元素(如稀土氧化物和稀土金属化合物)开发的高效阻燃材料。它可以显著提高汽车内饰材料的阻燃性能,减少火灾发生时有毒气体和烟雾的产生。稀土抑烟剂不仅能提升火灾时的安全性,…...

Qt Pro、Pri、Prf

一、概述 1、在Qt中,通常使用.pro(project)、pri(private include)、prf(project file)三种文件扩展名来组织项目。对于模块化编程,Qt提供了Pro和Pri,Pro管理项目,Pri管理模块。 2、pro文件是Qt项目的核心文件,包含了…...

基于AIOHTTP、Websocket和Vue3一步步实现web部署平台,无延迟控制台输出,接近原生SSH连接

背景:笔者是一名Javaer,但是最近因为某些原因迷上了Python和它的Asyncio,至于什么原因?请往下看。在着迷”犯浑“的过程中,也接触到了一些高并发高性能的组件,通过简单的学习和了解,aiohttp这个…...

如何在MacOS上查看edge/chrome的扩展源码

步骤 进入管理扩展页面点击详细信息复制对应id在命令行键入 open ~/Library/Application Support/Microsoft Edge/Default/Extensions/${你刚刚复制的id} 即可打开访达中对应的更目录 注意 由于原生命令行无法直接处理空格 ,所以需要加转义符\,即:open ~/Librar…...

【xdoj-离散线上练习H】T234(C++)

解题心得: 写递归函数的时候,首先写终止条件,这有助于对整个递归函数的把握。 题目:输入集合A和B,输出A到B上的所有函数。 问题描述 给定非空数字集合A和B,求出集合A到集合B上的所有函数。 输入格式 第一行…...

Docker Desktop Windows 安装

一、先下载Docker desktop WIndows 下载地址 二、安装 安装超简单 一路 下一步 三、安装之后,桌面会出现一个 小蓝鲸图标,打开它 》更新至最新版本,不然小蓝鲸打开,一会就退出了。 》wsl --update (这个有时比较慢…...

springCloud-2021.0.9 之 GateWay 示例

文章目录 前言springCloud-2021.0.9 之 GateWay 示例1. GateWay 官网2. GateWay 三个关键名称3. GateWay 工作原理的高级概述4. 示例4.1. POM4.2. 启动类4.3. 过滤器4.4. 配置 5. 启动/测试 前言 如果您觉得有用的话,记得给博主点个赞,评论,收…...

AI 驱动单元测试生成:智能优先级与自动化验证实践

1. 项目概述如果你和我一样,长期在维护一个中大型的 TypeScript 项目,那么“补单元测试”这件事,大概率是你技术债清单上那个永远在滚动、却很少被真正划掉的任务。手动写测试枯燥耗时,尤其是面对那些遗留的、逻辑复杂的业务函数时…...

Claude Code / Cursor 写的代码,你敢直接上线吗?我踩过一次坑,再也不敢

👉 这是一个或许对你有用的社群🐱 一对一交流/面试小册/简历优化/求职解惑,欢迎加入「芋道快速开发平台」知识星球。下面是星球提供的部分资料: 《项目实战(视频)》:从书中学,往事上…...

用100道题拿下你的算法面试(链表篇-7):复制带随机指针的链表

一、面试问题 给定一个链表的头节点,链表中每个节点都包含两个指针:一个指向下一个节点的 next 指针,以及一个指向链表中任意节点的 random 指针。请复制该链表,并返回新链表的头节点。 二、【朴素解法】使用哈希表 —— 时间复杂…...

VSCode调试C++项目全攻略:从CMake工程配置到Native Debug实战(含传参技巧)

VSCode调试C项目全攻略:从CMake工程配置到Native Debug实战(含传参技巧) 在当今的C开发环境中,高效调试已成为提升生产力的关键环节。对于使用CMake管理的中大型项目,如何在VSCode中实现无缝调试体验,是许多…...

硬件相关项目内容介绍(硬件咱们也有相关技术支持内容哦)

硬件相关项目内容介绍(硬件咱们也有相关技术支持内容哦) 硬件咱们也有相关技术支持内容哦。 主要看大家喜欢什么,硬件内容咱们会不定期更新分享,大家要是喜欢,后续就安排上实物实操。也虚心听取大家建议,不…...

2026盘古石取证初赛(APK取证)

APK取证1.分析方俊朗phone.E01检材,筛选优质客户应用将用户查询记录存储在一个加密的本地数据库中。请问该加密数据库的文件名是什么?[答案格式:12_abc.db]题目说了这边是筛选优质客户,其实和手机取证最后一题一样的,先…...

别再被FFmpeg里的12bpp搞懵了!手把手教你理解YUV420sp与BPP的关系

别再被FFmpeg里的12bpp搞懵了!手把手教你理解YUV420sp与BPP的关系 第一次在FFmpeg文档里看到"12bpp"这个描述时,我盯着屏幕愣了半天——RGB24格式不是8bpp吗?YUV420不是应该更节省空间吗?怎么反而变成了12bpp&#xff1…...

Python蒙特卡洛树搜索实战:手把手教你调参,让黑白棋AI从‘菜鸟’变‘高手’

Python蒙特卡洛树搜索实战:从调参到策略优化的完整指南 蒙特卡洛树搜索(MCTS)作为近年来最成功的游戏AI算法之一,已经在围棋、黑白棋等策略游戏中展现出惊人的实力。但很多开发者在实现基础版本后,常常陷入性能瓶颈——…...

手把手教你ClickHouse(二、Windows下Docker部署与可视化实战)

1. Windows下Docker环境准备 在开始部署ClickHouse之前,我们需要先确保Windows系统已经正确配置Docker环境。这里我推荐使用Docker Desktop for Windows,它提供了图形化界面和完整的容器管理功能。安装过程可能会遇到几个常见坑点,我把自己实…...

上午题_程序设计语言

编译程序和解释程序...