For details please link to https://blog.csdn.net/lwlfox/article/details/100989175
$ helm install cert-manager-webhook-alidns ./deploy/webhook-alidns -n cert-man
or
$ hell install --name cert-manager-webhook-alidns --namespace=cert-manager --set image.repository=<your repo>/cert-manager-webhook-alidns \
--set image.tag=latest ./deploy/webhook-alidns
$ docker build -t <your repo>/cert-manager-webhook-alidns .
#For users in china, you have to use vpn as some resources have been blocked in china
#docker host should has 2G memory minimum
secret
$ kubectl -n cert-manager create secret generic alidns-credentials --from-literal=accessKeySecret='your alidns accesskeySecret'
ClusterIssuer
apiVersion: certmanager.k8s.io/v1alpha1
kind: ClusterIssuer
metadata:
name: letsencrypt-prod
spec:
acme:
server: https://acme-v02.api.letsencrypt.org/directory
email: <your email>
privateKeySecretRef:
name: letsencrypt-prod
solvers:
- selector:
dnsNames:
- '*.example.cn'
dns01:
webhook:
config:
accessKeyId: <your alidns accessKeyId>
accessKeySecretRef:
key: accessKeySecret
name: alidns-credentials
regionId: "cn-beijing"
ttl: 600
groupName: certmanager.webhook.alidns
solverName: alidns
Ingress
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: example-ingress
namespace: default
annotations:
certmanager.k8s.io/cluster-issuer: "letsencrypt-prod"
spec:
tls:
- hosts:
- '*.example.cn'
secretName: wildcard-example-cn-tls
rules:
- host: demo.example.cn
http:
paths:
- path: /
backend:
serviceName: backend-service
servicePort: 80
All DNS providers must run the DNS01 provider conformance testing suite, else they will have undetermined behaviour when used with cert-manager.
It is essential that you configure and run the test suite when creating a DNS01 webhook.
An example Go test file has been provided in main_test.go.
Prepare
$ scripts/fetch-test-binaries.sh
You can run the test suite with:
$ TEST_ZONE_NAME=example.com go test .
The example file has a number of areas you must fill in and replace with your own options in order for tests to pass.