动态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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 歌曲的BPM (Beat Per Minute)–每分钟节拍数[通俗易懂]

    歌曲的BPM (Beat Per Minute)–每分钟节拍数[通俗易懂]foobar2000解决舞曲挑选

    2022年8月1日
    3
  • 使用pydicom实现Dicom文件读取与CT图像窗宽窗位调整

    使用pydicom实现Dicom文件读取与CT图像窗宽窗位调整1.前言为了能够在Labelme上对Dicom图像进行编辑,这里对python环境下Dicom文件的读取进行了研究。在Dicom图像中CT的窗宽窗位是一个很重要的概念,但是找了半天在pydicom中没有相关设置函数,这里跟DCMTK还不一样。但是可以根据两个tag得到CT图像的CT值,那就是(0028|1052):rescaleintercept和(0028|1053):rescales…

    2022年6月26日
    139
  • c语言sigaction,c语言信号处理sigaction[通俗易懂]

    c语言sigaction,c语言信号处理sigaction[通俗易懂]c语言信号处理sigaction(2011-04-1823:45:19)标签:c语言信号处理sigactionsighupit分类:c信号安装函数sigaction(intsignum,conststructsigaction*act,structsigaction*oldact)的第二个参数是一个指向sigaction结构的指针(结构体名称与函数名一样,千万别弄混淆了)。在结构sig…

    2022年5月26日
    28
  • 定时器的使用_西门子定时器指令

    定时器的使用_西门子定时器指令中使用SCL语言编程的技巧前言:两年半前我就在工控网上发表了有关SCL编程的知识<<在S7300400型PLC中使用高级语言编程>>,但发表完后,即使我自己都从没有把任何使用SCL编写的程序用到实际控制中,当时的感觉是使用SCL编程到处受限,没有STL语言灵活和强大。直到最近使用施耐德的Unity软件编程,并使用这种已经国际标准化的文本语言(等同于西门子的SCL语言),才体…

    2022年10月6日
    1
  • NFS服务器搭建与配置[通俗易懂]

    NFS服务简介什么是NFS?NFS就是NetworkFileSystem的缩写,它最大的功能就是可以通过网络,让不同的机器、不同的操作系统可以共享彼此的文件。​ NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统中来看,那个远程主机的目录就好像是自己的一个磁盘分区一样,在使用上相当便利;NFS一般用来存储共享视频,图片等静态数据。NFS挂…

    2022年4月18日
    112
  • C语言实践(2016级第5周):编程思维启蒙

    C语言实践(2016级第5周):编程思维启蒙

    2022年2月21日
    34

发表回复

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

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