|
| 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