更新时间:2024-09-24 GMT+08:00
基于角色的权限管理(RBAC)
什么是基于角色的用户管理?
- 基于角色的用户管理(Role-Based Access Control,简称RBAC)是通过为角色赋予权限,使用户成为适当的角色而获取相应角色的权限。
- 角色是一组权限的抽象。
- 使用RBAC可以极大简化对权限的管理。
什么是RBAC模型?
为角色赋予适当的权限。
指定用户为相应的角色。
场景介绍
假设有两个SCHEMA:s1,s2。
有两组用户:
- 一组用户包括u1,u2,可以在s1中查询所有表,在s2中更新所有表。
- 另一组用户包括u3,u4,可以在s2中查询所有表,在s1中更新所有表。
授予权限操作步骤
- 使用系统管理员dbadmin连接GaussDB(DWS)数据库。
- 复制以下语句在窗口1中执行,创建本用例的SCHEMA s1和s2,用户u1~u4。
示例中{password}请替换成实际密码。
1 2 3 4 5 6
CREATE SCHEMA s1; CREATE SCHEMA s2; CREATE USER u1 PASSWORD '{password}'; CREATE USER u2 PASSWORD '{password}'; CREATE USER u3 PASSWORD '{password}'; CREATE USER u4 PASSWORD '{password}';
- 复制以下语句在窗口1中执行,创建对应的s1.t1,s2.t1表。
1 2
CREATE TABLE s1.t1 (c1 int, c2 int); CREATE TABLE s2.t1 (c1 int, c2 int);
- 复制以下语句在窗口1中执行,为表插入数据。
1 2
INSERT INTO s1.t1 VALUES (1,2); INSERT INTO s2.t1 VALUES (1,2);
- 复制以下语句在窗口1中执行,创建4个角色。分别对应s1的查询权限、s1的更新权限、s2的查询权限、s2的更新权限。
1 2 3 4
CREATE ROLE rs1_select PASSWORD disable; --s1的查询权限 CREATE ROLE rs1_update PASSWORD disable; --s1的更新权限 CREATE ROLE rs2_select PASSWORD disable; --s2的查询权限 CREATE ROLE rs2_update PASSWORD disable; --s2的更新权限
- 复制以下语句在窗口1中执行,将SCHEMA s1和s2的访问权限先授予这些角色。
1
GRANT USAGE ON SCHEMA s1, s2 TO rs1_select, rs1_update,rs2_select, rs2_update;
- 复制以下语句在窗口1中执行,将具体的权限授予这些角色。
1 2 3 4
GRANT SELECT ON ALL TABLES IN SCHEMA s1 TO rs1_select; --将s1下的所有表的查询权限授予角色rs1_select GRANT SELECT,UPDATE ON ALL TABLES IN SCHEMA s1 TO rs1_update; --将s1下的所有表的查询、更新权限授予角色rs1_update GRANT SELECT ON ALL TABLES IN SCHEMA s2 TO rs2_select; --将s2下的所有表的查询权限授予角色rs2_select GRANT SELECT,UPDATE ON ALL TABLES IN SCHEMA s2 TO rs2_update; --将s2下的所有表的查询、更新权限授予角色rs2_update
- 复制以下语句在窗口1中执行,将对应的角色授予对应的用户,实现将一组权限授予用户。
1 2
GRANT rs1_select, rs2_update TO u1, u2; --u1,u2可以对s1的查询权限、对s2的更新权限。 GRANT rs2_select, rs1_update TO u3, u4; --u3,u4可以对s2的查询权限、对s1的更新权限。
- 复制以下语句在窗口1中执行,可以查看指定用户绑定的角色。
1
\du u1;
- 重新打开一个会话窗口2,以用户u1连接DWS数据库。
1
gsql -d gaussdb -h <DWS的公网IP> -U u1 -p 8000 -r -W {password};
- 复制以下语句在窗口2中执行,验证用户u1对s1.t1有查询权限而没有更新权限。
1 2
SELECT * FROM s1.t1; UPDATE s1.t1 SET c2 = 3 WHERE c1 = 1;
- 复制以下语句在窗口2中执行,验证用户u1对s2.t1有更新权限。
1 2
SELECT * FROM s2.t1; UPDATE s2.t1 SET c2 = 3 WHERE c1 = 1;
父主题: 数据库管理