Skip to content

Commit 307d09b

Browse files
committed
docs: Add user management tutorial. #245
1 parent 7e85f4f commit 307d09b

File tree

3 files changed

+127
-2
lines changed

3 files changed

+127
-2
lines changed

README.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ RadonDB MySQL Kubernetes supports deployment and management of RaodnDB MySQL clu
2828
- [Monitoring and alerting](docs/deploy_monitoring.md)
2929
- [Backups](docs/deploy_backup_restore_s3.md)
3030
- Logs
31-
- Account management
31+
- [Account management](docs/mgt_mysqluser.md)
3232

3333
## Quick Start
3434

README_zh.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ RadonDB MySQL Kubernetes支持在[Kubernetes](https://kubernetes.io)和[KubeSphe
2828
- [监控告警](docs/deploy_monitoring.md)
2929
- [备份](docs/deploy_backup_restore_s3.md)
3030
- 集群日志管理
31-
- 账户管理
31+
- [账户管理](docs/mgt_mysqluser.md)
3232

3333
## 快速开始
3434

docs/mgt_mysqluser.md

Lines changed: 125 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,125 @@
1+
# 使用 MysqlUser CRD 管理 MySQL用户
2+
3+
## 前提条件
4+
5+
* 已部署 [RadonDB MySQL 集群](kubernetes/deploy_radondb-mysql_operator_on_k8s.md)
6+
7+
## 创建用户帐号
8+
9+
### 1. 校验 CRD
10+
11+
使用如下指令,将查看到名称为 `mysqlusers.mysql.radondb.com` 的 CRD。
12+
13+
```plain
14+
kubectl get crd | grep MysqlUser
15+
mysqlusers.mysql.radondb.com 2021-09-21T09:15:08Z
16+
```
17+
18+
### 2. 创建 Secret
19+
20+
RadonDB MySQL 使用 K8S 中的 [Secret](https://kubernetes.io/docs/concepts/configuration/secret/) 对象保存用户的密码。
21+
22+
使用如下指令,将使用[示例配置](#Secret)创建一个名为 `sample-user-password` 的 Secret。
23+
24+
```plain
25+
kubectl apply -f https://raw.githubusercontent.com/radondb/radondb-mysql-kubernetes/main/config/samples/mysqluser_secret.yaml
26+
```
27+
28+
### 3. 创建用户
29+
30+
使用如下指令,将使用[示例配置](#MysqlUser)创建一个名为 `sample_user` 的用户。
31+
32+
```plain
33+
kubectl apply -f https://raw.githubusercontent.com/radondb/radondb-mysql-kubernetes/main/config/samples/mysql_v1alpha1_mysqluser.yaml
34+
```
35+
36+
> 注意;直接修改 spec.user(用户名) 等同于以新用户名创建一个用户。如需创建多个用户,请确保 metadata.name(CR 实例名) 与 spec.user(用户名)一一对应。
37+
38+
## 修改用户帐号
39+
40+
用户帐号信息由 spec 字段中参数定义,目前支持:
41+
42+
* 修改 `hosts` 参数。
43+
* 新增 `permissions` 参数。
44+
45+
### 授权 IP
46+
47+
允许使用用户帐号的 IP,通过 `hosts` 字段参数定义。
48+
49+
* % 表示所有 IP 均可访问。
50+
* 可修改一个或多个 IP。
51+
52+
```plain
53+
hosts:
54+
- "%"
55+
```
56+
57+
### 用户权限
58+
59+
用户帐号数据库访问权限,通过 MysqlUser 中 permissions 字段参数定义。可通过新增 permissions 字段参数值,实现用户帐号权限的新增。
60+
61+
```plain
62+
permissions:
63+
- database: "*"
64+
tables:
65+
- "*"
66+
privileges:
67+
- SELECT
68+
```
69+
70+
* `database` 参数表示该用户帐号允许访问的数据库。* 代表允许访问集群所有数据库。
71+
* `tables` 参数表示该用户帐号允许访问的数据库表。 * 代表允许访问数据库中所有表。
72+
* `privileges` 参数表示该用户帐号被授权的数据库权限。更多权限说明,请参见 [Privileges Supported by MySQL](https://dev.mysql.com/doc/refman/5.7/en/grant.html)
73+
74+
## 删除用户帐号
75+
76+
使用如下指令将删除使用[示例配置](#MysqlUser)创建的 MysqlUser CR。
77+
78+
```plain
79+
kubectl delete mysqluser sample-user-cr
80+
```
81+
82+
>说明:删除 MysqlUser CR 会自动删除 CR 对应的 MySQL 用户。
83+
84+
## 示例配置
85+
86+
### Secret
87+
88+
```plain
89+
apiVersion: v1
90+
kind: Secret
91+
metadata:
92+
name: sample-user-password # 密钥名称。应用于 MysqlUser 中的 secretSelector.secretName。
93+
data:
94+
pwdForSample: UmFkb25EQkAxMjMKIA== #密钥键,应用于 MysqlUser 中的 secretSelector.secretKey。示例密码为 base64 加密的 RadonDB@123
95+
# pwdForSample2:
96+
# pwdForSample3:
97+
```
98+
99+
### MysqlUser
100+
101+
```plain
102+
apiVersion: mysql.radondb.com/v1alpha1
103+
kind: MysqlUser
104+
metadata:
105+
106+
name: sample-user-cr # 用户 CR 名称,建议使用一个用户 CR 管理一个用户。
107+
spec:
108+
user: sample_user # 需要创建/更新的用户的名称。
109+
hosts: # 支持访问的主机,可以填多个,% 代表所有主机。
110+
- "%"
111+
permissions:
112+
- database: "*" # 数据库名称,* 代表所有数据库。
113+
tables: # 表名称,* 代表所有表。
114+
- "*"
115+
privileges: # 权限,参考 https://dev.mysql.com/doc/refman/5.7/en/grant.html。
116+
- SELECT
117+
118+
userOwner: # 指定被操作用户所在的集群。不支持修改。
119+
clusterName: sample
120+
nameSpace: default # radondb mysql 集群所在的命名空间。
121+
122+
secretSelector: # 指定用户的密钥和保存当前用户密码的键。
123+
secretName: sample-user-password # 密钥名称。
124+
secretKey: pwdForSample # 密钥键,一个密钥可以保存多个用户的密码,以键区分。
125+
```

0 commit comments

Comments
 (0)