问题描述
我正在使用 k3d 和 calico,并尝试使用 calicoctl
来设置网络策略。我可以在 Ubuntu 上使用它,但在 Windows 上却不能。为了进行设置,我执行了以下操作:
# Download Calico YAML
# DOWNLOAD: https://raw.githubusercontent.com/rancher/k3d/main/docs/usage/guides/calico.yaml
# Create k3d cluster
k3d cluster create "dev" --k3s-server-arg '--flannel-backend=none' --volume "$(pwd)/calico.yaml:/var/lib/rancher/k3s/server/manifests/calico.yaml
# Download Windows version
# DOWNLOAD: https://github.com/projectcalico/calicoctl/releases/download/v3.18.2/calicoctl-windows-amd64.exe
# Make an Alias
Set-Alias -Name calicoctl -Value ".\calicoctl-windows-amd64.exe"
然后当我尝试使用 NetWorkPolicy
运行应用 calicoctl apply -f my-policy.yaml
时出现错误:
创建 Calico API 客户端失败:配置无效:未提供任何配置,请尝试设置 KUBERNETES_MASTER 环境变量
所以我尝试使用我的 Kubeconfig 的值来设置:
# Get the IP/Port from Kubeconfig (Gives https://0.0.0.0:60776)
$kmaster=(kubectl config view -o jsonpath="{.clusters[?(@.name=='k3d-dev')].cluster.server}")
# Set the kubernetes master env variable from what's in kube config
[Environment]::SetEnvironmentvariable(“KUBERNETES_MASTER”,$kmaster,“User”)
那仍然给出同样的错误。 (注意:来自 Kubeconfig 的 ip 是“https://0.0.0.0:60776”)
然后我尝试了以下所有方法,但都不起作用:
set KUBECONfig=~/.kube/config
SET CALICO_KUBECONfig=C:\Users\myname\.kube\config
SET KUBE_CONfig_PATH=C:\Users\myname\.kube\config
$env:KUBERNETES_MASTER=(kubectl config view -o jsonpath="{.clusters[?(@.name=='k3d-dev')].cluster.server}")
如何让“calicoctl-windows-amd64.exe”找到我的 Kubernetes 集群?
解决方法
虽然官方 documentation 声称:
- Calico 在默认用户位置
~/.kube/config
中查找配置
- 它还会查看
KUBERNETES_MASTER
(错误输出说明了这一点) - 它还会查看
KUBECONFIG
它没有!以上都不适用于 Windows。 (在 Ubuntu 上,我不需要做任何特别的事情,它会找到我的配置)
我找到的唯一解决方案是执行以下操作:
- 创建配置文件
- 在每个
calicoctl
调用中传递配置文件
calico.cfg.yaml
apiVersion: projectcalico.org/v3
kind: CalicoAPIConfig
metadata:
spec:
datastoreType: "kubernetes"
kubeconfig: "C:/users/myusername/.kube/config"
注意:如果你通过“~/.kube/config”,它会失败并说它找不到那个路径
现在调用它需要:
# NOTICE THE "--config=calico.cfg.yaml"
calicoctl apply -f some-policy.yaml --config=calico.cfg.yaml
我认为,根据配置文件的工作情况判断,但在使用 "~/.kube/config"
作为 kubeconfig 路径时抛出错误,它是 查看该“默认”路径,但使用的 Windows API 无法识别 ~
别名。