构建后端为etcd的CoreDNS的容器集群(七)、编写适合阅读的域名管理脚本

本文为系列测试文章,拟基于自签名证书认证的etcd容器来构建coredns域名解析系统。

一、前置文章

构建后端为etcd的CoreDNS的容器集群(一)、生成自签名证书

构建后端为etcd的CoreDNS的容器集群(二)、下载最新的etcd容器镜像

构建后端为etcd的CoreDNS的容器集群(三)、etcd功能测试

构建后端为etcd的CoreDNS的容器集群(四)、etcd挂载私有自签名证书进行访问测试

构建后端为etcd的CoreDNS的容器集群(五)、coredns对接etcd测试

构建后端为etcd的CoreDNS的容器集群(六)、编写自动维护域名记录的代码脚本

二、对接etcd,新增域名的脚本

etcdctl命令添加域名记录key值形如"/coredns/com/test/www",比较难阅读,编写shell脚本,用于较方便地新增域名。

1、编写脚本,脚本名:adddomain.sh,内容如下:
bash 复制代码
[root@localhost coredns]# cat adddomain.sh
#!/bin/bash
##__author__='daigjianbing'

ENDPOINTS=https://etcd-1:2379,https://etcd-2:2379,https://etcd-3:2379
SSL_CACERT=/opt/coredns/ssl/ca.pem
SSL_CERT=/opt/coredns/ssl/etcd.pem
SSL_KEY=/opt/coredns/ssl/etcd-key.pem

if [ $# -lt 2 ]; then
    echo -e "Usage: $0 <domain> <ip> \nJust like: $0 www.163.com 192.168.1.1"
    exit 1
fi

domain=$1
ip=$2

parts=(${domain//\./ }) #用.分拆域名
reversed_domain=""
# 倒序重新生成易于阅读的域名
for ((i=${#parts[@]}-1; i>=0; i--)); do
    if [ -z "$reversed_domain" ]; then
        reversed_domain="${parts[$i]}"
    else
        reversed_domain="${reversed_domain}/${parts[$i]}"
    fi
done

# 生成实际命令
etcdctl_command="etcdctl --endpoints=${ENDPOINTS} --cacert=${SSL_CACERT} --cert=${SSL_CERT} --key=${SSL_KEY} put /coredns/$reversed_domain '{\"host\":\"$ip\",\"ttl\":10}'"
echo "${etcdctl_command}"   #回显命令
eval $etcdctl_command       #执行命令
[root@localhost coredns]# 
2、执行测试
bash 复制代码
[root@localhost coredns]# ./adddomain.sh www.test.com 192.168.1.1
etcdctl --endpoints=https://etcd-1:2379,https://etcd-2:2379,https://etcd-3:2379 --cacert=/opt/coredns/ssl/ca.pem --cert=/opt/coredns/ssl/etcd.pem --key=/opt/coredns/ssl/etcd-key.pem put /coredns/com/test/www '{"host":"192.168.1.1","ttl":10}
OK
[root@localhost coredns]# 

可以看到具体添加域名的指令及执行结果为ok。

三、对接etcd,查询域名的脚本

同样编写脚本,将etcd数据库中存储的域名,以适合阅读的形式进行回显输出。

1、编写脚本,脚本名showdomain.sh
bash 复制代码
[root@localhost coredns]# cat showdomain.sh 
#!/bin/bash
##__author__='daigjianbing'

ENDPOINTS=https://etcd-1:2379,https://etcd-2:2379,https://etcd-3:2379
SSL_CACERT=/opt/coredns/ssl/ca.pem
SSL_CERT=/opt/coredns/ssl/etcd.pem
SSL_KEY=/opt/coredns/ssl/etcd-key.pem

while read -r line; do
    if [[ $line =~ ^/coredns/ ]]; then
        key=${line#/coredns/}
        parts=(${key//\// })
        reversed_parts=($(for part in "${parts[@]}"; do echo $part; done | tac))
        domain=""
        for ((i=0; i<${#reversed_parts[@]}; i++)); do
            if [ -z "$domain" ]; then
                domain="${parts[$i]}"
            else
                domain="${parts[$i]}.${domain}"
            fi
        done
    else
        value=$(echo $line | awk -F'"host":"|","ttl":' '{print $2}')
        echo "${domain}, $value"
    fi
done <<< "$(etcdctl --endpoints=${ENDPOINTS} --cacert=${SSL_CACERT} --cert=${SSL_CERT} --key=${SSL_KEY} get --prefix "/")"
[root@localhost coredns]#
2、执行测试
bash 复制代码
[root@localhost coredns]# ./showdomain.sh     
www.test.com, 192.168.1.1

测试回显正常。

三、编写删除域名的脚本

1、脚本名deldomain.sh,内容:
bash 复制代码
[root@localhost coredns]# cat deldomain.sh
#!/bin/bash
##__author__='daigjianbing'

ENDPOINTS=https://etcd-1:2379,https://etcd-2:2379,https://etcd-3:2379
SSL_CACERT=/opt/coredns/ssl/ca.pem
SSL_CERT=/opt/coredns/ssl/etcd.pem
SSL_KEY=/opt/coredns/ssl/etcd-key.pem

if [ $# -lt 1 ]; then
    echo -e "Usage: $0 <domain>\nJust like: $0 www.163.com"
    exit 1
fi

domain=$1

parts=(${domain//\./ })
reversed_domain=""
for ((i=${#parts[@]}-1; i>=0; i--)); do
    if [ -z "$reversed_domain" ]; then
        reversed_domain="${parts[$i]}"
    else
        reversed_domain="${reversed_domain}/${parts[$i]}"
    fi
done

etcdctl_command="etcdctl --endpoints=${ENDPOINTS} --cacert=${SSL_CACERT} --cert=${SSL_CERT} --key=${SSL_KEY} del /coredns/$reversed_domain"
echo "${etcdctl_command}"
eval $etcdctl_command
[root@localhost coredns]#
2、执行删除测试
bash 复制代码
[root@localhost coredns]# sh deldomain.sh www.test.com
etcdctl --endpoints=https://etcd-1:2379,https://etcd-2:2379,https://etcd-3:2379 --cacert=/opt/coredns/ssl/ca.pem --cert=/opt/coredns/ssl/etcd.pem --key=/opt/coredns/ssl/etcd-key.pem del /coredns/com/test/www
1
[root@localhost coredns]#
3、再次查询数据库
bash 复制代码
[root@localhost coredns]# ./showdomain.sh 
[root@localhost coredns]#

可见记录已删除。

相关推荐
冬奇Lab18 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神1 天前
三、用户与权限管理
数据库·mysql
大树882 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠2 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质2 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工2 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智2 天前
ARP代理--工作原理
运维·网络·arp·arp代理
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化