使用bind架设内网dns
在之前的spark on yarn集群配置中,感觉最麻烦的就是各个机器之间的网络配置了,一直想简化这部分的工作。
一开始的办法是一台机器一台机器的编辑 /etc/network/interfaces 文件和 /etc/hosts 文件使各台机器都有固定的ip和通过机器名称可以转换成对应的ip,这样一旦集群中一台机器发生变动,各台机器都要过一遍,很是麻烦。
现在一般的家用路由器上都有根据mac地址分配固定ip的功能,所以只要在路由器上配置dhcp分配的规则,将各个机器的网卡mac地址填入就可以将机器的ip固定住了。
接下来就是机器之间互相识别的事了,这里我们在集群内选定一台主机,作为dns服务器,其他的机器只要将dns服务设定为这台机器,就可以识别其他机器名称所对应的ip了。
按惯例,给出操作环境:
首先安装bind
安装完毕之后开始配置。
先要说一些基本认知:
然后我们开始配置bind,参照 ubuntu的bind中文wiki 。
修改 named.conf.local
添加一个zone节点,这里我们的zone名字是“mwnet”:
然后将“db.local”文件复制成“db.mwnet”,并修改之:
其中第5、11行就是将\"localhost\"修改成了自己的zone名称。
第12行是必须的,指定默认的域名解析到的ip,包括“ns.mwnet”的解析。
从第13行开始就是机器名称的解析了。
接着增加一个反向解析的配置,这一步必须要做,否则hdfs的datanode启动会失败。
同样修改 named.conf.local
添加一个zone节点:
然后将 db.127 文件复制成 db.192.168.3 ,并修改之:
注意这里PTR记录和 db.mwnet 里面的A记录是一一对应的。
保存修改之后重启服务。
接下来修改各台机器的dns服务器设置,需要改动 /etc/resolvconf/resolv.conf.d/base 文件:
第1行写search是为了在寻找主机的时候,自动在主机名称后面加上“.mwnet”,以便dns服务器解析。
第2行写domain是为了让本机加入\"mwnet\"域,这样完整的主机名就变成了设备名称+“.mwnet”。
第3行指定了dns服务器的地址。
需要注意的是这个改动必须重启机器后生效。
如果之前没有改动过 /etc/hosts 文件,需要注意一点就是把系统自动添加机器名称解析到127.0.1.1的记录删除,很多事情都坏在这条记录上。
Cemtos7.2内网搭建DNS服务器
192.168.1.204 DNS
192.168.1.202 nginx
(容器安装,docker安装就不赘述了)
为了方便,使用docker环境手动搭建DNS服务器,选择andyshinn/dnsmasq的docker镜像,2.75版本
查看是否创建成功
进入容器,以下内容均在容器内操作
创建代理文件并添加内容
添加解析规则
修改dnsmasq配置文件,指定使用上述两个我们自定义的配置文件
重启容器
(nginx安装不再赘述)
因为nginx要配置域名跳转,nginx要使用80端口,80端口只能使用root启动或者使用普通用户(非80端口,如9000)启动后通过端口转发将9000转发为80端口(需要开启防火墙)
配置文件/nginx/conf/nginx.conf中要包含
在/nginx/conf/conf.d目录下
jira.conf配置文件
wiki.conf配置文件
需要修改DNS配置更改为192.168.1.204 这个IP就可以了
如:win10修改DNS配置
右击wifi所在位置,选择“打开网络和‘Internet’设置”,后选择“网络和共享中心”
打开后找到连接的网络,点击网络,打开属性并将自动获取DNS修改为手动获取,如下,修改IP
点击wifi打开热点即可
BIND + LVS + Keepalived 搭建内网DNS集群-分区域响应结果,可做智能解析
本次配置的所有服务器均为虚拟机,操作系统为Centos 7.3。
本次部署的LVS是基于DR的工作模式,负载均衡调度方式使用了RR,客户端发起DNS请求是,LVS回轮询发送至每台服务器上。DNS服务器解析请求后直接返回给客户端。
在每台服务器上安装ntpdate,确保时间同步。
yum安装bind-chroot,顾名思义这个是可指定chroot的bind,比较安全。
bind-utils是bind软件提供的一组DNS工具包,里面有一些DNS相关的工具.主要有:dig,host,nslookup,nsupdate.使用这些工具可以进行域名解析和DNS调试工作.
这里开始主DNS的配置,下面是配置named.conf,默认安装的路径为/etc/named.conf
从DNS服务器安装与主DNS安装方法一样,只是在配置文件上有些改动,且不需要配置区域数据文件。
在每台机器的/etc/init.d/目录中创建一个lvsrs文件,如下:
给予文件可执行权限
将脚本设置为开机启动
采用key认证方式配置主从DNS服务
生成如下一段字符串
需要配置几个区域就生成几次。
最终配置文件
主:
主机文件 :/etc/named.rfc1912.lan.zones
主机文件 :/etc/named.rfc1912.zones
备:
备机文件 :/etc/named.rfc1912.lan.zones
备机文件 :/etc/named.rfc1912.zones
配置DNS集群只需要克隆备机,然后把named.conf的监听ip地址重新配置即可。
新DNS Server上线后,在lvs的文件内添加新IP,重启就上线完成了。
如何搭建DNS服务器?
搭建DNS服务器步骤如下:
1、安装bind服务 。
2、配置bind的主配置文件,将侦听53端口和dns请求查询设置为所有主机 。
3、配置区域文件,添加自己的域名,定义正向解析和反向解析信息 。
4、进入/var/named/目录,创建正向解析配置文件和反向解析配置文件。
5、修改正向解析配置文件,添加解析记录。
6、修改反向解析配置文件,添加反向解析记录。
7、防火墙允许53端口通过,设置服务器开机自动启动dns服务。
8、dns服务器将本机ip设置为dns地址 。
9、配置完成验证解析记录正常。
为什么要设置内网DNS
因为DNS是用来解析域名用的,DNS服务器又是网络运营商提供的所以自己在内网设立DNS的效果不会有什么变化。
DNS作用是域名到IP地址的解析,如果解析速度快的话复那开网页速度自然会提快。一般局域网不会建立内制网DNS服务,因为内网DNS作用是负责做内部的域名解析,也就是有内百部域名解析需要的话才建。
内网DNS的设置方法如下:
1、安装好DNS Server套件。
2、点击主页面左上方,可以看见DNS Server,点击,打开DNS Server套件。
3、在区域,新增,创建Master区域。
4、自定义一个域名。
5、由于暂时未设置路由器的DNS,这里将笔记本的DNS设置为DNS服务器的地址。
6、双击步骤三设置的地方,编辑源记录。
7、点击新增,选择A Type。
8、名称写www,IP地址写服务器的地址,就完成了。