首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >启用RBAC后,使用kubectl访问Kubernetes API失败

启用RBAC后,使用kubectl访问Kubernetes API失败
EN

Stack Overflow用户
提问于 2018-04-17 21:09:18
回答 2查看 479关注 0票数 0

我正在尝试在我的集群上启用RBAC,并将以下行添加到kube-apiserver.yml中:

- --authorization-mode=RBAC
- --runtime-config=rbac.authorization.k8s.io/v1beta1
- --authorization-rbac-super-user=admin

我做了systemctl重新启动kubelet;apiserver启动成功,但我无法运行kubectl命令,我得到了这个错误:

kubectl get po 
Error from server (Forbidden): pods is forbidden: User "kubectl" cannot list pods in the namespace "default"

我哪里出错了,或者我应该为kubectl用户创建一些角色?如果是这样,这是如何实现的

EN

回答 2

Stack Overflow用户

发布于 2018-04-17 21:18:35

来自服务器的

错误(禁止):pods被禁止:用户kubectl不能列出命名空间default中的pod

您正在使用用户kubectl通过kubectl实用程序访问集群,但是您设置了--authorization-rbac-super-user=admin,这意味着您的超级用户是admin

要解决此问题,请使用超级用户"kubectl“而不是”admin“启动kube-apiserver。

只需更新选项的值:--authorization-rbac-super-user=kubectl

票数 0
EN

Stack Overflow用户

发布于 2018-09-29 06:56:14

老问题,但对于谷歌搜索者来说,你可以使用不安全的端口:

如果您的API服务器在启用了不安全端口(-- insecure - port )的情况下运行,您还可以通过该端口进行API调用,这不会强制执行身份验证或授权。

来源:https://kubernetes.io/docs/reference/access-authn-authz/rbac/#privilege-escalation-prevention-and-bootstrapping

因此,将--insecure-port=8080添加到kube-apiserver选项中,然后重新启动它。

然后运行:

kubectl create clusterrolebinding kubectl-cluster-admin-binding --clusterrole=cluster-admin --user=kubectl

然后关闭不安全端口。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49879027

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档