Linux为什么卡住了?

简介:

通过SSH登录Linux服务器时,输完用户名就卡住了,要等待10秒钟才提示密码输入。这究竟是什么原因导致的呢? 10秒钟的时间并不算长,吃个薯片喝口咖啡就过去了。但是作为强迫症患者,我还是容不得它的存在,因此便决定写篇文章,向大家演示一下怎样用Wireshark一步步解决这个问题。ssh_linux_01首先是抓包,步骤如下

  • 在Linux服务器上启动抓包。
  • 从笔记本SSH到Linux服务器,输入用户名并回车。
  • 等待10秒左右,直到登录界面提示输入密码。
  • 停止抓包。

这样就可以得到一个涵盖该现象的网络包了。一般在实验室中没有干扰流量,不用过滤也可以分析,不过我们最好在做实验时就养成过滤的习惯,以适应生产环境中抓到的包。因为我们是通过SSH协议登录的,所以可以直接用“ssh”来过滤,如图所示。SSH包都是加密了的,因此我们看不出每个包代表了什么意思,不过这并不影响分析。从图2中可以看到,21号包和25号包之间恰好就相隔10秒。ssh_linux_02这两个包之间所发生的事件,可能就是导致这个现象的原因。于是我再用“frame.number> 21 && frame.number< 25”过滤,结果如图所示。ssh_linux_03分析

从图中可以看到,Linux服务器当时正忙着向DNS服务器查询10.32.200.23的PTR记录(即反向解析),试图获得这个IP地址所对应的域名。该IP属于我们测试所用的笔记本,但由于DNS服务器上没有它的PTR记录,所以两次查询都等了5秒钟还没结果,总共浪费了10秒钟。我们由此可以推出,这台Linux服务器在收到SSH访问请求时,会先查询该客户端IP所对应的PTR记录。假如经过5秒钟还没有收到回复,就再发一次查询。如果第二次查询还是等了5秒还没回复,就彻底放弃查询。我们甚至可以进一步猜测,如果DNS查询能成功,就不用白等那10秒钟了。为了验证这个猜测,我在DNS服务器中添加了10.32.200.23的PTR记录,如图所示,然后再次登录。ssh_linux_04这一次果然立即登录进去了。从图的Wireshark截屏可见,DNS查询是成功的,所以21号包和26号包之间几乎是没有时间停顿的。ssh_linux_05结果

明白了DNS查询就是问题的起因,接下来就知道怎么进一步研究了。只要在Google搜索“ssh dns”,第一页出来的链接都是关于这个问题的。随便挑几篇阅读一下,就连我这样的Linux初学者都能把这个问题研究透了。原来这个行为是定义在“/etc/ssh/sshd_config”文件中的,默认配置是这样的:

[root@Linux_Server ~]# cat /etc/ssh/sshd_config |grep -i usedns

#UseDNS yes

改成下面这样就可以解决了,不用去动DNS服务器上的配置:

[root@Linux_Server~]# cat /etc/ssh/sshd_config |grep -i usedns

UseDNS no 



本文转自Linux就该这么学博客园博客,原文链接:http://www.cnblogs.com/linuxprobe/p/5343631.html,如需转载请自行联系原作者

相关文章
|
5月前
|
Web App开发 安全 Linux
linux杀进程
linux杀进程
|
8月前
|
Java Unix Linux
开发常用的 Linux 命令4(系统、进程和其它)
开发常用的 Linux 命令4(系统、进程和其它)
|
10月前
|
测试技术 网络安全 开发工具
Linux-程序与进程学习
Linux-程序与进程学习
107 0
|
12月前
|
监控 Linux
Linux 这4个进程相关的命令,太好用!
Linux 这4个进程相关的命令,太好用!
83 0
Linux学习笔记 11(查看进程命令)
1、 Ps作用:查看所有进程(1) 查询当前控制台上运行的进程(2) 查询系统中所有运行的进程,包括后台进程参数a是所有进程参数x包括不占用控制台的进程参数u显示用户(3) 询系统中所有运行的进程,包括后台进程,而且可以显示出每个进程的父进程号2、 Pstree作用:树状格式显示进程列表(1) 以树状格式显示系统的进程列表(2) 带进程号的树状格式显示进程列表3、 Top作用:动态地显示系统中的进程(1) 动态地显示系统中的进程4、 Kill作用:杀掉指定进程(1) 杀掉指定进程(2) 强制杀掉指定进程作用:杀掉指定进程(1) 杀掉指定进程作用:动态地显示系统中的进程(1) 动态地显示)
Linux学习笔记 11(查看进程命令)
|
Linux NoSQL
(学习笔记)使用 Kdump 检查 Linux 内核崩溃
版权声明:转载请注明出处:http://blog.csdn.net/dajitui2024 https://blog.csdn.net/dajitui2024/article/details/79396544 ...
1480 0
|
网络协议 Linux 网络安全