阿里云使用 ExternalDNS 集成外部DNS服务

安装bitnami helm源

helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo update

生成external-dns配置yaml

cat << EOF > external-dns.yaml
image:
  registry: registry-vpc.cn-shenzhen.aliyuncs.com
  repository: liweilun/external-dns
policy: sync
provider: alibabacloud
#logLevel: debug
txtOwnerId: "rzedu"
alibabacloud:
  accessKeyId: "xxx"
  accessKeySecret: "xxx"
  zoneType: public
  vpcId: "xxx"
domain-filter:
- aaa.cn
- xxx.cn
interval: "1m"
extraVolumes:
- name: hostpath
  hostPath:
    path: /usr/share/zoneinfo
    type: Directory
extraVolumeMounts:
- name: hostpath
  mountPath: /usr/share/zoneinfo
EOF

参数详解

policy是dns增删策略
sync模式:增删该domain下所有解析,实际上是external-dns 实例仅创建/修改/删除由该实例创建的记录(与txtOwnerId挂钩)
upsert-only模式:仅创建/修改由该实例创建的记录(与txtOwnerId挂钩)
alibabacloud的zoneType
public:修改云解析dns记录
private:修改PrivateZone记录
或者留空
domain-filter是指只监听哪些域名,默认空数组监听所有域名
domain-filter: []
interval指与外部dns provider同步解析记录的间隔,默认1分钟

helm安装external-dns

helm upgrade --install externaldns  -f external-dns.yaml bitnami/external-dns

配置dns记录

默认监听kind为service和ingress的资源对象
绝大部分都是插入a记录,只有externalname写域名才能插入cname记录
如果ingress入口是用crd的话,最方便是新建一个ExternalName,注解hostname里面写上域名,允许星号通配符
kind: Service
apiVersion: v1
metadata:
  name: dns
  annotations:
    external-dns.alpha.kubernetes.io/hostname: xxx.cn,www.xxx.cn,*.xxx.cn
spec:
  type: ExternalName
  externalName: nlbxxx.cn-shenzhen.nlb.aliyuncs.com

在这里插入图片描述

出现cname-www是因为txt记录和cname记录不能同时为www
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值