在LAMP环境中配置DNS解析,首先需要安装Bind(Berkeley Internet Name Domain)软件包,它是Linux系统下最常用的DNS服务器软件。
使用以下命令安装Bind及辅助工具(以CentOS/RHEL为例):
sudo yum -y install bind bind-utils
安装完成后,启动Bind服务并设置开机自启:
sudo systemctl start named
sudo systemctl enable named
Bind的主配置文件为/etc/named.conf,需修改以下关键参数以允许DNS服务正常工作:
options section,修改allow-query为允许所有客户端查询(生产环境建议限制为特定IP段,如allow-query { 192.168.1.0/24; };):options {
listen-on port 53 { any; }; # 监听所有IP的53端口
listen-on-v6 port 53 { ::1; }; # IPv6监听(可选)
directory "/var/named"; # 区域文件存放目录
allow-query { any; }; # 允许所有客户端查询
};
include "/etc/named.rfc1912.zones";未被注释,该文件用于定义具体域名区域。/etc/named.rfc1912.zones,添加一个新的正向解析区域(以example.com为例):zone "example.com" IN {
type master; # 区域类型(主DNS)
file "example.com.zone"; # 区域数据文件路径(相对于/var/named)
};
/var/named/example.com.zone文件,并添加以下内容:$TTL 86400 # TTL(生存时间),单位:秒
@ IN SOA ns.example.com. admin.example.com. ( # SOA记录(Start of Authority)
2025103001; # 序列号(每次修改需递增)
1D; # 刷新时间(1天)
1H; # 重试时间(1小时)
1W; # 过期时间(1周)
3H ); # 负面缓存时间(3小时)
@ IN NS ns.example.com. # NS记录(Name Server)
ns IN A 192.168.1.100 # A记录(域名指向服务器IP)
www IN A 192.168.1.100 # A记录(www子域名指向同一IP)
注:
ns.example.com为域名服务器名称,admin.example.com为管理员邮箱(需替换为实际值),192.168.1.100为DNS服务器IP。
named用户,避免权限问题:sudo chown -R named:named /var/named/example.com.zone
sudo chmod 640 /var/named/example.com.zone
named-checkconf检查主配置文件语法,使用named-checkzone检查区域文件语法:sudo named-checkconf
sudo named-checkzone example.com /var/named/example.com.zone
若无错误,将输出OK。sudo systemctl reload named
在客户端(或DNS服务器本身)使用nslookup或dig命令测试域名解析是否成功:
nslookup www.example.com 192.168.1.100
或
dig @192.168.1.100 www.example.com
若解析结果返回192.168.1.100,则说明DNS配置成功。
配置完DNS后,需确保LAMP中的Apache虚拟主机监听对应域名:
/etc/httpd/conf.d/example.com.conf),设置ServerName为域名:<VirtualHost *:80>
ServerName www.example.com
ServerAlias example.com
DocumentRoot /var/www/example.com
<Directory /var/www/example.com>
AllowOverride All
Require all granted
</Directory>
</VirtualHost>
sudo systemctl restart httpd
通过以上步骤,即可在LAMP环境中完成DNS解析配置,使域名指向服务器IP并访问网站。