用dnsmasq搭建小型的内网DNS

简介:

dnsmasq是个非常小巧的dns服务器,可以解决小范围的dns查询问题,譬如机房内网。

 

大致思路是这样的:

配置dnsmasq为DNS缓存服务器,同时在/etc/hosts文件中加入本地内网解析,这样一来,每当内网机器查询时就会优先查询hosts文件,这就等于将/etc/hosts共享给全内网机器使用,从而解决内网机器互相识别的问题。相比逐台机器编辑hosts文件或者添加bind DNS记录,仅编辑一个hosts文件,这简直太容易了。

实施过程以CentOS 6为例

 

 
 
  1. 安装配置 
  2. yum install dnsmasq -y 
  3. service dnsmasq start 

将其他机器的DNS换成dnsmasq所在的IP即可,玩完了,就这么容易。

 

接下来你就可以编辑hosts文件了,你懂的,简单列举一下格式

 
 
  1. 127.0.0.1  localhost 
  2.  
  3. 192.168.1.10   web01.xxx.com    web01 
  4. 192.168.1.20   web02.xxx.com    web02 

 

hosts文件的强大之处还在于能够劫持解析,譬如mirror.centos.org是CentOS仓库所在,几乎是机器正常必访问一个域名,我将它解析成一个内网地址,搭建一个内网镜像站,不仅内网机器也可以及时得到安全更新,每月还可以节省很多流量。 

 

其他问题 

 
 
  1. 默认配置文件为/etc/dnsmasq.conf,注释掉的不是示例就是默认值。   
  2.    
  3. 默认直接缓存resolv.conf中的nameserver,通过下面的选项指定其他文件   
  4. resolv-file=/etc/resolv.dnsmasq.conf   
  5.    
  6. 默认监听本地所有端口,指定监听端口的办法(别忘了本地回环)   
  7. listen-address=127.0.0.1,192.168.1.56   
  8.   
  9. 我要给dns记录在另外一个文件,而不是/etc/hosts  
  10. addn-hosts=/etc/addion_hosts  
  11.   
  12. 设置dns缓存大小  
  13. cache-size=150  
  14.  
  15. 我担心dnsmasq的稳定性怎么办 
  16. 解决办法一:写脚本或用nagios监视dnsmasq进程,或者定时重启 
  17. 解决办法二:在另一台机器也搭建一个dnsmasq,/etc/hosts文件拷一份过去,客户端指定2个内网DNS 

 

记得在iptables防火墙开放53端口哦!

 

最后补充 一点关于性能优化的想法:

 我们都知道,bind不配合数据库的情况下,经常需要重新载入并读取配置文件,这是造成性能低下的原因。

根据这点教训,我们可以考虑不读取/etc/hosts文件。而是另外指定一个在共享内存里的文件,比如/dev/shm/dnsrecord.txt ,这样就不费劲了,又由于内存的非持久性,重启就消失,可以定期同步硬盘上的某个内容到内存文件中。

 

具体一点就是下面的步骤

 

 
 
  1. /etc/dnsmasq.conf 
  2.  
  3. no-hosts 
  4. addn-hosts=/dev/shm/dnsrecord.txt 

解决同步问题

 
 
  1. 开机启动 
  2. #echo "cat /etc/hosts > /dev/shm/dnsrecord.txt" >>/etc/rc.local 
  3.  
  4. 定时同步内容 
  5. #crontab -e 
  6. */10 * * * * cat /etc/hosts > /dev/shm/dnsrecord.txt 

 










本文转自 紫色葡萄 51CTO博客,原文链接:http://blog.51cto.com/purplegrape/1083354,如需转载请自行联系原作者
目录
相关文章
|
域名解析 缓存 监控
ubuntu20.04上安装dnsmasq服务及dns缓存配置
ubuntu20.04 安装dnsmasq服务, 缓存dns,加快网络地址解析
1757 0
|
6月前
|
域名解析 监控 网络协议
企业实战(17)记录一次使用DDNS动态域名解析服务外网通过域名访问内网服务器服务的过程
企业实战(17)记录一次使用DDNS动态域名解析服务外网通过域名访问内网服务器服务的过程
416 0
|
7月前
|
域名解析 网络协议 Linux
如何centos搭建内网dns服务器的详细步骤
要在 CentOS 上搭建内网 DNS 服务器,你可以按照以下步骤进行操作: 1. 安装 BIND DNS 服务器: - 打开终端并以 root 用户身份登录到 CentOS。 - 运行以下命令安装 BIND DNS 服务器: ``` sudo yum install bind bind-utils ``` 2. 配置 BIND DNS 服务器: - 使用文本编辑器打开 `/etc/named.conf` 文件,并根据需求进行配置。以下是一个示例配置: ``` options { listen-on po
1374 0
|
8月前
|
缓存 算法 安全
转:深度解析如何利用递归算法来验证内网管理软件中的重要数据的完整性
用递归算法来验证内网管理软件里关键数据,就好比是在用放大镜审视一份份重要合同,确保它们都符合约定的条款,这样一来数据的品质和安全性都能得到提升。这种举重若轻的步骤,能够保证数据真实可靠,避免任何潜在的错误和漏洞。
49 1
|
9月前
|
存储 域名解析 弹性计算
阿里云VPC内网DNS日志正式接入SLS日志审计服务
内网DNS日志(Intranet DNS Log) 记录了指定阿里云uid下所有VPC网络内终端产生的DNS域名解析请求和应答,终端请求的这些域名既包含了配置在PrivateZone上的内网权威域名,也包含了外部公网域名。为了满足用户可以快速、简单实现多账号、多地域场景下内网DNS日志的采集、管理、中心化查询分析等需求,DNS与SLS联合开发,在SLS日志审计应用中发布一键开启内网DNS日志的功能。
阿里云VPC内网DNS日志正式接入SLS日志审计服务
|
域名解析 网络协议 安全
【内网安全-隧道技术】SMB、ICMP、DNS隧道、SSH协议
【内网安全-隧道技术】SMB、ICMP、DNS隧道、SSH协议
647 0
【内网安全-隧道技术】SMB、ICMP、DNS隧道、SSH协议
|
域名解析 Kubernetes 网络协议
内网主从智能DNS从此不再烦恼
内网主从智能DNS从此不再烦恼
|
网络协议
阿里云内网可用的dns
来自于阿里云技术支持工单 如果你要自己设置dns,可用: ```bash nameserver 100.100.2.136 nameserver 100.100.2.138 nameserver 223.
8000 0
|
域名解析 缓存 网络协议
Dnsmasq加速本地DNS请求
文章目录   Dnsmasq安装 Dnsmasq配置 Dnsmasq启动 Dnsmasq使用 Dnsmasq小结     默认的情况下,我们平时上网用的本地DNS服务器都是使用电信或者联通的,但是这样也导致了不少的问题,首当其冲的就是上网时经常莫名地弹出广告,或者莫名的流量被消耗掉导致网速变慢。
5562 0
|
运维 安全 网络协议
企业上云,内网DNS请用PrivateZone
DNS服务的作用就是就好比手机中的通讯录,可以通过域名找到对应IP。对于一家科技企业来说,搭建一套内网DNS是很有必要的。但是,当企业将网络整体搬迁到云上或者和云上网络相联通时,DNS服务常常面临无法覆盖新网络环境的问题。

相关产品

  • 云解析DNS
  • 推荐镜像

    更多