--- title: 设置 Konnectivity 服务 content_type: task weight: 70 --- Konnectivity 服务为控制平面提供集群通信的 TCP 级别代理。 ## {{% heading "prerequisites" %}} {{< include "task-tutorial-prereqs.md" >}} ## 配置 Konnectivity 服务 接下来的步骤需要出口配置,比如: {{< codenew file="admin/konnectivity/egress-selector-configuration.yaml" >}} 你需要配置 API 服务器来使用 Konnectivity 服务,并将网络流量定向到集群节点: 1. 确保 `ServiceAccountTokenVolumeProjection` [特性门控](/zh/docs/reference/command-line-tools-reference/feature-gates/) 被启用。你可以通过为 kube-apiserver 提供以下标志启用 [服务账号令牌卷保护](/zh/docs/tasks/configure-pod-container/configure-service-account/#service-account-token-volume-projection): ``` --service-account-issuer=api --service-account-signing-key-file=/etc/kubernetes/pki/sa.key --api-audiences=system:konnectivity-server ``` 1. 创建一个出站流量配置文件,比如 `admin/konnectivity/egress-selector-configuration.yaml`。 1. 将 API 服务器的 `--egress-selector-config-file` 参数设置为你的 API 服务器的 离站流量配置文件路径。 1. 如果你在使用 UDS 连接,须将卷配置添加到 kube-apiserver: ```yaml spec: containers: volumeMounts: - name: konnectivity-uds mountPath: /etc/kubernetes/konnectivity-server readOnly: false volumes: - name: konnectivity-uds hostPath: path: /etc/kubernetes/konnectivity-server type: DirectoryOrCreate ``` 为 konnectivity-server 生成或者取得证书和 kubeconfig 文件。 例如,你可以使用 OpenSSL 命令行工具,基于存放在某控制面主机上 `/etc/kubernetes/pki/ca.crt` 文件中的集群 CA 证书来 发放一个 X.509 证书, ```bash openssl req -subj "/CN=system:konnectivity-server" -new -newkey rsa:2048 -nodes -out konnectivity.csr -keyout konnectivity.key -out konnectivity.csr openssl x509 -req -in konnectivity.csr -CA /etc/kubernetes/pki/ca.crt -CAkey /etc/kubernetes/pki/ca.key -CAcreateserial -out konnectivity.crt -days 375 -sha256 SERVER=$(kubectl config view -o jsonpath='{.clusters..server}') kubectl --kubeconfig /etc/kubernetes/konnectivity-server.conf config set-credentials system:konnectivity-server --client-certificate konnectivity.crt --client-key konnectivity.key --embed-certs=true kubectl --kubeconfig /etc/kubernetes/konnectivity-server.conf config set-cluster kubernetes --server "$SERVER" --certificate-authority /etc/kubernetes/pki/ca.crt --embed-certs=true kubectl --kubeconfig /etc/kubernetes/konnectivity-server.conf config set-context system:konnectivity-server@kubernetes --cluster kubernetes --user system:konnectivity-server kubectl --kubeconfig /etc/kubernetes/konnectivity-server.conf config use-context system:konnectivity-server@kubernetes rm -f konnectivity.crt konnectivity.key konnectivity.csr ``` 接下来,你需要部署 Konnectivity 服务器和代理。 [kubernetes-sigs/apiserver-network-proxy](https://github.com/kubernetes-sigs/apiserver-network-proxy) 是一个参考实现。 在控制面节点上部署 Konnectivity 服务。 下面提供的 `konnectivity-server.yaml` 配置清单假定在你的集群中 Kubernetes 组件都是部署为{{< glossary_tooltip text="静态 Pod" term_id="static-pod" >}} 的。 如果不是,你可以将 Konnectivity 服务部署为 DaemonSet。 {{< codenew file="admin/konnectivity/konnectivity-server.yaml" >}} 在你的集群中部署 Konnectivity 代理: {{< codenew file="admin/konnectivity/konnectivity-agent.yaml" >}} 最后,如果你的集群启用了 RBAC,请创建相关的 RBAC 规则: {{< codenew file="admin/konnectivity/konnectivity-rbac.yaml" >}}