K8S Yaml
test
cat <<EOF | kubectl apply -f -
apiVersion: apps/v1
kind: Deployment
metadata:
name: test-deployment
spec:
selector:
matchLabels:
app: nginx
replicas: 1
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:latest
ports:
- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
name: test-service
spec:
selector:
app: nginx
type: NodePort
ports:
- port: 80
targetPort: 80
nodePort: 32000
EOF
Deployment
apiVersion: apps/v1
kind: Deployment
metadata:
name: test-deployment
namespace: test-deployment
labels:
key: val
spec:
replicas: 1
selector:
matchLabels:
app: test-deployment
template:
metadata:
labels:
app: test-deployment
test: "true"
spec:
hostAliases:
- hostnames:
- test.aa.com
- test.bb.com
ip: 192.168.0.127
- hostnames:
- test.cc.com
ip: 192.168.0.128
hostNetwork: true
tolerations:
- key: "CriticalAddonsOnly"
operator: "Exists"
- operator: "Exists"
effect: "NoSchedule"
- operator: "Exists"
effect: "NoExecute"
schedulerName: default-scheduler
nodeSelector:
resourceGroup: test
affinity:
podAntiAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 1
podAffinityTerm:
labelSelector:
matchExpressions:
- key: "test"
operator: In
values:
- "true"
topologyKey: "kubernetes.io/hostname"
restartPolicy: Always # Never
terminationGracePeriodSeconds: 30
containers:
- name: test-deployment
image: docker.io/library/nginx:1.21.3
imagePullPolicy: IfNotPresent
ports:
- containerPort: 22
name: ssh
protocol: TCP
securityContext:
runAsUser: 0
terminationMessagePath: /dev/termination-log
terminationMessagePolicy: File
env:
- name: http_proxy
value: http://xxxx:3120
command:
- nginx -g daemon off;
resources:
requests:
cpu: 200m
memory: 128Mi
limits:
cpu: "8"
memory: 20Gi
nvidia.com/gpu: "1"
livenessProbe:
httpGet:
path: /healthz
port: 80
scheme: HTTPS
livenessProbe:
tcpSocket:
port: 53
initialDelaySeconds: 5
periodSeconds: 10
volumeMounts:
- name: config-volume
mountPath: /etc/kubernetes
- name: dnsmasq-config
mountPath: /etc/dnsmasq.conf
subPath: dnsmasq.conf
serviceAccountName: service-account-sa
volumes:
- name: config-volume
configMap:
name: config-demo
- name: dnsmasq-config
configMap:
name: dnsmasq-config
StatefulSet
apiVersion: apps/v1
kind: StatefulSet
metadata:
annotations:
meta.helm.sh/release-name: yani
meta.helm.sh/release-namespace: default
labels:
app.kubernetes.io/instance: yani
app.kubernetes.io/managed-by: Helm
app.kubernetes.io/name: template
helm.sh/chart: template-1.0.0
taskId: yani
name: yani
namespace: default
spec:
podManagementPolicy: OrderedReady
replicas: 1
selector:
matchLabels:
app.kubernetes.io/instance: yani
app.kubernetes.io/name: template
serviceName: yani
template:
metadata:
creationTimestamp: null
labels:
app.kubernetes.io/instance: yani
app.kubernetes.io/managed-by: Helm
app.kubernetes.io/name: template
helm.sh/chart: template-1.0.0
spec:
containers:
- command:
- /bin/sh
- -c
- /script/start-script.sh
image: docker.io/gradiant/jupyter:6.0.3
imagePullPolicy: IfNotPresent
livenessProbe:
failureThreshold: 5
httpGet:
path: /
port: http
scheme: HTTP
initialDelaySeconds: 600
periodSeconds: 10
successThreshold: 1
timeoutSeconds: 5
name: yani
ports:
- containerPort: 8888
name: http
protocol: TCP
readinessProbe:
failureThreshold: 5
httpGet:
path: /
port: http
scheme: HTTP
initialDelaySeconds: 30
periodSeconds: 5
successThreshold: 1
timeoutSeconds: 1
resources:
limits:
cpu: 100m
memory: 128Mi
requests:
cpu: 100m
memory: 128Mi
securityContext:
runAsUser: 1001
terminationMessagePath: /dev/termination-log
terminationMessagePolicy: File
volumeMounts:
- mountPath: /script
name: start-script
- mountPath: /home/jovyan
name: jupyter-pvc
dnsPolicy: ClusterFirst
restartPolicy: Always
schedulerName: default-scheduler
securityContext:
fsGroup: 1001
terminationGracePeriodSeconds: 30
volumes:
- configMap:
defaultMode: 0777
name: yani-start-script
name: start-script
- emptyDir: {}
name: jupyter-pvc
Job
apiVersion: batch/v1
kind: Job
metadata:
name: hello-job
spec:
activeDeadlineSeconds: 60 # 设置Job的超时时间为60秒
template:
spec:
containers:
- name: hello-job-container
image: busybox
command: ["echo", "Hello, Kubernetes Job!"]
# 如果你想让容器保持运行一段时间(比如模拟长时间运行的任务),
# 可以使用下面的命令替换上面的echo命令。但请注意,这通常不是Job的预期用途。
# command: ["sh", "-c", "echo Hello, Kubernetes Job! && sleep 30"]
restartPolicy: Never
backoffLimit: 0 # 设置为0表示不允许重试,根据你的需求调整
CronJob
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: my-cronjob
spec:
schedule: "*/1 * * * *" # 每分钟的每一秒执行一次(注意:CronJob的精度通常到分钟,这里仅为示例)
jobTemplate:
spec:
template:
spec:
containers:
- name: my-container
image: busybox
command: ["echo", "$(date) Hello from the Kubernetes cron job"]
restartPolicy: OnFailure
successfulJobsHistoryLimit: 3
failedJobsHistoryLimit: 1
ConfigMap
apiVersion: v1
kind: ConfigMap
metadata:
name: config-demo
namespace: kube-system
data:
scheduler-config.yaml: |
apiVersion: kubescheduler.config.k8s.io/v1
kind: KubeSchedulerConfiguration
profiles:
- schedulerName: d-scheduler
- schedulerName: image-locality-scheduler
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "common.names.fullname" . }}-start-script
namespace: {{ .Release.Namespace | quote }}
labels: {{- include "common.labels.standard" . | nindent 4 }}
{{- if .Values.commonLabels }}
{{- include "common.tplvalues.render" ( dict "value" .Values.commonLabels "context" $ ) | nindent 4 }}
{{- end }}
{{- if .Values.commonAnnotations }}
annotations: {{- include "common.tplvalues.render" ( dict "value" .Values.commonAnnotations "context" $ ) | nindent 4 }}
{{- end }}
data:
start-script.sh: |
{{- .Values.script | nindent 4 }}
script: |
#!/bin/sh
echo "hl" > /tmp/yani
ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: cluster-role-crb
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-role-cr
subjects:
- kind: ServiceAccount
name: service-account-sa
namespace: kube-system
ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: cluster-role-cr
rules:
- apiGroups: [""]
resources:
- pods
- pods/logs
- pods/status
- pods/binding
- bindings
- nodes
- events
- services
- namespaces
- configmaps
- secrets
- serviceaccounts
- resourcequotas
- replicationcontrollers
- persistentvolumes
- persistentvolumeclaims
verbs:
- get
- list
- watch
- create
- update
- patch
- delete
- apiGroups: ["apps"]
resources:
- replicasets
- statefulsets
- deployments
- daemonsets
verbs:
- get
- list
- watch
- create
- update
- patch
- delete
- apiGroups: ["storage.k8s.io"]
resources:
- storageclasses
- volumeattachments
- csinodes
- csidrivers
- csistoragecapacities
verbs:
- get
- list
- watch
- apiGroups: ["policy"]
resources:
- poddisruptionbudgets
verbs:
- get
- list
- watch
- apiGroups: ["k8s.io", "events.k8s.io"]
resources:
- priorityclasses
- events
verbs:
- get
- list
- watch
- create
- update
- patch
- delete
- apiGroups: ["node"]
resources:
- runtimeclasses
verbs:
- get
- list
- watch
- apiGroups: ["coordination.k8s.io"]
resources:
- leases
verbs:
- get
- list
- watch
- create
- update
- patch
ServiceAccount
apiVersion: v1
kind: ServiceAccount
metadata:
name: service-account-sa
namespace: kube-system
daemonset
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: dnsmasq
namespace: kube-system
spec:
selector:
matchLabels:
dns: dnsmasq
template:
metadata:
labels:
dns: dnsmasq
spec:
tolerations:
- key: "CriticalAddonsOnly"
operator: "Exists"
- operator: "Exists"
effect: "NoSchedule"
- operator: "Exists"
effect: "NoExecute"
containers:
- name: dnsmasq
image: easzlab.io.local:5000/busybox:1.28
command: ["/bin/sh", "-c"]
args:
- |
cat /opt/resolv.conf > /etc/resolv.conf
tail -f /dev/null
volumeMounts:
- name: resolv-host
mountPath: /etc/resolv.conf
- name: resolv-config
mountPath: /tmp/resolv.conf
subPath: resolv.conf
volumes:
- name: resolv-host
hostPath:
path: /etc/resolv.conf
type: FileOrCreate
- name: resolv-config
configMap:
name: resolv-config
Service
apiVersion: v1
kind: Service
metadata:
annotations:
meta.helm.sh/release-name: ingress-apisix
meta.helm.sh/release-namespace: ingress-apisix
labels:
app.kubernetes.io/component: etcd
app.kubernetes.io/instance: ingress-apisix
app.kubernetes.io/managed-by: Helm
app.kubernetes.io/name: etcd
app.kubernetes.io/version: 3.5.10
helm.sh/chart: etcd-9.7.3
name: apisix-etcd
namespace: ingress-apisix
spec:
clusterIP: 10.127.15.211
clusterIPs:
- 10.127.15.211
internalTrafficPolicy: Cluster
ipFamilies:
- IPv4
ipFamilyPolicy: SingleStack
ports:
- name: client
port: 2379
protocol: TCP
targetPort: client
- name: peer
port: 2380
protocol: TCP
targetPort: peer
selector:
app.kubernetes.io/component: etcd
app.kubernetes.io/instance: ingress-apisix
app.kubernetes.io/name: etcd
sessionAffinity: None
type: ClusterIP
{{- $serviceType := .Values.service.type -}}
apiVersion: v1
kind: Service
metadata:
name: {{ include "common.names.fullname" . }}
namespace: {{ .Release.Namespace | quote }}
labels: {{- include "common.labels.standard" . | nindent 4 }}
{{- if .Values.commonLabels }}
{{- include "common.tplvalues.render" ( dict "value" .Values.commonLabels "context" $ ) | nindent 4 }}
{{- end }}
{{- if .Values.commonAnnotations }}
annotations: {{- include "common.tplvalues.render" ( dict "value" .Values.commonAnnotations "context" $ ) | nindent 4 }}
{{- end }}
spec:
type: {{ .Values.service.type }}
sessionAffinity: {{ default "None" .Values.service.sessionAffinity }}
{{- if and .Values.service.clusterIP (eq .Values.service.type "ClusterIP") }}
clusterIP: {{ .Values.service.clusterIP }}
{{- end }}
{{- if and .Values.service.loadBalancerIP (eq .Values.service.type "LoadBalancer") }}
loadBalancerIP: {{ .Values.service.loadBalancerIP }}
{{- end }}
{{- if and (eq .Values.service.type "LoadBalancer") .Values.service.loadBalancerSourceRanges }}
loadBalancerSourceRanges: {{- toYaml .Values.service.loadBalancerSourceRanges | nindent 4 }}
{{- end }}
{{- if or (eq .Values.service.type "LoadBalancer") (eq .Values.service.type "NodePort") }}
externalTrafficPolicy: {{ .Values.service.externalTrafficPolicy | quote }}
{{- end }}
ports:
{{- range .Values.service.ports }}
- name: {{ .name }}
port: {{ .port }}
targetPort: {{ .targetPort }}
{{- if and (or (eq $serviceType "NodePort") (eq $serviceType "LoadBalancer")) (not (empty .nodePort)) }}
nodePort: {{ .nodePort }}
{{- end }}
{{- end }}
selector: {{- include "common.labels.matchLabels" . | nindent 4 }}
service:
type: ClusterIP # clusterIP LoadBalancer NodePort
ports:
- name: http
port: 80
targetPort: http
Ingress
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
annotations:
meta.helm.sh/release-name: yani
generation: 1
labels:
app.kubernetes.io/instance: yani
name: yani
namespace: default
spec:
ingressClassName: nginx
rules:
- host: hl.test.com
http:
paths:
- backend:
service:
name: yani
port:
number: 80
path: /
pathType: Prefix
{{- if .Values.ingress.enabled -}}
{{- $fullName := include "common.names.fullname" . -}}
{{- $httpPort := .Values.service.port -}}
{{- $pathType := .Values.ingress.pathType -}}
apiVersion: {{ include "common.capabilities.ingress.apiVersion" . }}
kind: Ingress
metadata:
name: {{ .Release.Name }}
namespace: {{ .Release.Namespace | quote }}
labels: {{- include "common.labels.standard" . | nindent 4 }}
{{- if .Values.commonLabels }}
{{- include "common.tplvalues.render" ( dict "value" .Values.commonLabels "context" $ ) | nindent 4 }}
{{- end }}
spec:
{{- if .Values.ingress.ingressClassName }}
ingressClassName: {{ .Values.ingress.ingressClassName | quote }}
{{- end }}
rules:
{{- range .Values.ingress.hosts }}
- host: {{ .host }}
http:
paths:
{{- range .paths }}
- path: {{ default "/" .path }}
pathType: {{ default "Prefix" $pathType }}
backend:
service:
name: {{ $fullName }}
port:
number: {{ .port | default $httpPort }}
{{- end }}
{{- end }}
{{- end }}
ingress:
enabled: true
ingressClassName: nginx
pathType: Prefix
apiVersion: "networking.k8s.io/v1"
hosts:
- host: hl.test.com
paths:
- path: /
port: 80
pod
apiVersion: v1
kind: Pod
metadata:
name: test-pod
spec:
schedulerName: default-scheduler
containers:
- name: test-pod
image: docker.io/library/nginx:1.21.3
ServiceMonitor
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
annotations:
meta.helm.sh/release-name: ingress-apisix
meta.helm.sh/release-namespace: ingress-apisix
labels:
app.kubernetes.io/instance: ingress-apisix
app.kubernetes.io/managed-by: Helm
app.kubernetes.io/name: apisix
app.kubernetes.io/version: 3.9.1
helm.sh/chart: apisix-2.8.1
release: ai-kube-prometheus-stack
name: apisix
namespace: ingress-apisix
spec:
endpoints:
- interval: 15s
path: /apisix/prometheus/metrics
scheme: http
targetPort: prometheus
namespaceSelector:
matchNames:
- ingress-apisix
selector:
matchLabels:
app.kubernetes.io/instance: ingress-apisix
app.kubernetes.io/managed-by: Helm
app.kubernetes.io/name: apisix
app.kubernetes.io/service: apisix-prometheus-metrics
app.kubernetes.io/version: 3.9.1
helm.sh/chart: apisix-2.8.1
PodMonitor
apiVersion: monitoring.coreos.com/v1
kind: PodMonitor
metadata:
labels:
app: apisix-etcd
app.kubernetes.io/instance: ingress-apisix
app.kubernetes.io/name: etcd
app.kubernetes.io/version: 3.5.10
release: ai-kube-prometheus-stack
name: apisix-etcd
namespace: monitoring
spec:
podMetricsEndpoints:
- interval: 15s
path: /metrics
scheme: http
port: client
namespaceSelector:
matchNames:
- ingress-apisix
selector:
matchLabels:
app.kubernetes.io/instance: ingress-apisix
app.kubernetes.io/name: etcd
app.kubernetes.io/component: etcd
Namespace
apiVersion: v1
kind: Namespace
metadata:
name: aaa
api-resources
NAME SHORTNAMES APIVERSION NAMESPACED KIND
bindings v1 true Binding
componentstatuses cs v1 false ComponentStatus
configmaps cm v1 true ConfigMap
endpoints ep v1 true Endpoints
events ev v1 true Event
limitranges limits v1 true LimitRange
namespaces ns v1 false Namespace
nodes no v1 false Node
persistentvolumeclaims pvc v1 true PersistentVolumeClaim
persistentvolumes pv v1 false PersistentVolume
pods po v1 true Pod
podtemplates v1 true PodTemplate
replicationcontrollers rc v1 true ReplicationController
resourcequotas quota v1 true ResourceQuota
secrets v1 true Secret
serviceaccounts sa v1 true ServiceAccount
services svc v1 true Service
mutatingwebhookconfigurations admissionregistration.k8s.io/v1 false MutatingWebhookConfiguration
validatingwebhookconfigurations admissionregistration.k8s.io/v1 false ValidatingWebhookConfiguration
customresourcedefinitions crd,crds apiextensions.k8s.io/v1 false CustomResourceDefinition
apiservices apiregistration.k8s.io/v1 false APIService
apisixclusterconfigs acc apisix.apache.org/v2 false ApisixClusterConfig
apisixconsumers ac apisix.apache.org/v2 true ApisixConsumer
apisixglobalrules agr apisix.apache.org/v2 true ApisixGlobalRule
apisixpluginconfigs apc apisix.apache.org/v2 true ApisixPluginConfig
apisixroutes ar apisix.apache.org/v2 true ApisixRoute
apisixtlses atls apisix.apache.org/v2 true ApisixTls
apisixupstreams au apisix.apache.org/v2 true ApisixUpstream
controllerrevisions apps/v1 true ControllerRevision
daemonsets ds apps/v1 true DaemonSet
deployments deploy apps/v1 true Deployment
replicasets rs apps/v1 true ReplicaSet
statefulsets sts apps/v1 true StatefulSet
tokenreviews authentication.k8s.io/v1 false TokenReview
localsubjectaccessreviews authorization.k8s.io/v1 true LocalSubjectAccessReview
selfsubjectaccessreviews authorization.k8s.io/v1 false SelfSubjectAccessReview
selfsubjectrulesreviews authorization.k8s.io/v1 false SelfSubjectRulesReview
subjectaccessreviews authorization.k8s.io/v1 false SubjectAccessReview
horizontalpodautoscalers hpa autoscaling/v2 true HorizontalPodAutoscaler
cronjobs cj batch/v1 true CronJob
jobs batch/v1 true Job
certificatesigningrequests csr certificates.k8s.io/v1 false CertificateSigningRequest
leases coordination.k8s.io/v1 true Lease
endpointslices discovery.k8s.io/v1 true EndpointSlice
events ev events.k8s.io/v1 true Event
flowschemas flowcontrol.apiserver.k8s.io/v1beta3 false FlowSchema
prioritylevelconfigurations flowcontrol.apiserver.k8s.io/v1beta3 false PriorityLevelConfiguration
nodes metrics.k8s.io/v1beta1 false NodeMetrics
pods metrics.k8s.io/v1beta1 true PodMetrics
alertmanagerconfigs amcfg monitoring.coreos.com/v1alpha1 true AlertmanagerConfig
alertmanagers am monitoring.coreos.com/v1 true Alertmanager
podmonitors pmon monitoring.coreos.com/v1 true PodMonitor
probes prb monitoring.coreos.com/v1 true Probe
prometheusagents promagent monitoring.coreos.com/v1alpha1 true PrometheusAgent
prometheuses prom monitoring.coreos.com/v1 true Prometheus
prometheusrules promrule monitoring.coreos.com/v1 true PrometheusRule
scrapeconfigs scfg monitoring.coreos.com/v1alpha1 true ScrapeConfig
servicemonitors smon monitoring.coreos.com/v1 true ServiceMonitor
thanosrulers ruler monitoring.coreos.com/v1 true ThanosRuler
ingressclasses networking.k8s.io/v1 false IngressClass
ingresses ing networking.k8s.io/v1 true Ingress
networkpolicies netpol networking.k8s.io/v1 true NetworkPolicy
runtimeclasses node.k8s.io/v1 false RuntimeClass
poddisruptionbudgets pdb policy/v1 true PodDisruptionBudget
clusterrolebindings rbac.authorization.k8s.io/v1 false ClusterRoleBinding
clusterroles rbac.authorization.k8s.io/v1 false ClusterRole
rolebindings rbac.authorization.k8s.io/v1 true RoleBinding
roles rbac.authorization.k8s.io/v1 true Role
priorityclasses pc scheduling.k8s.io/v1 false PriorityClass
csidrivers storage.k8s.io/v1 false CSIDriver
csinodes storage.k8s.io/v1 false CSINode
csistoragecapacities storage.k8s.io/v1 true CSIStorageCapacity
storageclasses sc storage.k8s.io/v1 false StorageClass
volumeattachments storage.k8s.io/v1 false VolumeAttachment
hostAliases
cat <<EOF| kubectl apply -f -
apiVersion: v1
kind: Pod
metadata:
name: test
spec:
hostAliases:
- hostnames:
- test.aa.com
ip: 10.0.0.1
- hostnames:
- test1.aa.com
- test2.aa.com
ip: 10.0.0.2
containers:
- name: test
image: busybox:1.28
imagePullPolicy: IfNotPresent
command: ["/bin/sh", "-c", "sleep 3000"]
EOF
Demo
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: apisix-etcd-monitor
namespace: ingress-apisix
spec:
selector:
matchLabels:
app: apisix-etcd-monitor
template:
metadata:
labels:
app: apisix-etcd-monitor
spec:
hostNetwork: true
nodeSelector:
monitor: apisix-etcd
containers:
- name: apisix-etcd-monitor
image: easzlab.io.local:5000/alpine:3.10.4
ports:
- name: metrics
containerPort: 3379
hostPort: 3379
command:
- sh
- -c
- tail -f /dev/null
---
apiVersion: monitoring.coreos.com/v1
kind: PodMonitor
metadata:
labels:
app: apisix-etcd-monitor
release: ai-kube-prometheus-stack
name: apisix-etcd-monitor
namespace: monitoring
spec:
podMetricsEndpoints:
- interval: 15s
path: /metrics
scheme: http
port: metrics
namespaceSelector:
matchNames:
- ingress-apisix
selector:
matchLabels:
app: apisix-etcd-monitor
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: apisix-etcd-monitor
namespace: ingress-apisix
spec:
selector:
matchLabels:
app: apisix-etcd-monitor
template:
metadata:
labels:
app: apisix-etcd-monitor
spec:
hostNetwork: true
nodeSelector:
monitor: apisix-etcd
containers:
- name: apisix-etcd-monitor
image: easzlab.io.local:5000/alpine:3.10.4
ports:
- name: metrics
containerPort: 3379
hostPort: 3379
command:
- sh
- -c
- tail -f /dev/null
---
apiVersion: v1
kind: Service
metadata:
name: apisix-etcd-monitor
namespace: ingress-apisix
labels:
app: apisix-etcd-monitor-svc
spec:
selector:
app: apisix-etcd-monitor
ports:
- name: metrics
protocol: TCP
port: 3379
targetPort: metrics
---
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
labels:
release: ai-kube-prometheus-stack
name: apisix-etcd-monitor
namespace: ingress-apisix
spec:
endpoints:
- interval: 15s
path: /metrics
scheme: http
targetPort: metrics
namespaceSelector:
matchNames:
- ingress-apisix
selector:
matchLabels:
app: apisix-etcd-monitor-svc
j2
indent=0 指定转换时不增加额外的缩进。 indent(2):在生成的 YAML 内容前面添加 2 个空格的缩进,以便在嵌套上下文中正确对齐。
# vars/main.yaml
dnsmasq_replica_count: "{{ groups['dnsmasq'] | length }}"
resources:
requests:
cpu: 200m
memory: 128Mi
limits:
cpu: 4
memory: 4Gi
dnsmasq_global_conf: |
no-hosts
no-resolv
no-poll
neg-ttl=300
min-cache-ttl=300
dns-forward-max=10000
cache-size=100000
edns-packet-max=1232
log-facility=/var/log/dnsmasq.log
all-servers
server=114.114.114.114
server=8.8.8.8
dnsmasq_address_conf: |
address=/image.ac.com/127.0.0.1
tolerations:
- key: "CriticalAddonsOnly"
operator: "Exists"
- operator: "Exists"
effect: "NoSchedule"
- operator: "Exists"
effect: "NoExecute"
affinity:
podAntiAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 1
podAffinityTerm:
labelSelector:
matchExpressions:
- key: "{{ ingress_label }}"
operator: In
values:
- "true"
topologyKey: "kubernetes.io/hostname"
config:
worker-processes: "auto"
worker-cpu-affinity: "auto"
max-worker-connections: "16384"
# value.yaml.j2
image:
repository: {{ dnsmasq_image }}
pullPolicy: IfNotPresent
name: {{ dnsmasq_name }}
namespace: {{ dnsmasq_namespace }}
replicaCount: {{ dnsmasq_replica_count}}
podLabel: {{ dnsmasq_label }}
resources:
{{ resources | to_nice_yaml(indent=2) }}
dnsmasqConfig: | # 字符串
{{ dnsmasq_global_conf | to_nice_yaml | from_yaml | indent(2) }}
{{ dnsmasq_address_conf | to_nice_yaml | from_yaml | indent(2) }}
config:
{{ config | to_nice_yaml(indent=0) | indent(2) }}
affinity:
{{ affinity | to_nice_yaml(indent=2) }}
tolerations:
{{ tolerations | to_nice_yaml(indent=0) }}
# resolv.conf.j2
{% for item in groups['dnsmasq'] %}
nameserver {{ item }}
{% endfor %}
options timeout:1 attempts:3 rotate
nodeSelector:
ingress: "true"
nodeSelector:
{{ ingress_label }}: "true"
tolerations:
- key: CriticalAddonsOnly
operator: Exists
- effect: NoSchedule
operator: Exists
- effect: NoExecute
operator: Exists
# indent=0 指定转换时不增加额外的缩进。
# indent(2):在生成的 YAML 内容前面添加 2 个空格的缩进,以便在嵌套上下文中正确对齐。
tolerations:
{{ tolerations | to_nice_yaml(indent=0) | indent(2) }}
ansible
# file/chart/templates/test.yaml
...
resources:
{{- toYaml .Values.resources | nindent 10 }}
...
# file/chart/templates/cm.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: dnsmasq-config
namespace: {{ .Values.namespace }}
data:
dnsmasq.conf: |
{{- .Values.dnsmasqConfig | nindent 4 }}
# task/main.yaml
- name: install
import_tasks: helm-install.yml
vars:
version: "{{ version }}"
name: "{{ iname }}"
- name: 轮询等待 svc 运行
wait_for:
host: "{{ groups['ingress'][0] }}"
port: "{{ ingress_nodePort }}"
delay: 10
timeout: 180
- name: get svc ip
shell: "{{ kubectl }} get svc test -o jsonpath='{.spec.clusterIP}'"
register: test_ip
- name: echo stdout
shell:
cmd: |
echo {{ test_ip.stdout }}
delegate_to: "{{ item }}"
loop: "{{ groups['ingress'] }}"
when: etcd.external | default(false) != true
- name: clean
import_tasks: clean.yml
when: "'clean' in ansible_run_tags"
tags:
- clean