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

WSL2环境下因服务器重装引发的SSH连接问题排查记录

背景

近期在重装一台云服务器后,我尝试从本地的WSL2环境通过SSH连接,遇到了连接失败的问题。我的工作环境组合比较典型:SSH密钥对存放在Windows原生系统下(C:\Users\YourUser\.ssh),而日常的终端操作则在WSL2中完成。本文旨在记录该问题的排查过程和最终采用的优化方案。

1. 初步尝试:指定密钥路径连接

服务器重装后,需要将本地的SSH公钥重新部署到服务器的authorized_keys文件中。在WSL2终端中,直接执行 ssh-copy-id 无法访问到位于Windows文件系统中的密钥。

解决方案是利用WSL的挂载机制,通过/mnt/路径访问Windows磁盘,并使用 ssh-copy-id-i 参数来指定公钥的具体位置。

# -i 参数用于指定身份文件(公钥)
ssh-copy-id -i /mnt/c/Users/我真棒/.ssh/id_rsa.pub root@38.55.178.244

2. 发现问题:主机密钥验证失败

执行上述命令后,连接并未成功,终端返回了关于主机身份识别变更的警告:
在这里插入图片描述

WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!
...
Host key verification failed.

这个警告是SSH的一项核心安全特性。SSH客户端会在本地的 ~/.ssh/known_hosts 文件中缓存已连接过的服务器的主机公钥指纹。当客户端再次连接同一IP或域名的服务器时,会校验收到的公钥指纹是否与本地记录一致。

由于我重装了服务器系统,服务器端的SSH服务重新生成了一对主机密钥,导致其指纹发生了变化。客户端检测到这一不匹配,出于防止中间人攻击的考虑,默认中断了连接。

3. 解决问题:更新本地主机记录

确认主机密钥变更是由我方正常操作(重装系统)引起后,需要更新本地的 known_hosts 文件。手动编辑该文件容易出错,推荐使用 ssh-keygen 工具进行管理。警告信息中也提示了标准的操作命令:

ssh-keygen -f "/home/oi/.ssh/known_hosts" -R "38.55.178.244"

该命令会精确地移除指定IP地址的旧记录,而不影响文件中其他主机的条目。

清除旧记录后,再次执行第一步中的 ssh-copy-id 命令。此时,终端会提示无法确认主机的真实性,并询问是否继续连接。输入 yes 后,新的主机密钥指纹将被保存到 known_hosts 文件中,随后按提示输入密码即可完成公钥的部署。
在这里插入图片描述
测试连接发现也是能成功连接上
在这里插入图片描述

4. 优化工作流:统一SSH配置

虽然连接问题得以解决,但每次操作都需要手动指定位于Windows下的密钥路径,操作上较为繁琐。为了优化日常工作流,我决定统一Windows与WSL2的SSH配置。

我采用的方法是在WSL2中创建符号链接,使其 ~/.ssh 目录直接指向Windows下的对应目录。

操作步骤:

  1. 备份并移除WSL2中原有的.ssh目录

    mv ~/.ssh ~/.ssh_backup
    
  2. 创建符号链接

    ln -s /mnt/c/Users/我真棒/.ssh ~/.ssh
    
  3. 修正目录和文件权限
    这是非常关键的一步。由于Windows和Linux的文件权限系统不同,直接链接后可能导致权限过于开放,SSH会因此拒绝使用这些密钥。必须手动设置为SSH要求的严格权限。

    chmod 700 ~/.ssh
    chmod 600 ~/.ssh/id_rsa
    

完成配置后,WSL2中的所有SSH相关命令将默认使用Windows目录下的密钥和配置,实现了两个环境身份的统一,简化了后续操作。


文章转载自:

http://Lh367pM5.brnwc.cn
http://x7FWw3tw.brnwc.cn
http://g97CRu4b.brnwc.cn
http://kYQkzumS.brnwc.cn
http://RgfKMNaD.brnwc.cn
http://eb0J8Uzv.brnwc.cn
http://ezYtiwbW.brnwc.cn
http://l1AG4Nh6.brnwc.cn
http://upatpw7r.brnwc.cn
http://5ejeYwiR.brnwc.cn
http://g2b6RAEy.brnwc.cn
http://jImeqLP8.brnwc.cn
http://HdN5MMX4.brnwc.cn
http://UAP0Q2BV.brnwc.cn
http://k8ThiN0X.brnwc.cn
http://272t221P.brnwc.cn
http://oxfrzs5G.brnwc.cn
http://K2Pl8W3r.brnwc.cn
http://WfRxplIK.brnwc.cn
http://Izie9ukS.brnwc.cn
http://0iLRw6xj.brnwc.cn
http://mriFhhgm.brnwc.cn
http://kfJPHJlL.brnwc.cn
http://3uJ5qFfT.brnwc.cn
http://hwlRtoqc.brnwc.cn
http://d37ROlGf.brnwc.cn
http://cZWXwORP.brnwc.cn
http://HzTJ8PH5.brnwc.cn
http://N8FXPEuO.brnwc.cn
http://Sxb7e9GM.brnwc.cn
http://www.dtcms.com/a/370117.html

相关文章:

  • 02-Media-6-rtsp_server.py 使用RTSP服务器流式传输H264和H265编码视频和音频的示例程序
  • I/O 多路复用 (I/O Multiplexing)
  • Nginx性能调优:参数详解与压测对比
  • java接口和抽象类有何区别
  • C/C++动态爱心
  • YOLOv8 在 Intel Mac 上的 Anaconda 一键安装教程
  • 关于 React 19 的四种组件通信方法
  • Joplin-解决 Node.js 中 “digital envelope routines::unsupported“ 错误
  • [论文阅读] 软件工程 - 需求工程 | 2012-2019年移动应用需求工程研究趋势:需求分析成焦点,数据源却藏着大问题?
  • sensitive-word 敏感词性能提升14倍优化全过程 v0.28.0
  • 留数法分解有理分式
  • 基于FPGA的汉明码编解码器系统(论文+源码)
  • C++经典的数据结构与算法之经典算法思想:排序算法
  • 大恒-NF相机如何控制风扇
  • 01.单例模式基类模块
  • 数位DP -
  • kotlin - 2个Fragment实现左右显示,左边列表,右边详情,平板横、竖屏切换
  • 基于SpringBoot+Thymeleaf开发的实验室助理工作管理系统
  • 手写MyBatis第53弹: @Intercepts与@Signature注解的工作原理
  • 基于SpringBoot+JSP开发的潮鞋网络商城
  • docker run 命令,不接it选项,run一个centos没有显示在运行,而run一个nginx却可以呢?
  • 【C++框架#3】Etcd 安装使用
  • 洛谷 P3178 [HAOI2015] 树上操作-提高+/省选-
  • Java全栈开发工程师的面试实战:从基础到复杂场景的技术探索
  • 【Flask】测试平台开发,重构提测管理页面-第二十篇
  • ICPC 2023 Nanjing R L 题 Elevator
  • TensorFlow 面试题及详细答案 120道(101-110)-- 底层原理与扩展
  • 《sklearn机器学习——聚类性能指标》Davies-Bouldin Index (戴维斯-博尔丁指数)
  • 美团9-6:编程题
  • 深度学习--自然语言预处理--- Word2Vec