CentOS 7 部署 dnsmasq

文章目录

      • (1)概述
      • (2)dnsmasq的解析流程
      • (3)重要参数说明
      • (4)部署dnsmasq
      • (5)其他内容
      • (6)域名劫持
      • (7)dns污染验证
      • (8)dnsmasq优化

(1)概述

在本博客中,将介绍如何在CentOS 7上部署和配置dnsmasq,一个轻量级的DNS和DHCP服务器。dnsmasq可以用于本地域名解析、网络地址分配和DNS缓存等功能。

(2)dnsmasq的解析流程

dnsmasq的解析流程如下:

  1. 首先,不管是pc还是服务器都是会解析hosts文件,其中包含了一些自定义的域名和IP地址的映射关系。
  2. 然后,dnsmasq会解析/etc/dnsmasq.d/目录下的*.conf文件,这些文件中可以定义更多的域名解析规则,这些规则的优先级高于dnsmasq.conf文件。
  3. 如果以上解析步骤都没有找到对应的解析结果,dnsmasq会查询上游DNS服务器,即在resolv.dnsmasq.conf文件中定义的DNS服务器。

如果你不想使用hosts文件进行解析,可以在/etc/dnsmasq.conf中添加no-hosts语句,这样dnsmasq将直接查询上游DNS服务器。同样,如果你不想进行上游查询,可以添加no-resolv语句。

(3)重要参数说明

下面是一些经常修改的重要参数说明:

参数说明
resolv-file定义dnsmasq从哪里获取上游DNS服务器的地址,默认从/etc/resolv.conf获取。
strict-order表示严格按照resolv-file文件中的顺序从上到下进行DNS解析,直到第一个解析成功为止。
listen-address定义dnsmasq监听的地址,默认是监控本机的所有网卡上。
address启用泛域名解析,即自定义解析A记录。例如:address=/long.com/192.168.115.10,访问long.com时的所有域名都会被解析成192.168.115.10
bogus-nxdomain对于任何被解析到此IP的域名,将响应NXDOMAIN使其解析失效。可以多次指定,通常用于对于访问不存在的域名,禁止其跳转到运营商的广告站点。
server指定使用哪个DNS服务器进行解析,对于不同的网站可以使用不同的域名对应解析。例如:server=/google.com/8.8.8.8表示对于google.com的服务,使用谷歌的DNS解析。

(4)部署dnsmasq

以下是在CentOS 7上安装和配置dnsmasq的示例步骤:

  1. 安装dnsmasq:

    yum install -y dnsmasq
    
  2. 修改dnsmasq配置文件/etc/dnsmasq.conf

    vi /etc/dnsmasq.conf
    

    在配置文件中添加以下内容:

    strict-order
    cache-size=10000
    resolv-file=/etc/resolv.dnsmasq.conf
    addn-hosts=/etc/dnsmasq/hosts
    listen-address=10.0.0.35
    log-facility=/data/dnsmasq_log/dnsmasq.log
    
  3. 创建dnsmasq的hosts文件:

    cp /etc/hosts /etc/dnsmasq/hosts
    
  4. 修改网卡的DNS配置文件(例如ifcfg-eth0):

    vi /etc/sysconfig/network-scripts/ifcfg-eth0
    

    在配置文件中添加以下内容:

    DNS1=223.5.5.5
    DNS2=8.8.8.8
    
  5. 填写上游DNS服务器IP:

    vim /etc/resolv.dnsmasq.conf
    

    在文件中添加以下内容:

    nameserver 8.8.8.8
    nameserver 223.5.5.5
    
  6. 启动dnsmasq服务:

    systemctl enable dnsmasq
    systemctl start dnsmasq
    systemctl stop dnsmasq
    
  7. 验证配置是否生效:

    dig www.baidu.com
    

    如果配置生效,将会返回与www.baidu.com相关的DNS解析结果。

  8. 或者使用pc客户端,配置dns服务器IP为DNS尝试解析

(5)其他内容

  • cache-size:设置dnsmasq的DNS缓存条目数量,默认为150条。可以通过设置为0来禁用缓存。
  • dns-forward-max:指定DNS同属查询转发的最大数量。
  • address:除了用于解析A记录之外,还可以用于解析CNAME、MX、NS等记录类型。
  • bogus-nxdomain:可以用于阻止某些域名被解析到特定的IP地址,从而使其解析失效。
  • server:可以根据不同的域名指定不同的DNS服务器进行解析,这样可以实现灵活的解析策略。

(6)域名劫持

hosts文件除了用于本地域名解析外,还可以用于域名劫持。

什么是域名劫持?

域名劫持是指将特定域名解析到指定的IP地址,从而实现对该域名的控制。

通过在hosts文件中添加域名和IP地址的映射关系,可以将特定域名解析到指定的IP地址,而不是通过DNS服务器进行解析。这样可以实现对该域名的劫持,将用户的访问重定向到指定的IP地址上。

域名劫持通常用于以下情况:

  1. 广告屏蔽:可以将广告域名解析到一个不存在的IP地址上,从而屏蔽广告内容。
  2. 网络安全:可以将恶意域名解析到一个安全的IP地址上,阻止恶意软件的访问。
  3. 内部测试:可以将域名解析到内部测试服务器上,用于开发和测试目的。

例如,假设我们想将内网的某个服务通过域名,映射在dnsmasq服务器上,域名为www.joshzhong.com劫持到IP地址192.168.1.100,可以在hosts文件中添加以下条目:

192.168.31.100   www.joshzhong.com

内网终端配置dnsmasq服务器IP为dns服务器,那么当用户访问www.joshzhong.com时,系统会首先检查访问dnsmasq的hosts文件,发现了对应的映射关系,就直接将其解析为192.168.31.100,而不会向DNS服务器发起解析请求。

(7)dns污染验证

1、获取dig和nc工具

要在CentOS上获取dig和nc工具,可以使用以下命令进行安装:

# 安装dig工具
yum -y install bind-utils# 安装nc工具
yum -y install nc

以上命令将通过yum包管理器安装所需的工具。

2、验证DNS污染

一旦安装了dig和nc工具,你可以使用它们来验证DNS是否被污染。下面是一些示例命令:

# 通过114解析google域名
dig google.com @114.114.114.114 +short# 检测IP是否属于Google
echo -e 'begin\n142.251.42.238\nend' | nc bgp.tools 43

第一个命令使用dig工具以114.114.114.114为DNS服务器解析google.com域名,并显示结果。

第二个命令使用nc工具连接到bgp.tools的43端口,并发送IP地址。这将返回与该IP地址相关的网络信息,包括运营商。

如果第二个命令返回的运营商不是"Google LLC",则可以判断DNS被污染。

通过使用这些工具,你可以验证DNS是否被污染,并采取相应的措施来解决问题。

(8)dnsmasq优化

记录一下,之前通过设置不同地域的dns,来针对不同业务进行访问,确实又起到加速作用。

如果你使用国内的VPS来搭建本地DNS服务器,可以提高DNS响应速度并增加稳定性。以下是修改DNS配置和网络设置的步骤,以下通过内网10.0.0.35为例。请注意,这些配置仅供参考:

  1. 修改网卡配置:打开网卡配置文件进行编辑。
vi /etc/sysconfig/network-scripts/ifcfg-em2
  1. 修改上游DNS配置:打开resolv.conf文件进行编辑。
vi /etc/resolv.conf

在文件中添加以下内容:

nameserver 8.8.8.8
nameserver 223.5.5.5
nameserver 8.8.4.4

请按照这个顺序进行配置,以测试国内速度是否提升。

  1. 修改dnsmasq配置:打开dnsmasq.conf文件进行编辑。
vi /etc/dnsmasq.conf

根据你的需求,对文件进行相应的修改。

  1. 修改hosts文件:打开hosts文件进行编辑。
vi /etc/dnsmasq/hosts

根据你的需求,对文件进行相应的修改。例如,你可以将10.0.0.30的hosts文件复制到10.0.0.35,并重启dnsmasq服务,以实现对Google的正常访问。

  1. 修改ROS策略:在ROS的IP防火墙策略中,打开DNS服务器的IP设置。例如,国内流量走fenliu2,国外流量走fenliu10(SDWAN)。

  2. 验证:通过访问网站http://ip111.cn/进行验证。

当DNS解析正常时,将显示从Google测试获取的IP地址。如果测试不正常,可能会显示空白,并且无法打开google.com。

请根据你的具体需求和环境进行相应的配置和验证,以上内容仅供参考。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/218395.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Git 小妙招】走进 Git 的分支管理(万字图文讲解)

文章目录 前言1. 理解分支2. 创建分支3. 切换分支4. 合并分支5. 删除分支6. 合并冲突7. 分支管理策略7.1 一个简单的分支策略(仅参考) 8. bug 分支9. 删除临时分支总结 前言 本文开始介绍 Git 的杀手级功能之⼀:分⽀。本文涉及分⽀创建,切换&#xff0c…

16:00的面试,16:07就出来了,问的问题过于变态了。。。

从小厂出来,没想到在另一家公司又寄了。 到这家公司开始上班,加班是每天必不可少的,看在钱给的比较多的份上,就不太计较了。没想到六月一纸通知,所有人不准加班,加班费不仅没有了,薪资还要降40…

选择排序

本题要求从键盘读入n个整数,对这些数做选择排序。输出选择排序每一步的结果和最终结果。 输入格式: 输入的第一行是一个正整数n,表示 在第二行中会有n个整数。 输出格式: 输出选择排序每一步的结果和最终结果。 输入样例: 在这里给出一组输入。例如…

园区网络虚拟化应该这样建

下午好,我的网工朋友。 今天和你聊聊怎么建立园区网络虚拟化。 区别于传统园区关注独立的单台设备,虚拟化网络关注全网的整体业务体验,通过iMaster NCE-Campus和VXLAN技术,实现网络资源能够任意灵活调度。 通过虚拟化技术&…

【Redis】深入理解 Redis 常用数据类型源码及底层实现(1.结构与源码概述)

在文章【Redis】不卡壳的 Redis 学习之路:从十大数据类型开始入手中我们介绍了Redis常用的10大数据类型,这10大数据类型可并不是直接在底层通过代码实现的,而是通过不同的底层数据结构组合起来的,这篇我们介绍下Redis常用数据类型…

C++静态成员数据

静态成员数据初始化 #include <iostream> class MyClass { public: static int staticVar; // 声明静态变量 static void staticFunction() { std::cout << "This is a static function." << std::endl; } void regularFunction() { std…

three.js纹理贴图不清晰,颜色失真

一. 贴图不清晰 给渲染器加一些配置选项&#xff1a; // 初始化渲染器let renderer new THREE.WebGLRenderer({antialias: true, //抗锯齿// alpha: true})renderer.setPixelRatio(window.devicePixelRatio) // 设置像素比二. 颜色失真 let texture new THREE.Texture…

CSAPP——linux下的 status 函数及进程退出/进程回收详解

status函数是一个系统调用&#xff0c;用于获取子进程的退出状态。它通常在父进程中使用&#xff0c;以便检查子进程是否正常退出或出现错误。 status函数的原型如下&#xff1a; int waitpid(pid_t pid, int *status, int options); pid参数指定要等待的子进程的进程ID stat…

排序算法——快速排序

快速排序是计算机科学中最著名和广泛使用的排序算法之一。自1960年由英国计算机科学家托尼霍尔&#xff08;Tony Hoare&#xff09;发明以来&#xff0c;它以其高效率和简洁的实现而闻名。在本文中&#xff0c;我们将深入探讨快速排序的工作原理、其优缺点&#xff0c;并提供一…

网络安全这条路,如何打怪升级干掉大Boss?

企业对网络安全的重视是挂在嘴上还是落实在行动中&#xff1f;网络安全人员岗位设置是否合理而有效&#xff1f;网络安全从业者最需要什么样的技能培训&#xff1f;网络安全从业者的职业发展路径应该如何规划&#xff1f;一份“网络安全从业人员现状调查”报告&#xff0c;解你…

解决Hbase报错:ERROR: Can‘t get master address from ZooKeeper; znode data == null

文章目录 问题描述解决方案 问题描述 报错了&#xff1a;这啥公司啊&#xff0c;怎么给的文档怎么错这么多&#xff0c;起一服务&#xff0c;集群里总有几个组件报错 继上次Flume 脚本&#xff0c;使用hdfs sink报错了以后&#xff0c;hbase又报错了&#xff0c;报错提示如下&…

与OA完美契合的开放式低代码平台

随着企业数字化转型的加速&#xff0c;越来越多的企业开始寻求能够快速适应业务需求变化、降低IT成本、提高运营效率的信息系统解决方案。OA作为面向企业日常办公需求的信息系统&#xff0c;在提高企业内部协作效率、优化业务流程、降低运营成本方面具有重要的作用。 它涵盖了…

山西电力市场日前价格预测【2023-12-13】

日前价格预测 预测说明&#xff1a; 如上图所示&#xff0c;预测明日&#xff08;2023-12-13&#xff09;山西电力市场全天平均日前电价为331.79元/MWh。其中&#xff0c;最高日前电价为371.77元/MWh&#xff0c;预计出现在11:15。最低日前电价为280.66元/MWh&#xff0c;预计…

OpenHarmony 如何去除系统锁屏应用

前言 OpenHarmony源码版本&#xff1a;4.0release / 3.2 release 开发板&#xff1a;DAYU / rk3568 一、3.2版本去除锁屏应用 在源码根目录下&#xff1a;productdefine/common/inherit/rich.json 中删除screenlock_mgr组件的编译配置&#xff0c;在rich.json文件中搜索th…

Vue中使用echarts@4.x中国地图及AMap相关API的使用

一、此 demo 实现的基本功能 1.中国地图的显示 2.地图点击下钻的功能 3.地图相关组件的使用&#xff0c;例 tooltip… 二、实现思路 初始使用下载本地的中国 geo 格式的 json 数据来绘制地图&#xff0c;点击某一区划&#xff08;例&#xff1a;山东省&#xff09;时&#xff0…

Android13 不能静态注册的几个广播

Android13 不能静态注册的几个广播 文章目录 Android13 不能静态注册的几个广播一、不能静态注册的广播:二、静态注册无法生效的分析1、Intent.java2、其他地方声明了不能静态注册的广播3、为啥静态注册的广播无效&#xff1f;4、其他静态注册无法生效的广播5、其他Android fra…

LeeCode刷题

寻找数组的中心下标 给定一个整数nums&#xff0c;请编写一个能够返回数组“中心下标”的方法 中心下标是数组的一个下标&#xff0c;其左侧所有元素相加的和等于右侧所有元素相加的和。如果数组不存在中心下标&#xff0c;返回-1.如果数组右多个中心下标&#xff0c;应该返回…

C#中UDP的简单使用+样例

发送&#xff1a; udpClient.Send(bytes, bytes.Length, "127.0.0.1", 11001); --发送的数据是byte类型&#xff0c;指定ip和端口 接收&#xff1a; public MainWindow() {InitializeComponent();udpClient new UdpClient(11001); // 监听端口11001Task.Run(() &g…

SQL Update语句

SQL Update语句 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; SQL Update语句&#xff1a;数据库操作高招解析 数据库是我们搭建查券返利机器人的重要组成部分&…

【计算机设计大赛】冬残奥会可视化系统_附源码—信息可视化赛道获奖项目深入剖析【可视化项目案例-19】

🎉🎊🎉 你的技术旅程将在这里启航! 记得看本专栏里顶置的可视化宝典导航贴哦! 🚀🚀 本专栏为可视化专栏,包含现有的所有可视化技术。订阅专栏用户在文章底部可下载对应案例完整源码以供大家深入的学习研究。 🎓 每一个案例都会提供完整代码和详细的讲解,不论你…