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

本文介绍了一种DHCP服务故障的现象及排查过程。故障表现为终端无法获取IP地址,最终定位到syslog服务的阻塞问题,并给出了具体的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

syslog服务的收包队列也达到了500万左右。
查看syslog的调用栈,发现:
这里写图片描述

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值