PowerDNS调研小结

PowerDNS

作为域名解析服务,官网提供了三个组件:Authoritative\Recursor\dnsdist,分别用来作为权威服务器、域名递归解析、dns服务负载均衡来提供dns服务,每个服务独立存在,可按需部署。

https://www.powerdns.com/

Authoritative

作为权威服务器使用,仅提供域名解析服务,数据来源于配置文件指定的后端,若后端不存在或者宕机解析不可用,没有递归作用;

高可用的部署方式

1、master/slave

2、服务单机部署通过后端库的高可用提供dns的高可用服务

/etc/resolve.conf配置多个nameserver实现多个dns权威服务器的故障转移

后端(Backend)分类参考

推荐后端bind、mysql、sqlite3,当然需要根据自身需求选择合适的后端。

https://doc.powerdns.com/authoritative/backends/index.html

pdns权威个版本下载地址:https://downloads.powerdns.com/releases/

pdns不同版本的yum源地址参考:

yum install epel-release yum-plugin-priorities &&

curl -o /etc/yum.repos.d/powerdns-auth-44.repo https://repo.powerdns.com/repo-files/centos-auth-44.repo 

yum install pdns-backend-sqlite --nogpgcheck package_need_to_install 

pdns默认配置文件:/etc/pdns/pdns.conf

pdns默认日志文件:/var/log/messages

mysql配置参考


launch=gmysql
api=yes
api-key=powerdns
enable-lua-records=shared
launch=gmysql
gmysql-host=127.0.0.1
gmysql-port=3306
gmysql-user=powerdns
gmysql-password=*********
gmysql-dbname=powerdns
log-dns-details=yes
log-dns-queries=yes
query-logging=yes
receiver-threads=5
loglevel=9
setgid=pdns
setuid=pdns
webserver=yes
webserver-address=0.0.0.0
webserver-allow-from=0.0.0.0/0,::1
webserver-port=8082

sqlite3配置参考

权限问题解决:sudo chown -R pdns:pdns /var/lib/powerdns

launch=gsqlite3
gsqlite3-database=/var/lib/powerdns/pdns.sqlite3
gsqlite3-dnssec=yes

多后端配置参考

launch=gmysql,gsqlite3
gsqlite3-database=/var/lib/powerdns/pdns.sqlite3
api=yes
api-key=powerdns
enable-lua-records=shared
gmysql-host=127.0.0.1
gmysql-port=3306
gmysql-user=powerdns
gmysql-password=*******
gmysql-dbname=powerdns
gmysql-failover-mode=smart

log-dns-details=yes
log-dns-queries=yes
query-logging=yes
receiver-threads=5
loglevel=9
setgid=pdns
setuid=pdns
webserver=yes
webserver-address=0.0.0.0
webserver-allow-from=0.0.0.0/0,::1
webserver-port=8082

配置多个后端的场景,可将不通的zone或者子zone配置在不同的后端用于业务区分和数据隔离,权威在做解析时会查询所有后端知道查到记录为止,但是若一个后端出现宕机不可能,则dns在缓存到期后就不可用,不能提供failover(故障转移)功能;

如果想要实现powerdns对于多个后端自动进行故障转移,目前调研的方式可以通过pipe自定义解析脚本实现,不限制语言,通过标准输入和输出来提供给pdns数据,在自定义脚本中可以查询多个后端,当其中一个不可用后,查询另一个后端来实现故障转移;当然脚本会相对复杂,需要对没种类型的解析分别处理,同时性能和稳定性需要保证;

https://doc.powerdns.com/authoritative/backends/pipe.html

https://github.com/endreszabo/PowerDNS-Dynamic-Reverse-Backend/blob/master/pdns-dynamic-reverse-backend.py

性能调优

https://yuweizzz.github.io/post/powerdns_performance_guide/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值