And*_*w B 6 domain-name-system capacity-planning ddos
我已阅读并理解您能否帮助我进行容量规划?,但我不确定我是否了解 DNS 服务器方案中的下一步。我认为我的 CPU 负载很高,或者我可能开始放弃查询,但我想在对它采取行动之前更好地了解我的服务器的负载。这对我来说尤其重要,因为众所周知,将基础设施扩展到 DDoS 负载正在失败。
为了了解我的环境,我应该分析什么?
在 Serverfault 上,我们通常会告诉您我们无法帮助您进行容量规划。这是有充分理由的:我们不知道您的环境的具体情况,关于如何衡量它的答案几乎相同。不幸的是,DNS 容量测量是一个鲜为人知的话题,大多数管理员会认为高 CPU 使用率意味着是时候考虑增加容量了。这是一个非常非常糟糕的主意,扩展到 DNS DDoS 将不可避免地导致您的网络设备窒息。(或者更糟的是,人们联系您的法律部门)
服务器日志和数据包捕获是大多数管理员会首先尝试利用的内容,但简单的事实是,SNMP 可以告诉您更多有关环境的信息,而不是您的日志所做的事情。不要忽略日志和数据包捕获,但 SNMP 通常可以帮助您更快地发现问题的存在。
除了跟踪 SNMP 监控工具提供的默认系统统计信息(应包括 CPU 负载、每个接口的吞吐量和数据包计数器、磁盘 I/O 等),我建议添加以下 OID:
udpInErrors强烈推荐愤怒红色)udpInDatagrams ,udpOutDatagramsudpNoPortstcpInSegs ,tcpOutSegs这些图表可以归为两类:指示问题的指标和帮助您诊断问题的指标。
指标
udpInErrors是容量问题的主要标志。每次内核丢弃 UDP 数据报时,此计数器都会增加,因为应用程序处理流量的速度不够快。这意味着您的 DNS 服务过载,无法跟上传入的流量。
如果您无法将这些指标的增加与系统上的其他性能问题相关联,那么恭喜您:您正接近/超出容量,是时候添加服务器了。想想我印象深刻。:)
诊断
这仅涵盖 DNS 特定项目。在这里用你的头脑,不要指望这是包罗万象的。(例如:磁盘 I/O 饱和不是 DNS 特有的问题)
旁注:udpNoPorts并不是真正的容量指标,但它对于识别缓存中毒尝试很有用。每次在意外端口上看到 UDP 数据包时,此计数器都会增加,并且在正常操作期间持续出现这些数据包可能表明有人正在尝试伪造回复。(或者,或者你的一个听众没有运行:把它重新打开 foo'!)
| 归档时间: |
|
| 查看次数: |
1865 次 |
| 最近记录: |