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

【ssh】ubuntu服务器+本地windows主机,使用密钥对进行ssh链接

目录

  • 1、服务器配置ssh
  • 2、本地主机秘钥对
  • 3、上传公钥至服务器
  • 4、配置服务器的公钥信息
  • 5、测试连接

1、服务器配置ssh

使用的服务器系统为 ubuntu系统20.04
首先确认服务器是否已安装SSH,已安装的话会返回openssh 的相关信息,返回为空表示未安装

dpkg -l | grep openssh-server

如果没有安装,进行安装

sudo apt update
sudo apt install openssh-server

安装成功后,启动ssh服务

sudo systemctl start ssh
sudo systemctl enable ssh

允许防火墙 通过SSH连接

sudo ufw allow 22/tcp

检查是否启动成功

sudo systemctl status ssh

返回:
请添加图片描述

查看服务器的主机名hostname 和 用户名

hostname -I
ls /home/

查看 ssh 端口port,默认的端口号为22

sudo ss -tulnp | grep sshd

如果需要配置ssh的config文件,可以用vi或者nano对Config文件的内容进行修改

sudo  vi /etc/ssh/sshd_config

编辑完后按 Esc
:w 保存文件
:wq or ZZ 保存并退出
:x 保存并退出(只有当文件被修改时才保存)
:q 退出(未修改时)
:q! 强制退出不保存

或者

sudo nano /etc/ssh/sshd_config

编辑完后按
Ctrl + O 保存
屏幕底部显示 File Name to Write: [当前文件名],保持原文件名,直接按 Enter 回车,要另存为新文件,输入新文件名后按回车
Ctrl + X退出

2、本地主机秘钥对

本地主机:windows11
使用Git Bash 检查本地是否现有SSH密钥

ls -al ~/.ssh

返回:
如果看到 id_rsa (私钥) 和 id_rsa.pub (公钥),说明已有密钥对
如果没有,新增秘钥

ssh-keygen -t rsa -b 4096

输入保存路径(默认按回车使用 ~/.ssh/id_rsa)
输入密钥密码(可选但推荐,为空则直接回车)

秘钥成功生成后,会在本地用户路径C:\Users\本地用户名.ssh文件夹中看到 id_rsa和 id_rsa.pub
在这里插入图片描述

3、上传公钥至服务器

依然是本地主机 Git bash 输入

cat ~/.ssh/id_rsa.pub

输出一段以ssh-rsa开头 以 邮箱结尾的秘钥
在这里插入图片描述
复制输出的全部内容,在Ubuntu服务器上执行:

mkdir -p ~/.ssh
echo "粘贴公钥内容" >> ~/.ssh/authorized_keys
chmod 600 ~/.ssh/authorized_keys
chmod 700 ~/.ssh

检查服务器中公钥文件是否存在

ls -l ~/.ssh/authorized_keys

检查文件中的内容

cat ~/.ssh/authorized_keys

4、配置服务器的公钥信息

打开ssh_config中关于秘钥的相关配置

sudo vi /etc/ssh/sshd_config

编辑文件,找到PubkeyAutentication 删掉前面的#号,并更改为:
请添加图片描述
保存并退出,修改后重启ssh服务:

sudo systemctl restart ssh

检查SSH服务秘钥是否修改配置成功

sudo grep -E '^PubkeyAuthentication|^AuthorizedKeysFile' /etc/ssh/sshd_config

输出:

PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys```

表明此时已允许密钥认证

检查秘钥的权限

ls -ld ~/.ssh && ls -l ~/.ssh/authorized_keys

应该输出

drwx------ 2 username username 4096 日期 .ssh
-rw------- 1 username username  567 日期 authorized_keys

5、测试连接

在ubuntu服务器中检查日志

sudo tail -f /var/log/auth.log

会显示log变化,不要关闭,回到本地windows主机,输入命令

ssh -i ~/.ssh/id_rsa username@服务器IP -p 端口号

在这里插入图片描述
连接成功后,服务器的log中会显示

Accepted publickey for 服务器主机名 from 本地IP port 本地端口号  

等链接信息

http://www.xdnf.cn/news/16530.html

相关文章:

  • Linux常用基础命令
  • 反射核心:invoke与setAccessible方法详解
  • Git 从入门到精通
  • linux命令ps的实际应用
  • SQL注入SQLi-LABS 靶场less26-30详细通关攻略
  • 深入解析Java元注解与运行时处理
  • ​第七篇:Python数据库编程与ORM实践
  • 前缀和-974.和可被k整除的子数组-力扣(LeetCode)
  • [mcp: JSON-RPC 2.0 规范]
  • 机器学习之线性回归——小白教学
  • LRU(Least Recently Used)原理及算法实现
  • 最新优茗导航系统源码/全开源版本/精美UI/带后台/附教程
  • BreachForums 黑客论坛强势回归
  • sqLite 数据库 (2):如何复制一张表,事务,聚合函数,分组加过滤,列约束,多表查询,视图,触发器与日志管理,创建索引
  • JAVA_TWENTY—ONE_单元测试+注解+反射
  • 学习Python中Selenium模块的基本用法(3:下载浏览器驱动续)
  • Seq2Seq学习笔记
  • 前端优化之虚拟列表实现指南:从库集成到手动开发
  • 嵌入式学习日志————TIM定时中断之定时器定时中断
  • Python算法实战:从排序到B+树全解析
  • 算法精讲:二分查找(一)—— 基础原理与实现
  • 自学嵌入式 day37 HTML
  • 信号上升沿时间与频谱分量的关系
  • FastAPI后台任务:异步魔法还是同步噩梦?
  • Simulink建模-Three-Phase V-I Measurement 模块详解
  • Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现各种食物的类型检测识别(C#代码UI界面版)
  • react 的 useTransition 、useDeferredValue
  • GitHub下载项目完整配置SSH步骤详解
  • Python day28
  • Linux重定向的理解