syslog-ng解析dns,引起dhcpd 工作失效!

最近工作中遇到一个问题,问题现象是:
dhcpd工作一段时间后,终端就无法再次获取ip。

首先,排查了是否因为地址池不够的情况。
其次,netstat -anup发现 dhcpd收包队列,达到了800万条。而发包队列为空。
这里写图片描述
貌似dhcpd被阻塞了,导致无法响应终端的dhcp discover/request请求。
但查看dhcpd代码,已设置无阻塞socket,按理不应该出现这种情况。
继续排查,发现,dhcpd无法分配ip的时候,函数调用栈是:syslog-ng解析dns,引起dhcpd 工作失效!_第1张图片
通过这个可知,是阻塞到了syslog()这里。
此时查看syslog进程,发现:
syslog-ng解析dns,引起dhcpd 工作失效!_第2张图片

syslog服务的收包队列也达到了500万左右。
查看syslog的调用栈,发现:
syslog-ng解析dns,引起dhcpd 工作失效!_第3张图片

看到没,终于发现问题了:
gethostbyaddr()是阻塞函数。

就此,该问题已基本被定位出原因。
解决方法就是:
修改syslog配置文件,取消是能use_dns以及dns_cache。

你可能感兴趣的:(linux,网络通信,dhcpd,syslog)