sshkey管理Linux系统的联网远程登录

2024-02-19 08:48

本文主要是介绍sshkey管理Linux系统的联网远程登录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

登录的密钥密匙

摘要:远程登录命令ssh可以远程登录并控制其主机,也就存在不安全因素,这里主要介绍对远程登录的加密,即仅分配给允许登录的人钥匙,其他人就拒之门外,极大地提高了安全性。详细具体做法如下:

1. 生成公钥私钥

默认情况下,是没有锁的,首先要做的就是配一把锁、一把钥匙,即生成公钥和私钥。

 

如下:

 

其中:

(1)Generating public/private rsa key pair.

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

加密字符保存文件(建议用默认)

建议密码可以为空,按[enter]键 即可

(2)Enter passphrase (empty for no passphrase):密钥密码

建议密码可以为空,按[enter]键 即可

(3)Enter same passphrase again:确认密码

建议密码可以为空,按[enter]键 即可

(4) /root/.ssh中可以看到 id_rsa   id_rsa.pub

id_rsa     私钥,就是钥匙

id_rsa.pub   公钥,就是锁

 

2. 添加key认证方式

在锁和钥匙齐全的情况下,将私钥封装成添加为key认证方式。

格式如下:

ssh-copy-id       添加key认证方式的工具

-i                       指定加密key文件

/root/.ssh/id_rsa.pub 加密key

root                    加密用户为root

172.25.86.11      被加密主机ip

注:添加key认证需要本主机超户密码验证


生成authorized_keys文件

 

3. 分发钥匙给client主机

也完成了key认证环节,下来就是把钥匙发送给对的人。

命令格式如下:

 

将服务器的密码发给客户端的同时也要验证客户端密码

 

在客户端打开相关目录,看到文件已经送达。

 

4. 测试

注:此时的输入密码远程连接依然存在

 

免密登录,需要配置相关文件,如下:

 

找到密码登录的这行:

 

yes改为no表示不用密码登录,用key密匙即可免密登录。

 

重启服务,很重要

 

[root@client86 ~]# ssh root@172.25.86.11           通过id_rsa直接连接不需要输入用户密码

Last login: Mon Oct  3 03:58:10 2017 from 172.25.86.10

[root@server86~]#

 


这篇关于sshkey管理Linux系统的联网远程登录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境