• dns自动配置Shell脚本


    这个脚本用于快速配置dns,输入域名、ip即可,如果有什么特殊的配置,稍微修改一下就可以了

    代码:

    #!/bin/bash
    
    #获取url
    echo "url:"
    read url
    
    #获取ip
    echo "ip:"
    read ip
    
    #向/etc/named.rfc1912.zones尾插入
    #zone "$url" IN {
    #       type master;
    #       file "$url.zone";
    #        allow-update{ none; };
    #};
    
    cat>>/etc/named.rfc1912.zones<<EOF
    
    zone "$url" IN {
           type master;
           file "$url.zone";
           allow-update{ none; };
    };
    EOF
    
    #复制生成文件
    cp -a /var/named/named.localhost /var/named/${url}.zone
    
    #向/var/named/${url}.zone中插入
    #$TTL 1D
    #@      IN SOA  $url admin.$url. (
    #                                       0       ; serial
    #                                       1D      ; refresh
    #                                       1H      ; retry
    #                                       1W      ; expire
    #                                       3H )    ; minimum
    #       NS      datav.aliyuncs.com.
    #       A       $ip
    
    
    cat>/var/named/${url}.zone<<EOF
    $TTL 1D
    @       IN SOA  $url admin.$url. (
                                            0       ; serial
                                            1D      ; refresh
                                            1H      ; retry
                                            1W      ; expire
                                            3H )    ; minimum
            NS      $url.
            A       $ip
    EOF
    
    
    #完成
    echo "$url $ip complete"

    注释(#开头的那一行)我觉得是写的挺清晰的,dns服务器提供解析某个域名到某个ip地址,所以这里的基本原理就是读取输入域名和ip,向named.rfc1912.zones和${url}.zone(由以前的配置文件复制产生)中插入配置语句。

    效果就是:

    然后重启named即可。

    还有只修改了获取参数的方法,其他的不变的另一个脚本

    #!/bin/bash
    
    #获取url
    url=$1
    #获取ip
    ip=$2
    
    #向/etc/named.rfc1912.zoneswz尾插入
    #zone "$url" IN {
    #       type master;
    #       file "$url.zone";
    #        allow-update{ none; };
    #};
    
    cat>>/etc/named.rfc1912.zones<<EOF
    
    zone "$url" IN {
           type master;
           file "$url.zone";
           allow-update{ none; };
    };
    EOF
    
    #复制生成文件
    cp -a /var/named/named.localhost /var/named/${url}.zone
    
    #向/var/named/${url}.zone中插入
    #$TTL 1D
    #@      IN SOA  $url admin.$url. (
    #                                       0       ; serial
    #                                       1D      ; refresh
    #                                       1H      ; retry
    #                                       1W      ; expire
    #                                       3H )    ; minimum
    #       NS      datav.aliyuncs.com.
    #       A       $ip
    
    
    cat>/var/named/${url}.zone<<EOF
    $TTL 1D
    @       IN SOA  $url admin.$url. (
                                            0       ; serial
                                            1D      ; refresh
                                            1H      ; retry
                                            1W      ; expire
                                            3H )    ; minimum
            NS      $url.
            A       $ip
    EOF
    
    
    
    #完成
    echo "$url $ip complete"

    这个只是用法上不一样,效果如下:

    至于named的安装,以及为什么插入那样的配置语句网上到处都是教程。

  • 相关阅读:
    Pixel XL编译和烧录Android 8.0
    公式编辑器CVE-2018-0798样本分析
    CVE-2021-33739 EOP漏洞分析
    Firefox 设置 Burpsuite 代理抓取本地数据包
    前端ECharts框架绘制各种图形
    c 除法反汇编算法
    IDA sig签名批量脚本
    从零构建自己的远控•客户端设计面向对象(13)
    从零构建自己的远控•AES加解密Demo(12)
    从零构建自己的远控•图像切割算法构思(11)
  • 原文地址:https://www.cnblogs.com/xxbbtt/p/11339523.html
Copyright © 2020-2023  润新知