动态dns有什么好处_动态DNS设置

动态dns有什么好处_动态DNS设置1.核心思想配置动态DNS服务器的核心思想是:在DNS服务器上运行多个BIND,每个BIND为来自不同区域的用户提供解析,因此每个BIND都应具有不同的配置文件和域文件,并且分别监听在不同的端口。在

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1.核心思想        配置动态DNS服务器的核心思想是:在DNS服务器上运行多个BIND,每个BIND为来自不同区域的用户提供解析,因此每个BIND都应具有不同的配置文件和域文件,并且分别监听在不同的端口。在接到客户端DNS请求时,根据客户的ip地址将请求重定向不同的BIND服务端口。BIND响应时,再改写相应包的服务端口为标准的53端口。这样就可以根据客户端的ip地址将不同的解析结果返回给客户端。整个过程对于客户端来说都是透明的。实现的关键在于运行不同的BIND及运用iptables进行ip地址及端口改写操作。        关于iptables更为详细的信息,请参考解决方案中作者的两篇文章——《用iptales实现包过虑型防火墙》及《用iptables实现NAT》。      2.配置过程      2.1.配置内核        netfilter要求内核版本不低于2.3.5,在编译新内核时,要求选择和netfilter相关的项目。这些项目通常都是位于”Networking options”子项下。以2.4.0内核为例,我们应该选中的项目有:      [*] Kernel/User netlink socket   [ ] Routing messages   <*> Netlink device emulation   [*] Network packet filtering (replaces ipchains)   …….        然后,在”IP: Netfilter Configuration —->”选中:       Connection tracking (required for masq/NAT)    FTP protocol support    IP tables support (required for filtering/masq/NAT)    limit match support    MAC address match support    Netfilter MARK match support    Multiple port match support    TOS match support    Connection state match support    Packet filtering    REJECT target support    Full NAT    MASQUERADE target support    REDIRECT target support    Packet mangling    TOS target support    MARK target support    LOG target support    ipchains (2.2-style) support    ipfwadm (2.0-style) support        其中最后两个项目可以不选,但是如果你比较怀念ipchains或者ipfwadm,你也可以将其选中,以便在2.4内核中使用ipchians或ipfwadm。但是需要注意的是,iptables是和ipchians/ipfwadm相对立的,在使用iptables的同时就不能同时使用ipchains/ipfwadm。编译成功后,这些模块文件都位于以下目录中   /lib/modules/2.4.0/kernel/net/ipv4/netfilter        编译2.4.0的新内核时还应该注意要在”Processor type and features”中选择和你的CPU相对应的正确的CPU选项,否则新内核可能无法正常工作。      2.2.配置BIND服务        缺省地,BIND服务监听在53端口,我们可以通过配置让BIND运行在不同的ip及端口上。实现这一点并不复杂,假设我们的DNS服务器的ip地址是211.163.76.1,并且我们想区分CERNET及非CERNET的客户,这时我们必须运行两个BIND,使用不同的配置文件。可以在使用非标准监听端口的BIND的配置文件中用listen-on指定BIND监听的端口,比如:      options {   listen-on port 54 {211.163.76.1;}   directory “/var/named_cernet”;   };        可以用named的-c 选项指定named读入不同的配置文件,比如:      /usr/sbin/named -u named -c /etc/named_cernet.conf      2.3.配置重定向规则        假设监听在标准端口的BIND服务器为非CERNET客户提供DNS解析,监听在54端口的BIND服务器为CERNET服务器提供DNS解析,我们可以建立如下的规则脚本:      #!/bin/bash   #打开端口转发   echo 1 > /proc/sys/net/ipv4/ip_forward      #加载相关的内核模块   /sbin/modprobe iptable_filter   /sbin/modprobe ip_tables   /sbin/modprobe iptables_nat      #刷新所有规则   /sbin/iptables -t nat -F      #加入来自CERNET的DNS请求转发规则,将其转发到本地54端口,    #CERNET地址列表可从www.nic.edu.cn/RS/ipstat/获得   /sbin/iptables -t nat -A PREROUTING -p udp -s 163.105.0.0/16        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p tcp -s 163.105.0.0/16        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p udp -s 166.111.0.0/16        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p tcp -s 166.111.0.0/16        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.4.128.0/19        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p tcp -s 202.4.128.0/19        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.112.0.0/15        –dport 53 -i eth0 -j REDIRECT 54   /sbin/iptables -t nat -A PREROUTING -p tcp -s 202.112.0.0/15        –dport 53 -i eth0 -j REDIRECT 54   …      #将返回给CERNET DNS客户数据包的源端口(54端口)伪装成53端口   /sbin/iptables -t nat -A POSTROUTING -p udp       –sport 54 -o eth0 -j SNAT –to 211.163.76.1:53   /sbin/iptables -t nat -A POSTROUTING -p tcp       –sport 54 -o eth0 -j SNAT –to 211.163.76.1:53      脚本   #!/bin/bash            DNS_IP=211.163.76.1   CNET_PORT=54      #打开端口转发   echo 1 > /proc/sys/net/ipv4/ip_forward   #加载相关的内核模块   /sbin/modprobe iptable_filter   /sbin/modprobe ip_tables   /sbin/modprobe iptables_nat   #刷新所有规则   /sbin/iptables -t nat -F      #加入来自CERNET的DNS请求转发规则,将其转发到本地54端口,CERNET地址列表可从#www.nic.edu.cn/RS/ipstat/获得   /sbin/iptables -t nat -A PREROUTING -p udp -s 162.105.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 166.111.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.4.128.0/19 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.112.0.0/15 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.38.96.0/19 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.204.0.0/14 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 210.25.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 210.31.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 211.68.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 211.71.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT      /sbin/iptables -t nat -A PREROUTING -p udp -s 202.200.0.0/15 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 210.26.0.0/15 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT      /sbin/iptables -t nat -A PREROUTING -p udp -s 202.115.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.202.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 210.40.0.0/15 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.203.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT      /sbin/iptables -t nat -A PREROUTING -p udp -s 202.116.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.192.0.0/15 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 210.36.0.0/14 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 202.38.192.0/18 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT   /sbin/iptables -t nat -A PREROUTING -p udp -s 211.66.0.0/16 –dport 53 -i eth0 -j REDIRECT –to-port $CNET_PORT      /sbin/iptables -t nat -A PREROUTING -p

(责任编辑:kiah)

http://www.dnstx.com/DNS/dnstech/2011083024.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167323.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IDEA 2022.01.12激活码【中文破解版】「建议收藏」

    (IDEA 2022.01.12激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~40…

    2022年4月2日
    105
  • 银行风控模型

    银行风控模型风控催生原因对于银行来说,现今互联网贷款和信用卡办理面临的主要难题是数据和风控。站在银行或金融机构角度,自然而然是想获得更多的信息和数据,但是在收集数据这方面又是比较无力的。加上当下的发展趋势,消费贷以及贷款审批速度都要求快。如何在快的的过程中对客户进行一个全面的审查,得出一个合理的结果呢?如果没有详细的数据对客户进行评估,这势必会提高放贷的风险。风控概述所谓风控,是指多银行贷款资金的…

    2022年6月13日
    38
  • python变量命名规则

    python变量命名规则在Python中,变量标记或指向一个值。当遇到变量时,Python将其替换为指向值。>>>cost=2.99>>>.1*cost0.29900000000000

    2022年7月6日
    23
  • Oracle与MySQL区别「建议收藏」

    Oracle与MySQL区别「建议收藏」1、Oracle是大型数据库,而MySQL是中小型数据库。但是MySQL是开源的,Oracle是收费的2、Oracle的内存占有量非常大,而mysql非常小3、MySQL支持主键自增长,插入时会自动增长。Oracle主键一般使用序列。4、MySQL分页用limit关键字,而Oracle使用rownum字段表明位置5、MySQL中0、1判断真假,Oracle中truefalse6、MySQL中命令默认commit,但是Oracle需要手动提交7、MySQL在windows环境下大小写不敏感,在l

    2025年11月17日
    5
  • Java读取文件的四种方式

    Java读取文件的四种方式 按字节读取文件内容 按字符读取文件内容 按行读取文件内容 随机读取文件内容    publicclassReadFromFile{/***以字节为单位读取文件,常用于读二进制文件,如图片、声音、影像等文件。*/publicstaticvoidreadFileByBytes(StringfileN…

    2022年7月26日
    7
  • Spring Cloud 微服务架构图「建议收藏」

    Spring Cloud 微服务架构图「建议收藏」SpringCloud微服务总体架构图上面图中技术名词理解:1、Sleuth-链路跟踪为服务之间调用提供链路追踪。通过Sleuth可以很清楚的了解到一个服务请求经过了哪些服务,每个服务处理花费了多长。从而让我们可以很方便的理清各微服务间的调用关系。2、断路器(Hystrix)在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调…

    2022年4月30日
    71

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号