吐槽下dnsmasq源码

无意中发现了一个巨牛的人工智能教程,忍不住分享一下给大家。教程不仅是零基础,通俗易懂,而且非常风趣幽默,像看小说一样!觉得太牛了,所以分享给大家。点 这里可以跳转到教程。

吐槽下dnsmasq源码

首先表示下感谢,作者提供简单的设计,丰富的功能,充分降低了我们这些普通程序员的工作,但是要理解起来还是不那么称心如意,主要有那么几点。

  1. 无关设计, 代码缩进问题。

无处不再的空格,偶尔有几行tab,真的不好看阿,阅读起来很麻烦
  1. 整体设计的感想

程序主要架构是select侦听socket的状态进行操作 -- 【决定其只能在小网络架构中使用】

采用struct dnsmasq全局的结构体,里面包含很多的链表来存储受到的数据报文并和响应绑定,思考的挺巧妙的,不过,个人觉得这样的结构体太臃肿了,看起来真的不舒服,只能慢慢熟悉代码逻辑后,理解设计。
  1. 修改其dns处理逻辑

主要处理逻辑在check_dns_listener, 我只看了udp的请求,tcp的请求就没注意理解,貌似是fork子进程,单独处理。 有最大连接数限制。

主要函数是receive_query, forward_query, reply_query等

receive_query - 主要是解析数据报,看看缓存有没有,有且未超时则使用缓存answer_request处理封装相应,没有就调用forward_query
forward_query - 主要做的就是将数据报文发送到所有的dns服务器,来自/tmp/resolve.conf.auto
reply_query - 接受dns服务器的响应,收到后查找是哪个请求,没有找到则丢弃,找到了,就根据SOA,等取出

你可能感兴趣的:(openwrt,Linux)