Linux的SSH基于公私钥验证的方式登录

2024-02-07 15:38

本文主要是介绍Linux的SSH基于公私钥验证的方式登录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

SSH是Linux下用于建立安全连接的一种技术,通过一对密钥对(包含公钥和私钥),通过签名验签方式校验,完成身份验证过程。详细原理请查看文章后面的参考文档,那位大佬写的很清晰,这篇文章主要是有一些基础,以及个人理解。

基础
  • 相关文件介绍
    如下图所示用户的Home目录下会有一个名为.ssh的目录,这里存放了指定用户的SSH相关文件,例如用户为root,如下所示。
    在这里插入图片描述

authorized_keys:本机器的该用户例如root)授权允许连接的客户端机器(即要允许登录连接本机的机器),例如本机器为A,要连接A的机器是B,B需要在A机器的authorized_keys里,否则会要求输入用户名和密码进行授权,才可以直接通过SSH建立连接。主要目的就是防止公钥泄漏了,别人在其他机器使用这个公钥来登录,这时候它不在这个列表里,那么就会直接拒绝,提示需要密码登录验证。
id_rsa:本机器的该用户(例如root)的私钥
id_rsa.pub:本机器的该用户(例如root)的公钥,一般提供给需要SSH连接本机器的客户端机器,客户端机器保存到对方的authorized_keys文件里,下次就用公钥直接SSH连接上了,不需要密码了。
known_hosts:本机器的该用户(例如root)通过SSH连接过的远程主机列表,这里记录的自身连接别人的机器的列表,记录了远程机器的IP和公钥。

  • 登录原理
    举个场景,A机器需要通过SSH免密(前提是私钥没有设置密码哈哈哈,讲真不推荐…)登录B机器,那需要怎么做了?

1.A机器产生一对密钥对(ssh-keygen命令),私钥文件:id_rsa,公钥文件:id_rsa.pub
2.A机器将公钥文件(id_rsa.pub)发给它要登录的B机器(可以通过ssh-copy-id命令),B机器会把这个A机器的公钥信息存到一个名字叫authorized_keys的文件里。
3.完成上述步骤,就可以在A机器,通过ssh B机器IP登录了。

原理:A机器登录B机器原理其实就是A用私钥签名,B用公钥验证签名的过程。

  • SSH的优点
    方便,安全。
    例如下列场景,Jenkins构建,需要运行shell脚本操作部署的机器,那么就可以,通过下列的语句实现:
#如果只是执行一条命令,那么可以这样写
ssh ip 命令
#多条的话,则可以这么写
ssh ip
命令1
命令2
exit
服务端SSH的配置
  • sshd_config配置
    root用户登录,更改ssh配置文件/etc/ssh/sshd_config,下列的配置可以不配置的默认应该是支持的
#启用rsa认证
RSAAuthentication yes
#启用公钥私钥配对认证方式
PubkeyAuthentication yes
  • 重启SSH服务
#重启ssh服务
systemctl restart sshd
客户端机器的配置

这个配置其实一般也是不需要的,因为如果你是Linux系统那么你自身就应该是产生了这样的一个密钥对的,完全可以使用这个来建立连接,所以你完全可以只执行第三步,ssh 【serverIp】直接建立连接,不过这个过程首次应该是会需要输入密码验证的方式来完成公钥的上传,后续则不需要了。

  • 生成公钥私钥对
ssh-keygen -t rsa

一路默认回车,系统在/root/.ssh下生成id_rsa、id_rsa.pub

  • 将id_rsa.pub发送到服务端机器上(让服务器信任该客户端)
ssh-copy-id -i /root/.ssh/id_rsa.pub  【serverIp】
  • 登录(验证)
ssh 【serverIp】
实践(jenkins)

Jenkins里的配置有两种方式:
1.密码登录远程主机,将需要部署的包发送到指定目录
2.SSH登录到远程主机,将需要部署的包发送到指定目录

配置的地方:Configure System [Jenkins],如下图所示。
在这里插入图片描述

参考

1.ssh命令和SSH服务详解 - 钟桂耀 - 博客园 (cnblogs.com)
2.ssh转发代理:ssh-agent用法详解 - 钟桂耀 - 博客园 (cnblogs.com)

这篇关于Linux的SSH基于公私钥验证的方式登录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/688171

相关文章

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存