设为首页 收藏本站
查看: 706|回复: 0

[经验分享] MySQL8.0——role功能

[复制链接]

尚未签到

发表于 2018-10-4 06:14:17 | 显示全部楼层 |阅读模式
  MySQL8.0新增了role功能:
  role可以看做一个权限的集合,这个集合有一个统一的名字role名。可以给多个账户统一的某个role的权限权限的修改直接通过修改role来实现,不需要每个账户一个一个的grant权限,方便运维和管理。role可以创建、删除、修改并作用到他管理的账户上。(和Oracle数据库中的角色差不多)
  官方文档:
  https://dev.mysql.com/doc/refman/8.0/en/roles.html
  官方给的案例:
  --创建3个角色:
  mysql> CREATE ROLE 'app_developer', 'app_read', 'app_write';
  --给每个角色授权:
  mysql> GRANT ALL ON app_db.* TO 'app_developer';    --:app_db给这个角色所有权限
  mysql> GRANT SELECT ON app_db.* TO 'app_read';      --:app_db给这个角色只读权限
  mysql> GRANT INSERT, UPDATE, DELETE ON app_db.* TO 'app_write';   --:app_db给这个角色写权限
  --给每个用户授予不同的角色:
  GRANT 'app_developer' TO 'dev1'@'localhost';
  GRANT 'app_read' TO 'read_user1'@'localhost', 'read_user2'@'localhost';
  GRANT 'app_read', 'app_write' TO 'rw_user1'@'localhost';
  --当然,还可以针对某个表的权限 做角色,如:
  mysql> grant select on testdb.emp to app_read;
  2、强制定义角色:mandatory_roles
  通过在mandatory_roles系统变量的值做设置,可以指定角色为强制性的。服务器将强制角色视为授予所有用户,因此不需要显式地授予任何帐户。
  在配置文件中,添加:
  [mysqld]
  mandatory_roles='role1,role2@localhost,r3@%.example.com'
  或者,在命令行中执行:
  SET PERSIST mandatory_roles = 'role1,role2@localhost,r3@%.example.com';
  例子:
  ①:首先建一个角色并授权:
  mysql> CREATE ROLE app_developer;
  mysql> GRANT ALL ON test.* TO app_developer;
  --然后我们把这个参数设成这个角色:(意思是:凡是创建的用户指定了@'%'用户可以在任意客户端登录数据库,默认创建用户会拥有app_developer角色)
  mysql> SET PERSIST mandatory_roles = 'app_developer@%';
  --然后我们创建一个用户 并不赋权

  mysql> create user test_user@'%'>  mysql> FLUSH PRIVILEGES;
  --使用新用户登录数据库,然后可以直接set这个role
  mysql> set role app_developer;
  mysql> show databases;
  +--------------------+
  | Database           |
  +--------------------+
  | information_schema |
  | test               |
  +--------------------+
  2 rows in set (0.00 sec)
  注意:当一个角色被set了之后是不可以被删除的
  3、检查用户的权限或角色,如:
  mysql> SHOW GRANTS FOR zhang@'%';
  +-----------------------------------+
  | Grants for zhang@%                |
  +-----------------------------------+
  | GRANT USAGE ON *.* TO `zhang`@`%` |
  +-----------------------------------+
  1 row in set (0.00 sec)
  --扩展显示,把授予角色的内容也显示出来:
  mysql> SHOW GRANTS FOR 'zhang'@'%' USING 'app_developer';
  +-------------------------------------------------+
  | Grants for zhang@%                              |
  +-------------------------------------------------+
  | GRANT USAGE ON *.* TO `zhang`@`%`               |
  | GRANT ALL PRIVILEGES ON `test`.* TO `zhang`@`%` |
  +-------------------------------------------------+
  2 rows in set (0.00 sec)
  4、移除角色:
  REVOKE role FROM user;
  或者,将角色的权限移除:
  REVOKE INSERT, UPDATE, DELETE ON app_db.* FROM 'app_write';
  5、删除角色
  DROP ROLE 'app_read', 'app_write';


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-611557-1-1.html 上篇帖子: 利用tcpdump简易抓取MySQL Query Log-10931853 下篇帖子: mysql的explain关键参数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表