我正在主节点上运行以下命令,以在Kubernetes集群上创建守护程序集。
$ kubectl apply -f https://k8s.io/examples/controllers/daemonset.yaml
我认为它已成功创建,因为显示了以下消息,
daemonset.apps/fluentd-elasticsearch created
但是之后我跑步时,
$ kubectl get daemonsets
No resources found in default namespace
所以我尝试重新创建相同的内容,但这一次它显示了,
$ kubectl apply -f https://k8s.io/examples/controllers/daemonset.yaml
daemonset.apps/fluentd-elasticsearch unchanged
我不明白这里发生了什么。一个解释将不胜感激。
答案 0 :(得分:2)
由于部署Yaml具有kube-system
namespace: kube-system
命名空间中进行部署
kubectl get daemonsets
命令显示了daemonsets
命名空间中的default
,因此它给出了No resources found
您需要在命令中添加-n
参数,以检查在特定名称空间(例如daemonsets
)中创建的kube-system
kubectl get daemonsets -n kube-system
答案 1 :(得分:2)
运行
kubectl get daemonsets —all-namespaces -o wide
这将为您提供存在于名称空间和辅助节点上的所有守护程序
答案 2 :(得分:0)
当您转到kubernetes官方文档并检查此链接DaemonSet时,您将看到DaemonSet的名称空间。
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: fluentd-elasticsearch
namespace: kube-system
labels:
k8s-app: fluentd-logging
spec:
selector:
matchLabels:
name: fluentd-elasticsearch
template:
metadata:
labels:
name: fluentd-elasticsearch
spec:
tolerations:
# this toleration is to have the daemonset runnable on master nodes
# remove it if your masters can't run pods
- key: node-role.kubernetes.io/master
effect: NoSchedule
containers:
- name: fluentd-elasticsearch
image: quay.io/fluentd_elasticsearch/fluentd:v2.5.2
resources:
limits:
memory: 200Mi
requests:
cpu: 100m
memory: 200Mi
volumeMounts:
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
readOnly: true
terminationGracePeriodSeconds: 30
volumes:
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers
答案 3 :(得分:0)
用于创建守护程序集的URL将在kube-system命名空间中创建一个守护程序集。而不是在默认名称空间中查看守护程序集。使用以下命令。它将显示所有守护程序以及运行它的名称空间。
Kubectl get ds --all-namespaces