SSH连接调试小技巧

本篇文章重点为大家讲解一下SSH连接调试小技巧,有需要的小伙伴可以参考一下。

问题一:SSH服务没有运行

SSH连接错误的常见原因是服务未在远程服务器上运行。这可能是由于服务意外关闭或系统重新启动后服务未启动而引起的。

要检查SSH服务是否正在运行,请运行下面命令:

[root@server1 ~]# systemctl status sshd

如何调试SSH连接如何调试SSH连接

解决方法

使用以下命令设置SSH服务开机启动,并启动服务:

[root@server1 ~]# systemctl enable sshd
[root@server1 ~]# systemctl start sshd

问题二:非标准端口上的SSH

调试SSH连接时的第二个常见问题是使用非标准端口。如果SSH在默认端口22以外的其他端口上运行,则除非明确指定运行SSH的端口,否则将不能连接到远程主机。

要查看运行SSH的端口,请使用netstat之类的工具,如下所示:

[root@clean-idea-1 ~]# netstat -tlunp|grep sshd
tcp        0      0 0.0.0.0:28159           0.0.0.0:*               LISTEN      818/sshd            
tcp6       0      0 :::28159                :::*                    LISTEN      818/sshd            

上面的输出显示了SSH服务在哪个端口上运行。在这种情况下,它是端口28159。

解决方法

端口不是默认的22时,连接就需要指定端口了:

[root@server1 ~]# ssh [email protected] -p 28159

问题三:端口被占用

SSH连接错误的另一个原因是其他服务或进程是否也使用与SSH服务相同的端口。例如,SSH的端口号为80,这和http服务的端口冲突了,则类似Apache的服务可能正在使用相同的端口。

要查看其他进程是否正在使用与SSH相同的端口,请使用以下命令检查日志:

[root@server1 ~]# journalctl -t sshd

该命令应返回如下所示的错误,显示端口已被占用。

解决方法

在这可以修改ssh的端口号,打开配置文件将端口修改为其他的,Port 2222

vim /etc/ssh/sshd_config

Port 2222

如何调试SSH连接如何调试SSH连接

问题四:被防火墙阻止

如果尝试了上述所有方法,仍无法建立SSH连接,则可以看看防火墙是否阻止连接?

解决方法

在Cetnos8中,使用fireawlld查看防火墙,并将端口添加允许里面:

[root@server1 ~]# firewall-cmd --list-all
[root@server1 ~]# firewall-cmd --permanent --add-port=2222/tcp
success
[root@server1 ~]# firewall-cmd --reload
success

如何调试SSH连接如何调试SSH连接

问题五:已禁用密码登录

有时,您可以将SSH配置为不接受密码登录,而仅使用公密钥身份验证。如果公钥在服务器上不可用或缺少私钥对,则可能导致不能登录的问题。

解决方法

要检查/etc/ssh/sshd_config配置文件是否允许密码登录,请将ssh配置设置为如下:

[root@server1 ~]# grep PasswordAuthentication /etc/ssh/sshd_config
#PasswordAuthentication yes
PasswordAuthentication yes
# PasswordAuthentication.  Depending on your PAM configuration,
# PAM authentication, then enable this but set PasswordAuthentication

上面的输出显示允许密码登录。

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/7168.html

(0)
晴川运维晴川运维
上一篇 2025年6月9日
下一篇 2025年6月9日

相关推荐

  • APF防火墙的安装和使用

    APF(Advanced Policy Firewall)是 Rf-x Networks 出品的Linux环境下的软件防火墙,被大部分Linux服务器管理员所采用,使用iptabl…

    Linux系统 2025年6月10日
  • Linux桌面环境(桌面系统)大比拼[附带优缺点]

    早期的 linux 系统都是不带界面的,只能通过命令来管理,比如运行程序、编辑文档、删除文件等。所以,要想熟练使用 Linux,就必须记忆很多命令。 后来随着 Windows 的普…

    Linux系统 2025年6月24日
  • C语言中const修饰的指针

    当用const进行修饰时,根据const位置的不同有三种不同效果。 判断的标准是:const修饰谁,谁的内容就是不可变的。 const修饰指针变量时候有三种情况: 1 const …

    Linux系统 2025年6月8日
  • gitlab 数据备份具体实现方法

    搭建个人Gitlab仓库可以更好地维护迭代频繁的代码或者文字方案,为确保重要数据的安全性,定期备份Gitlab数据是非常重要的,本篇文章重点为大家讲解一下gitlab 数据备份具体…

    Linux系统 2025年6月25日
  • Linux常用命令mzip命令具体使用方法

    Linux mzip命令是Zip/Jaz磁盘驱动器控制指令。 mzip为mtools工具指令,可设置Zip或Jaz磁盘驱动区的保护模式以及执行退出磁盘的动作。 语法 mzip&nb…

    Linux系统 2025年6月8日
  • 开源日志库Logger进阶使用方法

    日志对于开发来说是非常重要的,不管是调试数据查看、bug问题追踪定位、数据信息收集统计,日常工作运行维护等等,都大量的使用到。今天介绍著名开源日志库Logger的使用,库的地址:h…

    Linux系统 2025年6月15日
  • 详解grep命令的排除功能

    grep命令是linux中一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。 在一个或多个文件中搜素字符串模式,如果字符串模式包括空格,也必须被引用,模式后…

    Linux系统 2025年6月8日
  • Linux下查看系统架构具体方法

    计算机的体系结构从指令集的复杂度上可以分两类,一是复杂指令集CISC,主要是X86架构。另一类是精简指令集RISC,这个比较多,主要是ARM、MIPS、PowerPC等,本篇文章为…

    Linux系统 2025年6月8日
  • 学生党如何保护自己的网络安全

    互联网的兴起给人们的教育带来了巨大的好处。但是,这也使人们成为黑客和敏感信息盗窃的目标,这就是为什么每个学生都必须在某个时候了解在线网络安全的原因。 如今,几乎每个学生都拥有一台智…

    Linux系统 2025年6月25日
  • Linux下快速挂载U盘

    Linux下如何挂载U盘?在Linux系统中挂载U盘的方法非常简单,下面为大家分享一下Linux下快速挂载U盘具体方法。 1、 插入U盘 2、 #sudo fdisk –l 查看所…

    Linux系统 2025年6月19日

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注