linux安装 
- 下载 - 最新版本
 curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"- 指定版本
 curl -LO https://dl.k8s.io/release/v1.20.0/bin/linux/amd64/kubectl
- 安装sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl
- 配置
配置文件位置 ~/kube/config
Kubectl 自动补全 
BASH 
bash
source <(kubectl completion bash) # 在 bash 中设置当前 shell 的自动补全,要先安装 bash-completion 包。
echo "source <(kubectl completion bash)" >> ~/.bashrc # 在您的 bash shell 中永久的添加自动补全您还可以为 kubectl 使用一个速记别名,该别名也可以与 completion 一起使用:
bash
alias k=kubectl
complete -F __start_kubectl kZSH 
bash
source <(kubectl completion zsh)  # 在 zsh 中设置当前 shell 的自动补全
echo "[[ $commands[kubectl] ]] && source <(kubectl completion zsh)" >> ~/.zshrc # 在您的 zsh shell 中永久的添加自动补全常用命令 
Secret 
创建docker访问secret 需要在Deployment中指定
kubectl create secret docker-registry my-secret --docker-server=DOCKER_REGISTRY_SERVER --docker-username=DOCKER_USER --docker-password=DOCKER_PASSWORD --docker-email=DOCKER_EMAIL
spec:
  imagePullSecrets:
  - name: my-secret污点 
- 打上污点 - NoSchedule:K8Snode添加这个effecf类型污点,新的不能容忍的pod不能再调度过来,但是老的运行在node上不受影响 - NoExecute:K8Snode添加这个effecf类型污点,新的不能容忍的pod不能调度过来,老的pod也会被驱逐 - PreferNoSchedule:pod会尝试将pod分配到该节点 - kubectl taint nodes node1 key=value:NoSchedule kubectl taint nodes node1 key=value:NoExecute kubectl taint nodes node1 key=value:PreferNoSchedule
- 删除污点 - 加上[-] 
 - kubectl taint nodes node1 key=value:NoSchedule- kubectl taint nodes node1 key=value:NoExecute- kubectl taint nodes node1 key=value:PreferNoSchedule-- pod设置容忍 - tolerations: #containers同级 - key: "key1" #能容忍的污点key operator: "Equal" #Equal等于表示key=value , Exists不等于,表示当值不等于下面value正常 value: "value1" #值 effect: "NoExecute" #effect策略,见上面 tolerationSeconds: 3600 #原始的pod多久驱逐,注意只有effect: "NoExecute"才能设置,不然报错