dnsmasq先去解析hosts文件, 再去解析/etc/dnsmasq.d/下的*.conf文件,而且這些文件的優先級要高於dnsmasq.conf,咱們自定義的resolv.dnsmasq.conf中的DNS也被稱爲上游DNS,這是最後去查詢解析的;html
若是不想用hosts文件作解析,咱們能夠在/etc/dnsmasq.conf中加入no-hosts這條語句,這樣的話就直接查詢上游DNS了,若是咱們不想作上游查詢,就是不想作正常的解析,咱們能夠加入no-reslov這條語句。linux
bind這個DNS太龐大了,若是一個部門或者是服務範圍比較小的狀況下,咱們用dnsmasq徹底能夠,畢竟配置起來簡單方便,dnsmasq就用來咱們公司內部域名和公網域名存在衝突或者是本身的域名比較特別的話用起來比較好,也不影響正常的外網解析。git
1.直接使用yum安裝,而且設置開機自啓,關閉SELinuxvim
[root@localhost ]# yum install dnsmasq* -y [root@localhost ]# chkconfig dnsmasq on
2.修改本地網絡配置文件緩存
修改網卡參數服務器
[root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 TYPE=Ethernet ONBOOT=yes NM_CONTROLLED=yes BOOTPROTO=none IPADDR=172.19.30.250 PREFIX=24 GATEWAY=172.19.30.254 DNS1=127.0.0.1 DEFROUTE=yes IPV4_FAILURE_FATAL=yes IPV6INIT=no NAME=」System eth0″
修改hostname網絡
[root@localhost ~]# vim /etc/sysconfig/network NETWORKING=yes HOSTNAME=ad.cloud.com GATEWAY=172.19.30.254
3.修改iptables(嫌麻煩的直接關掉就能夠了)app
$ iptables -A INPUT -p udp -m udp –dport 53 -j ACCEPT $ iptables -A INPUT -p tcp -m tcp –dport 53 -j ACCEPT
# 開啓流量轉發功能dom
$ echo ‘1’ > /proc/sys/net/ipv4/ip_forward $ echo ‘1’ > /proc/sys/net/ipv6/ip_forward # IPv6 用戶選用
# 添加流量轉發規則,將外部到53的端口的請求映射到Dnsmasq服務器的53端口異步
$ iptables -t nat -A PREROUTING -p udp –dport 53 -j REDIRECT –to-ports 53 $ iptables -t nat -A PREROUTING -p tcp –dport 53 -j REDIRECT –to-ports 53
# 若是要限制只容許內網的請求,方法以下,若是是一個網卡,直接把eth1替換成eth0便可
$ iptables -t nat -A PREROUTING -i eth1 -p upd –dport 53 -j REDIRECT –to-port 53
$ service iptables save $ service iptables restart
4.修改/etc/dnsmasq.conf
[root@localhost dnsmasq.d]# vim /etc/dnsmasq.conf 填入如下內容 no-hosts
#不加載本地的/etc/hosts文件
local-ttl=3600
#本地緩存時間,一般不要求緩存本地,這樣更改hosts文件後即便生效
cache-size=1000000
#最大緩存條數
dns-forward-max=1000000 listen-address=127.0.0.1,172.19.30.250
#若是想要這臺服務器作解析,就要填上本身的地址,而且填上127.0.0.1的地址
resolv-file=/etc/resolv.dnsmasq.conf
#這個文件是能夠自定義的,我就跟隨大流,直接複製了一份resolv.conf改了名稱就用了
all-servers
#這條語句的意思就是若是本地沒查詢到,則想咱們的resolv.dnsmasq.conf文件中全部的DNS查詢,誰查到的快就用誰的
log-queries
#開啓日誌選項
log-facility=/var/log/dnsmasq/dnsmasq.log log-async=100
#異步log,緩解阻塞,提升性能。默認爲5,最大爲100
conf-dir=/etc/dnsmasq.d
#這條應該是最後一句,它的做用其實就是說明該目錄下的全部.conf文件都是要作解析的
提示:若是我們內網中存在多個不一樣域名,咱們能夠加上上面的這一句,咱們作解析時就好分類配置文件
5.添加resolv解析文件
修改咱們剛纔複製的配置文件,指定咱們正常須要的DNS,這樣的話咱們的內網就能夠正常的使用網絡,而不至於用了本身搭建的DNS,卻訪問不了互聯網。
[root@localhost dnsmasq.d]# vim /etc/resolv.dnsmasq.conf nameserver 202.106.0.20 nameserver 192.168.59.241 nameserver 114.114.114.114 nameserver 8.8.8.8 nameserver 168.95.1.1
#最後一條爲臺灣的DNS,咱們蘋果的官方appstore下載東西會快一些,而且蘋果電腦在線重裝系統用這個DNS也會快一些
6.添加其餘域名解析
咱們切換到這個目錄下,添加咱們不一樣內部域名的解析
[root@localhost dnsmasq.d]#cd /etc/dnsmasq.d/
添加一個解析文件
[root@localhost dnsmasq.d]#vim cloud.conf [root@localhost dnsmasq.d]# ls cloud.conf seccloud.conf
7.配置文件語法規則
正常下咱們添加的解析內容以下,解析地址的語法規則爲:
address=/domain/ip_address [root@localhost dnsmasq.d]#cat cloud.conf address=/im.cloud.top/192.168.59.12 address=/git.cloud.top/192.168.59.20 address=/crm.cloud.top/192.168.59.11 address=/ftp.cloud.top/172.19.2.253 address=/note.cloud.top/172.19.30.250
8.啓動dnsmasq服務
[root@localhost ~]#service dnsmasq start
9.咱們進行測試驗證:
本身的筆記本上域名訪問進行測試:
localhost:~ admin$ nslookup > git.cloud.top Server:172.19.30.250 Address:172.19.30.250#53 Name:git.cloud.top Address: 192.168.59.20 > www.baidu.com Server:172.19.30.250 Address:172.19.30.250#53 Non-authoritative answer: www.baidu.comcanonical name = www.a.shifen.com. Name:www.a.shifen.com Address: 61.135.169.121 Name:www.a.shifen.com Address: 61.135.169.125
緩存驗證:
[root@ad ~]# dig www.baidu.com ; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.62.rc1.el6_9.2 <<>> www.baidu.com ;; global options: +cmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 21877 ;; flags: qr rd ra; QUERY: 1, ANSWER: 3, AUTHORITY: 4, ADDITIONAL: 4 ;; QUESTION SECTION: ;www.baidu.com. IN A ;; ANSWER SECTION: www.baidu.com. 223 IN CNAME www.a.shifen.com. www.a.shifen.com. 549 IN A 119.75.213.61 www.a.shifen.com. 549 IN A 119.75.216.20 ;; AUTHORITY SECTION: shifen.com. 30440 IN NS ns4.baidu.com. shifen.com. 30440 IN NS dns.baidu.com. shifen.com. 30440 IN NS ns2.baidu.com. shifen.com. 30440 IN NS ns3.baidu.com. ;; ADDITIONAL SECTION: dns.baidu.com. 4938 IN A 202.108.22.220 ns2.baidu.com. 76100 IN A 61.135.165.235 ns3.baidu.com. 31611 IN A 220.181.37.10 ns4.baidu.com. 166964 IN A 220.181.38.10 ;; Query time: 59 msec ;; SERVER: 127.0.0.1#53(127.0.0.1) ;; WHEN: Sat Jul 1 13:25:51 2017 ;; MSG SIZE rcvd: 226 [root@ad ~]# dig www.baidu.com ; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.62.rc1.el6_9.2 <<>> www.baidu.com ;; global options: +cmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 61460 ;; flags: qr rd ra; QUERY: 1, ANSWER: 3, AUTHORITY: 0, ADDITIONAL: 0 ;; QUESTION SECTION: ;www.baidu.com. IN A ;; ANSWER SECTION: www.baidu.com. 215 IN CNAME www.a.shifen.com. www.a.shifen.com. 541 IN A 119.75.216.20 www.a.shifen.com. 541 IN A 119.75.213.61 ;; Query time: 0 msec ;; SERVER: 127.0.0.1#53(127.0.0.1) ;; WHEN: Sat Jul 1 13:25:59 2017 ;; MSG SIZE rcvd: 93
咱們能夠看到,上次解析保留了緩存,此次解析直接讀取了緩存文件。
本文地址:http://www.linuxprobe.com/dnsmasq-dns.html