如何创建 Token
在这篇文档中,你将了解如何使用 token 访问 Karpor dashboard。
Hub Cluster 采用了与 Kubernetes 相同的基于角色的访问控制(RBAC)机制。这意味着,要访问 Hub Cluster,用户需要在 Hub Cluster 上创建 ClusterRole、ServiceAccount,以及相应的 ClusterRoleBinding 来将两者绑定。为了提升用户体验,我们预设了两种 ClusterRole:karpor-admin 和 karpor-guest。karpor-admin 角色拥有在面板上执行所有操作的权限,包括但不限于添加或删除集群、创建资源组等;而 karpor-guest 角色则仅限于在面板上进行查看操作。随着对 Karpor 的深入了解,用户可以根据自身需求,创建额外的 ClusterRole,实现更细致的权限管理。
在安装 Karpor 时启用 RBAC 功能
为了方便用户快速上手 Karpor,karpor-server
的 RBAC(基于角色的访问控制)认证功能默认是关闭的。这意味着 karpor-server
会接受所有请求。然而,这种做法在生产环境中可能会带来显著的风险。我们强烈建议在生产环境中部署 Karpor 时启用 RBAC 认证功能,以保护数据安全。请按照以下说明在安装 Karpor 时启用 RBAC 功能。
helm repo add kusionstack https://kusionstack.github.io/charts
helm repo update
helm install karpor kusionstack/karpor --set server.enableRbac=true
导出 Hub Cluster 的 KubeConfig
由于 Hub Cluster 需要 KubeConfig 进行验证,可以通过以下命令一键导出用于访问 Hub Cluster 的 KubeConfig。
# 以下操作在安装 Karpor 的 Kubernetes 集群中运行
kubectl get configmap karpor-kubeconfig -n karpor -o go-template='{{.data.config}}' > $HOME/.kube/karpor-hub-cluster.kubeconfig
注意:确保本地可访问 Hub Cluster kubeconfig 中的 server 地址。默认为集群内部地址 (https://karpor-server.karpor.svc:7443),本地无法直接连接。如在本地部署 Karpor,需将 karpor-server 服务转发至本地 7443 端口,并将 server 地址改为 https://127.0.0.1:7443
。
你可以使用以下 sed 命令将 Hub 集群证书中的访问地址更改为本地地址:
对于 MacOS/BSD 系统(需要在 -i
后添加 ''
):
sed -i '' 's/karpor-server.karpor.svc/127.0.0.1/g' $HOME/.kube/karpor-hub-cluster.kubeconfig
对于 Linux/GNU 系统(仅需要 -i
):
sed -i 's/karpor-server.karpor.svc/127.0.0.1/g' $HOME/.kube/karpor-hub-cluster.kubeconfig
对于 Windows 系统: 请手动修改 kubeconfig 文件中的服务器地址。
将 Hub Cluster 的服务转发到本地
在本节中,我们假设你将 Karpor 部署在了本地集群(比如用 kind 或者 minikube 创建的集群)。
如上节所说,为了在本地访问 Hub Cluster,你需要将 karpor-server 的服务转发到本地。如果你使用了其他方法进行了转发,可以跳过这一步。这里使用简单的 port-forward 进行转发,打开另一个终端,运行:
# 以下操作在安装 Karpor 的 Kubernetes 集群中运行
kubectl -n karpor port-forward svc/karpor-server 7443:7443
为你的用户创建 ServiceAccount 和 ClusterRoleBinding
本节将指导你如何在 Hub Cluster 中创建 karpor-admin 和 karpor-guest 用户,并为它们分配相应的 ClusterRoleBinding。以下是具体的操作步骤:
首先,指定 kubectl 连接的目标集群为 Hub Cluster:
export KUBECONFIG=$HOME/.kube/karpor-hub-cluster.kubeconfig
然后,我们将创建两个常用的身份:管理员(karpor-admin)和访客(karpor-guest)。这个过程包括创建 ServiceAccount 并将其绑定到相应的 ClusterRole:
kubectl create serviceaccount karpor-admin
kubectl create clusterrolebinding karpor-admin --clusterrole=karpor-admin --serviceaccount=default:karpor-admin
kubectl create serviceaccount karpor-guest
kubectl create clusterrolebinding karpor-guest --clusterrole=karpor-guest --serviceaccount=default:karpor-guest
为你的用户创建 Token
以下操作需在 Hub Cluster 中执行,请确保已正确设置 kubectl 连接到 Hub Cluster:
export KUBECONFIG=$HOME/.kube/karpor-hub-cluster.kubeconfig
默认情况下,token 的有效期为 1 小时。如果你需要长期使用的 token,可以在生成时指定更长的过期时间。例如:
kubectl create token karpor-admin --duration=1000h
默认参数下, token 的最长有效期为 8760h(1 年)。如果你需要修改这个最长有效期,可以在 karpor-server 的启动参数中添加 --service-account-max-token-expiration={MAX_EXPIRATION:h/m/s}
。
注意:创建 token 需要 v1.25.0 或更高版本的 kubectl 。
开始安全地使用 Karpor
复制刚刚生成的 token,粘贴到 Karpor dashboard 的 token 输入框中, 点击登录。
在安全环境下开启你的 Karpor 之旅吧!