管理用户权限
Chaos Mesh 使用 Kubernetes 原生的 RBAC 功能来管理用户角色和权限。用户在创建、查看、管理混沌实验时,需要拥有 这个 apiGroups
下混沌实验自定义资源的相应权限。
注意
使用 Helm 安装 Chaos Mesh 时,默认开启权限验证功能。对于生产环境及其他安全要求较高的场景,建议保持权限验证功能开启。如果只是想体验 Chaos Mesh 的功能,希望关闭权限验证从而快速创建混沌实验,可以直接参阅权限验证功能的开启及关闭部分了解如何关闭权限验证。
你可以直接通过 Chaos Mesh Dashboard 界面创建用户并绑定权限。在访问 Dashboard 时会有登录窗口弹出,点击“点击这里生成”:
点击后,弹出的窗口如下所示:
需在弹出的窗口上执行下面的操作至第 3 步:
选择权限范围
如要获取整个 Kubernetes 混沌实验的相应权限,勾选集群范围方框。如果在命名空间下拉选项中指定了 namespace,则只获取该 namespace 下的权限。
-
目前 Chaos Mesh 提供了以下角色:
- Manager:拥有混沌实验的创建、查看、更新、删除等所有权限。
- Viewer:只拥有混沌实验的查看权限。
生成 RBAC 配置
在确定了所创建权限的范围和角色后,Dashboard 页面上会显示对应的 RBAC 配置。例如,
busybox
namespace 下 Manager 角色的 RBAC 配置如下所示:``` kind: ServiceAccount apiVersion: v1 metadata:
---
kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
namespace: busybox
name: role-busybox-manager-zcbaf
rules:
- apiGroups: [""]
resources: ["pods", "namespaces"]
- apiGroups:
- chaos-mesh.org
resources: [ "*" ]
verbs: ["get", "list", "watch", "create", "delete", "patch", "update"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
name: bind-busybox-manager-zcbaf
namespace: busybox
subjects:
- kind: ServiceAccount
name: account-busybox-manager-zcbaf
namespace: busybox
roleRef:
kind: Role
name: role-busybox-manager-zcbaf
```
点击 Dashboard 窗口中 RBAC 配置右上角的**复制**将 RBAC 配置内容复制到剪切板,然后写入到本地文件 `rbac.yaml`。
创建用户并绑定权限
在终端中运行以下命令:
生成令牌
复制 Dashboard 中第 3 步“最后获取令牌”下的命令,并在终端中运行:
kubectl describe -n busybox secrets account-busybox-manager-zcbaf
输出如下所示:
Type: kubernetes.io/service-account-token
Data
====
ca.crt: 1025 bytes
namespace: 7 bytes
token: eyJhbGciOi...z-PWMK8iQ
```
复制以上输出中的 token 的数据,用于下一步的登录。
使用创建的用户登录 Chaos Mesh
点击 Dashboard 令牌辅助生成器窗口上的关闭,返回到登录窗口。在令牌输入框中输入上一步复制的 token 数据,并在名称输入框中给该令牌输入一个有意义的名称,建议使用权限的范围和角色,例如
busybox-manager
。输入完成后,点击提交进行登录:
注意
需要保证执行 kubectl 的本地用户具有集群的管理权限,从而可以创建用户、绑定不同的权限、并获取 token。
如要管理令牌,在 Dashboard Web 页面中点击设置,如下所示:
可以在添加令牌窗口中继续添加新的令牌,也可以点击使用以切换不同权限的令牌,或者删除令牌。
使用 Helm 安装 Chaos Mesh 时,默认开启权限验证功能。对于生产环境及其他安全要求较高的场景,建议都保持权限验证功能开启。如果只是想体验 Chaos Mesh 的功能,希望关闭权限验证从而快速创建混沌实验,可以在 Helm 命令中设置 --set dashboard.securityMode=false
,命令如下所示: