当前位置: 首页 > article >正文

实战指南:在CentOS 8上部署与配置BIND DNS权威服务器

1. 为什么要在CentOS 8上搭建DNS服务器想象一下这样的场景公司内部有几十台服务器每次新同事入职都要发一份IP地址对照表开发团队每次联调测试都要反复确认服务地址运维人员排查问题时要在记事本里翻找各种192.168.x.x的地址。这种时候一个私有DNS服务器就像给局域网装上了导航系统让所有设备都能通过像gitlab.corp.internal、jenkins.corp.internal这样易记的域名互相访问。BINDBerkeley Internet Name Domain作为最老牌的DNS软件至今仍占据着75%以上的权威DNS服务器市场份额。我在实际企业环境中部署过不下20次BIND服务发现它最突出的三个优势配置灵活度高支持各种复杂解析规则、日志系统完善便于排查解析问题、社区支持强大遇到问题基本都能找到解决方案。最新版的BIND 9.16还增加了响应策略区RPZ功能可以轻松实现内部域名黑名单。在CentOS 8上部署时要注意与CentOS 7相比有两个关键变化一是默认使用dnf替代yum作为包管理器二是防火墙工具firewalld的配置方式有所调整。不过别担心接下来我会用最直白的操作演示带你避开所有坑。2. 环境准备与BIND安装2.1 系统基础配置先来个必做的热身动作——更新系统。我遇到过三次因为没更新系统导致依赖冲突的情况所以请务必执行sudo dnf update -y sudo reboot接着检查SELinux状态很多配置失败都是因为它多管闲事sestatus如果显示Enforcing建议先切换为宽松模式sudo setenforce 0 sudo sed -i s/SELINUXenforcing/SELINUXpermissive/g /etc/selinux/config2.2 安装BIND组件CentOS 8的AppStream仓库已经包含BIND 9.11运行这条命令安装全家桶sudo dnf install bind bind-utils -y这里解释下各包作用bind主服务程序bind-utils包含dig、nslookup等诊断工具bind-chroot可选安全沙箱环境安装完成后检查版本named -v # 预期输出BIND 9.11.26-RedHat-9.11.26-6.el83. 配置权威DNS区域3.1 主配置文件详解打开/etc/named.conf你会看到一个满屏都是符号的配置文件。别慌其实核心就三部分sudo vi /etc/named.conf找到options块修改为以下安全配置options { listen-on port 53 { any; }; directory /var/named; dump-file /var/named/data/cache_dump.db; statistics-file /var/named/data/named_stats.txt; memstatistics-file /var/named/data/named_mem_stats.txt; allow-query { 192.168.0.0/16; }; // 只允许内网查询 recursion no; // 关闭递归查询 dnssec-enable yes; dnssec-validation yes; };重点参数说明allow-query比旧教程中的any更安全限定只允许公司内网段查询recursion no防止服务器被当作开放解析器滥用dnssec开启DNS安全扩展3.2 创建正向解析区域在named.conf末尾添加你的私有域例如corp.internalzone corp.internal IN { type master; file db.corp.internal; allow-update { none; }; };然后创建区域文件sudo vi /var/named/db.corp.internal写入以下内容注意每行结尾的分号$TTL 1D IN SOA ns1.corp.internal. admin.corp.internal. ( 2024022001 ; serial 3H ; refresh 1H ; retry 1W ; expire 1D ) ; minimum IN NS ns1.corp.internal. IN MX 10 mail.corp.internal. ns1 IN A 192.168.1.100 mail IN A 192.168.1.200 gitlab IN A 192.168.1.50 jenkins IN A 192.168.1.51 wiki IN CNAME gitlab关键记录类型解释SOA起始授权记录包含序列号每次修改要1NS指明该域的DNS服务器MX邮件服务器地址数字10表示优先级A最基础的IP指向记录CNAME别名记录wiki指向gitlab4. 服务管理与排错4.1 启动与防火墙配置先检查配置文件语法sudo named-checkconf sudo named-checkzone corp.internal /var/named/db.corp.internal设置开机启动并立即运行sudo systemctl enable --now named开放防火墙端口CentOS 8需要同时放行TCP/UDPsudo firewall-cmd --permanent --add-servicedns sudo firewall-cmd --reload4.2 验证DNS解析在公司另一台电脑上测试将DNS服务器设为192.168.1.100nslookup gitlab.corp.internal 192.168.1.100 # 预期输出192.168.1.50 dig mx corp.internal 192.168.1.100 # 应看到mail.corp.internal的MX记录如果解析失败按这个顺序排查检查systemctl status named有无错误用journalctl -u named -f查看实时日志确认客户端/etc/resolv.conf是否配置正确5. 高级配置技巧5.1 配置DNS转发器当需要解析外部域名时可以设置转发到公共DNS。编辑/etc/named.confoptions { // ...原有配置... forwarders { 114.114.114.114; 223.5.5.5; }; forward only; };这会让BIND把非本地域名的查询转发给阿里云DNS。5.2 实现简单的负载均衡通过轮询机制分配请求webcluster IN A 192.168.1.101 webcluster IN A 192.168.1.102 webcluster IN A 192.168.1.103客户端查询时会随机返回其中一个IP实测能有效分散前端服务器压力。5.3 日志分析配置在named.conf中添加logging { channel query.log { file /var/named/log/query.log versions 5 size 20m; severity debug 3; }; category queries { query.log; }; };然后创建日志目录sudo mkdir /var/named/log sudo chown named:named /var/named/log通过分析日志可以清晰看到哪些客户端在频繁查询帮助识别异常行为。

相关文章:

实战指南:在CentOS 8上部署与配置BIND DNS权威服务器

1. 为什么要在CentOS 8上搭建DNS服务器? 想象一下这样的场景:公司内部有几十台服务器,每次新同事入职都要发一份IP地址对照表;开发团队每次联调测试都要反复确认服务地址;运维人员排查问题时要在记事本里翻找各种192.1…...

cobalt代码覆盖率报告:提升测试质量的关键指标

cobalt代码覆盖率报告:提升测试质量的关键指标 【免费下载链接】cobalt best way to save what you love 项目地址: https://gitcode.com/GitHub_Trending/cob/cobalt 引言:为什么代码覆盖率(Code Coverage)至关重要 在现…...

从编译错误到成功运行:手把手教你用CMake在Ubuntu 20.04上部署GeographicLib地理计算库

从编译错误到成功运行:手把手教你用CMake在Ubuntu 20.04上部署GeographicLib地理计算库 在Linux环境下部署开源库时,许多开发者会直接复制粘贴教程中的命令,却对背后的构建原理一知半解。以GeographicLib为例,这个被广泛应用于地理…...

Blender 3MF插件技术解析与进阶指南:从格式原理到工业级应用

Blender 3MF插件技术解析与进阶指南:从格式原理到工业级应用 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat Blender 3MF插件是连接开源3D创作与工业级3D打印…...

Godep依赖自动发现机制:Go项目依赖管理的终极指南

Godep依赖自动发现机制:Go项目依赖管理的终极指南 【免费下载链接】godep dependency tool for go 项目地址: https://gitcode.com/gh_mirrors/go/godep Godep作为Go语言早期经典的依赖管理工具,通过自动发现与追踪项目依赖,为Go开发者…...

FUTURE POLICE语音模型重装系统后快速恢复部署指南

FUTURE POLICE语音模型重装系统后快速恢复部署指南 重装系统这事儿,对开发者来说,有时候就跟电脑的“大扫除”一样,图个干净利落。但扫除完,看着空空如也的桌面和命令行,要重新把那些吃饭的家伙——比如你正在跑的FUT…...

封神级C++设计:用3个成员实现可清空、可恢复、零开销的容器(颠覆传统思维)

封神级C设计:用3个成员实现可清空、可恢复、零开销的容器(颠覆传统思维) 文章目录封神级C\\设计:用3个成员实现可清空、可恢复、零开销的容器(颠覆传统思维)一、传统方案的“坑”:要么笨重&…...

Phi-4-mini-reasoning实操手册:vLLM日志分析与常见加载失败排障指南

Phi-4-mini-reasoning实操手册:vLLM日志分析与常见加载失败排障指南 1. 模型简介 Phi-4-mini-reasoning是一个基于合成数据构建的轻量级开源模型,专注于高质量、密集推理的数据处理能力。作为Phi-4模型家族的一员,它经过专门微调以提升数学…...

如何快速实现ngx-bootstrap国际化:多语言应用开发完整指南

如何快速实现ngx-bootstrap国际化:多语言应用开发完整指南 【免费下载链接】ngx-bootstrap Fast and reliable Bootstrap widgets in Angular (supports Ivy engine) 项目地址: https://gitcode.com/gh_mirrors/ng/ngx-bootstrap ngx-bootstrap作为Angular生…...

STM32驱动SG90舵机:从PWM原理到蓝牙远程控制实战

1. 认识SG90舵机与PWM控制 第一次拿到SG90这个小家伙时,我差点以为是个玩具电机。直到把它接上STM32,看到它能精准地停在指定角度,才意识到这玩意儿在机器人、智能家居里有多实用。SG90是一种微型舵机,三根线分别接电源&#xff0…...

GLM-OCR实操手册:Web界面上传PNG/JPG/WEBP三格式兼容性验证与建议

GLM-OCR实操手册:Web界面上传PNG/JPG/WEBP三格式兼容性验证与建议 1. 项目概述与测试背景 GLM-OCR是一个基于先进多模态架构的OCR识别模型,专门为处理复杂文档而设计。它不仅能识别普通文字,还能准确识别表格结构和数学公式,在实…...

Phi-4-mini-reasoning惊艳效果:线性代数矩阵运算推理全过程展示

Phi-4-mini-reasoning惊艳效果:线性代数矩阵运算推理全过程展示 1. 模型概述 Phi-4-mini-reasoning是一款仅有3.8B参数的轻量级开源模型,专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这款模型由微软Azure AI Foundry开发,主打"…...

STM32CubeMX实战指南:从零搭建HAL库项目与LED控制

1. STM32CubeMX与HAL库开发入门 第一次接触STM32开发的朋友可能会被各种专业术语吓到——寄存器、固件库、HAL库、时钟树配置... 作为一个从51单片机转战STM32的"过来人",我完全理解这种困惑。三年前我刚开始用STM32F103时,光是搭建开发环境就…...

Swin2SR多帧超分:视频序列的时空信息融合

Swin2SR多帧超分:视频序列的时空信息融合 1. 引言 你有没有遇到过这样的情况:从监控录像中截取的关键画面模糊不清,或者老视频中的珍贵片段分辨率太低,无法看清细节?传统单帧超分技术往往力不从心,因为它…...

别再死记硬背了!用这5个真实运维脚本,搞定90%的Shell面试题

5个实战Shell脚本:从面试题到真实运维场景的蜕变 在技术面试中,Shell脚本能力往往是区分普通候选人和优秀候选人的关键指标。但死记硬背面试题答案的时代已经过去,现代企业更看重候选人解决实际问题的能力。本文将带你通过5个真实运维场景中的…...

Phi-3-Mini-128K高性能推理优化:深入理解WSL2下的GPU资源调配

Phi-3-Mini-128K高性能推理优化:深入理解WSL2下的GPU资源调配 1. 引言 如果你是一位在Windows上搞AI开发的伙伴,可能早就受够了原生环境里那些烦人的依赖冲突和性能瓶颈。我也是这么过来的,直到开始用WSL2,感觉像是打开了新世界…...

避坑指南:在FPGA上实现DP SST协议时,最容易搞错的BS/SR时序与填充规则

FPGA实战避坑:DP SST协议中BS/SR时序与填充规则的7个致命误区 DisplayPort单流传输(SST)协议在FPGA实现过程中,那些看似简单的BS(Blanking Start)和SR(Scrambler Reset)时序规则,往往成为视频流异常的罪魁祸首。去年在为某8K视频采集卡调试DP…...

从混淆矩阵到Kappa系数:实战解析土地利用分类精度评估全流程

1. 土地利用分类精度评估入门指南 当你完成了一张精美的土地利用分类图,最常被问到的问题往往是:"这个结果到底有多准?"作为从业多年的GIS分析师,我见过太多人只关注分类过程却忽视精度验证,最后在项目汇报时…...

【Mojo-Python互操作黄金标准】:基于CPython 3.12+Mojo 0.5.2的ABI兼容性白皮书(仅限首批200名开发者获取)

第一章:Mojo-Python互操作的ABI兼容性基石Mojo 语言设计之初即明确将 Python 生态无缝集成作为核心目标,其 ABI(Application Binary Interface)兼容性并非运行时桥接或胶水层模拟,而是通过底层统一的 CPython 对象模型…...

Sqitch 实战教程:如何在 PostgreSQL 中管理数据库变更

Sqitch 实战教程:如何在 PostgreSQL 中管理数据库变更 【免费下载链接】sqitch Sensible database change management 项目地址: https://gitcode.com/gh_mirrors/sq/sqitch Sqitch 是一款功能强大的数据库变更管理工具,专为 PostgreSQL 等数据库…...

QRCoder:开发者必备的二维码生成解决方案全攻略

QRCoder:开发者必备的二维码生成解决方案全攻略 【免费下载链接】QRCoder A pure C# Open Source QR Code implementation 项目地址: https://gitcode.com/gh_mirrors/qr/QRCoder 在数字化时代,二维码已成为信息传递的重要桥梁,但如何…...

Janus-Pro-7B惊艳效果:图表理解→数据洞察→信息图生成端到端

Janus-Pro-7B惊艳效果:图表理解→数据洞察→信息图生成端到端 1. 模型概述:统一多模态的新突破 Janus-Pro-7B是DeepSeek发布的一款统一多模态理解与生成模型,真正实现了"看懂图"和"生成图"的双重能力。这个模型最大的特…...

seq2seq-couplet错误处理与敏感词过滤:保障服务稳定性的终极指南

seq2seq-couplet错误处理与敏感词过滤:保障服务稳定性的终极指南 【免费下载链接】seq2seq-couplet Play couplet with seq2seq model. 用深度学习对对联。 项目地址: https://gitcode.com/gh_mirrors/se/seq2seq-couplet seq2seq-couplet是一个基于深度学习…...

终极指南:5分钟掌握Piper鼠标地图组件与SVG渲染核心技术

终极指南:5分钟掌握Piper鼠标地图组件与SVG渲染核心技术 【免费下载链接】piper GTK application to configure gaming devices 项目地址: https://gitcode.com/gh_mirrors/pip/piper Piper是一款功能强大的GTK应用程序,专为配置游戏设备而设计。…...

TinyCheck开发指南:从源码结构到核心类设计,理解网络安全检测平台架构

TinyCheck开发指南:从源码结构到核心类设计,理解网络安全检测平台架构 【免费下载链接】TinyCheck TinyCheck allows you to easily capture network communications from a smartphone or any device which can be associated to a Wi-Fi access point …...

避坑指南:GF-3 SAR数据预处理中常见的5个错误及解决方法

GF-3 SAR数据预处理实战:5个关键错误分析与Python解决方案 在遥感数据处理领域,GF-3卫星的合成孔径雷达(SAR)数据因其全天候、全天时的观测能力而备受青睐。然而,从原始数据到可用成果的预处理过程中,即便是经验丰富的工程师也常会…...

终极指南:3分钟掌握ControlNet-v1-1_fp16_safetensors高效AI图像控制

终极指南:3分钟掌握ControlNet-v1-1_fp16_safetensors高效AI图像控制 【免费下载链接】ControlNet-v1-1_fp16_safetensors 项目地址: https://ai.gitcode.com/hf_mirrors/comfyanonymous/ControlNet-v1-1_fp16_safetensors ControlNet-v1-1_fp16_safetensor…...

现在不升级Polars 2.0清洗栈,你的ETL将在Q3面临300%延迟增长——基于AWS Graviton+Arrow 15.0实测基准报告

第一章:Polars 2.0清洗栈升级的必要性与Q3延迟危机预警Polars 2.0 的清洗栈重构并非功能叠加式演进,而是面向真实数据工程场景的范式重置。随着企业级ETL流水线中非结构化日志、嵌套JSON、时序传感器数据占比突破68%,旧版基于LazyFrame单通道…...

VMware Workstation 16开机自启踩坑实录:从环境变量报错到bat脚本优化,一篇搞定

VMware Workstation 16开机自启全攻略:从环境变量到脚本优化的深度实践 每次重启服务器后手动打开虚拟机实在是个体力活。上周我负责维护的测试环境又因为忘记启动虚拟机导致整个团队阻塞了半天,这种低级错误让我决定彻底解决VMware Workstation的开机自…...

为什么JavaScript无法访问用户电脑的硬件信息

JavaScript和硬件信息访问:安全和信任的博弈许多人想知道:为什么JavaScript不能访问用户计算机的硬件信息?答案与安全和信任机制密切相关。虽然本地客户端软件可以访问硬件信息,但这是基于用户对软件的信任和授权。浏览器和客户端…...