安装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
Logo

技术共进,成长同行——讯飞AI开发者社区

更多推荐