Mysql 权限管理 MySQL权限管理的级别包括
qiyuwang 2024-10-25 16:36 27 浏览 0 评论
前言
为了避免删库跑路的事情,权限管理和数据备份是必要。
机器环境
mysql 8.0.21 x86_64 MySQL Community Serve
centos 7
Mysql 权限管理
Mysql 8.0 可以创建角色,然后将操作数据库、表、索引等的权限赋予给角色,将将角色赋予给用户,也是我们熟悉的 RBAC 模型。
当然也可以将权限直接授予用户。
用户
创建用户
-- 用户名称是由 用户名和登录用户的 ip 一同组成的,% 代表任意 ip
CREATE USER 'db_dev'@'localhost' IDENTIFIED BY 'Mysql@12345678';
修改用户密码
-- 修改用户密码
ALTER USER 'test'@'localhost' IDENTIFIED BY 'password';
锁定用户
-- 锁定用户不能登录
ALTER USER 'db_dev1'@'localhost' ACCOUNT LOCK;
-- 解锁
ALTER USER 'db_dev1'@'localhost' ACCOUNT UNLOCK;
权限
用户的权限信息保存在 information_schema.USER_PRIVILEGES
。也可以在 mysql.user
看到授权信息。
为了避免已经建立的链接的权限无法刷新,需要搭建数据库的时候,权限就要设计好。
有部分权限是可以动态修改的,但是有的权限,在一个会话中是不能修改的。为了避免问题,需要数据库使用之前就要做好权限规划。
权限说明
权限 | 说明 |
---|---|
ALL | 所有的权限,除了 GRANT OPTION and PROXY . |
ALTER | 修改表结构,ALTER TABLE |
CREATE | 创建数据库和表 |
DROP | 删除数据库、表、视图 |
GRANT OPTION | GRANT权限允许你把你自己拥有的那些权限授给其他的用户。可以用于数据库、表和保存的程序。 |
DELETE | 删除表数据 |
INDEX | INDEX权限允许你创建或删除索引。 |
INSERT | 插入表数据 |
SELECT | 查询表数据 |
UPDATE | 更新表数据 |
PROCESS | show processlist 命令显示在服务器内执行的线程的信息(即其它账户相关的客户端执行的语句)。 |
SHOW VIEW | 查看视图 |
SHOW DATABASES | 查看数据库列表,没有授予这个权限,只能查看到 information_schema |
LOCK TABLES | 锁表 |
RELOAD | FLUSH 相关的操作 |
CREATE TABLESPACE | 允许使用操作表空间和日志的语句,比如创建,删除,修改 |
CREATE TEMPORARY TABLES | 创建临时表 |
授权
-- 对从 localhost 登录的用户 db_dev 的数据库:ceshi 中所有表(*) 授予 SHOW DATABASES,SELECT,RELOAD 权限
GRANT SHOW DATABASES,SELECT,RELOAD ON ceshi.* TO 'db_dev'@'localhost';
-- 也可以针对某个表授权,`` 是为了处理关键字,当没有关键字可以 ceshi.test1 就可以
GRANT SELECT ON ceshi.`test1` TO 'db_dev'@'localhost';
-- 刷新权限信息,有的权限是可以动态加载的。为了避免权限出题,每次都执行这个语句
FLUSH PRIVILEGES;
回收权限
-- ON 指定数据库.表
-- FROM 指定用户
REVOKE SHOW DATABASES,SELECT ON *.* FROM 'db_dev'@'localhost';
-- 刷新权限信息
FLUSH PRIVILEGES;
角色
使用数据库的人员可能有,开发,DBA,运营相关(只会查询数据),程序运行。
角色激活
给用户赋予角色之后,角色默认不激活的。用户可以在会话中激活用户赋予的角色。
也可以设置参数,让所有角色都激活,这样用户登录成功,赋予的角色全选就可以使用了
-- 查看当前用户下使用了哪些角色
SELECT CURRENT_ROLE();
-- 登录之后激活定义的所有角色,给用户赋予哪些角色,就可以使用这些角色的权限
SET global activate_all_roles_on_login=ON;
-- 在会话中修改激活哪些角色
SET ROLE ops;
创建及删除角色
-- 开发(dev),db(db),运营(ops),程序运行(app_run)
CREATE ROLE 'app_run', 'db', 'ops', 'dev';
-- 删除角色
DROP ROLE 'db', 'app_run';
给角色分配权限
- 开发
开发一般会,创建数据库和表,crud,操作索引,修改表结构
drop 权限我建议不要给
-- crud,创建
GRANT SELECT, INSERT, UPDATE, DELETE,CREATE,CREATE VIEW,ALTER,SHOW DATABASES,SHOW VIEW,ALTER,INDEX,PROCESS,RELOAD,LOCK TABLES ON *.* TO 'dev';
- db
db 一般拥有所有权限
-- WITH GRANT OPTION 是拥有给用户授权的权限
GRANT ALL PRIVILEGES ON *.* TO 'db' WITH GRANT OPTION;
- 运营相关
基本都是查询语句
-- 或者指定某个具体数据库,或者表
GRANT SELECT,SHOW DATABASES,SHOW VIEW ON *.* TO 'ops';
- 程序运行相关
为了使用 flyway 这种可以修改表结构和索引的组件。对权限赋予 CREATE,INDEX,ALTER.
DELETE 语句不要怕,现在 mybatis plus 类似的组件,都带有安全删除的校验,全表删除或者全表更新必须带条件。在一定程度上避免删除表中所有数据。
GRANT SELECT, INSERT, UPDATE, DELETE,CREATE,CREATE VIEW,SHOW DATABASES,SHOW VIEW,ALTER,INDEX,RELOAD,LOCK TABLES,CREATE TEMPORARY TABLES ON *.* TO 'app_run';
给用户赋予角色
-- 给用户赋予 ops 角色
GRANT 'ops' TO 'db_dev'@'localhost';
撤销角色或者角色的权限
-- 从用户撤销某个角色
REVOKE ops FROM db_dev1@localhost;
-- 从角色中撤销某个权限
REVOKE SHOW VIEW ON *.* FROM 'ops';
-- 刷新权限
FLUSH PRIVILEGES;
查询用户的权限
-- 显示来自 localhost 登录的 test 用户
SHOW GRANTS FOR 'test'@'localhost';
SHOW GRANTS FOR 'root'@'%';
-- 来自某个角色 USEING 指定的角色的权限
SHOW GRANTS FOR 'read_user1'@'localhost' USING 'ops';
本文由 张攀钦的博客 http://www.mflyyou.cn/ 创作。 可自由转载、引用,但需署名作者且注明文章出处。
如转载至微信公众号,请在文末添加作者公众号二维码。微信公众号名称:Mflyyou
相关推荐
- 国服停机更新!LOL美服怎么进详细解答
-
国服停机更新!LOL美服怎么进详细解答嘿,各位召唤师们!是不是国服停机更新,手痒痒想玩玩国际服呢?别担心,我这就来教大家怎么轻松下载并注册英雄联盟LOL的国际服(比如美服、台服),保证让大家一看就懂,...
- 魔兽WLK:ICC测试服即将开放,玩家苦等1年的玩法,国服完美错过
-
虽然魔兽世界WLK版本一共有五个阶段,但是玩家们往往会忽略红玉圣殿这个副本,毕竟这个副本的意义就是引出4.0版本,在剧情上与WLK版本没有太大的关系,因此ICC也成为了《经典三部曲》最后一个值得关注的...
- 国服停机更新!英雄联盟台服怎么进一文详解
-
国服停机更新!英雄联盟台服怎么进一文详解嘿,小伙伴们!是不是有时候觉得国服停机更新,手痒得不行,想继续享受LOL的乐趣?别急,我这就给大家带来一份超级接地气的英雄联盟LOL国际服游玩攻略!国服停机更新...
- 国服测试服首日报告:可排随机5人本,收藏品共享,刷牌子换武器
-
官方发布压测首日收获,创下世界纪录...
- 云顶之弈S14赛季 测试服版本 4月2日即将上线国服 双人模式大改八排
-
今天分享下...
- 射击游戏《无畏契约》国服端游测试服招募开启,11月上旬开测
-
IT之家10月27日消息,腾讯开启射击竞技游戏《无畏契约》国服测试服先锋招募(PC端),仅限可以有稳定使用电脑参与体验的玩家,截至10月30日。IT之家附招募要求:对游戏测试有兴趣,...
- 测试服注意:国服18848已经可以正常登陆
-
最新更新:国服测试服已经可以正常登陆,版本号为18848早期不兼容的解决办法↓(已经用不到啦)注明,这方法是一位叫八神的大神解决的。第一将你的测试服更新到18848.然后打开战网。战网不要退出。下...
- 教部落玩家如何解决国服测试服登陆报错问题
-
德拉诺之王国服内测已经开启。但是选择部落的玩家却发现登陆以后以后经常会报错提示错误132。这是因为部落方面的新模型还没有完成,部落的玩家需要将使用新模型的选项关闭。这样就可以正常的游戏了!具体步骤如...
- 快速匹配开启国服一区测试!确定会取代自选模式
-
9月18日下午,英雄联盟国服宣布了最新改动,快速匹配模式将于9月19日上午10点至9月26日0点在联盟一区进行限时开放新一轮测试,更多的玩家可以体验到这个新模式了。快速匹配模式是拳头游戏在2023年8...
- 国服测试服更新公告:开放百级角色建立
-
国服德拉诺之王测试服最新更新进入,开放了直接建立100级PVE与100级PVP角色的模板,可以直接建立百级角色。要塞也开放了一键升级功能,方便玩家测试体验要塞。运营团队官方公告:我们在今天对《德拉诺之...
- 6.0测试服:国服测试服务器不兼容解决办法
-
今日国服测试服更新后服务器出现不兼容问题,造成国服玩家无法登陆。解决办法如下:此次无法登陆原因为游戏版本号错误导致,打开战网后自动更新32M文件后会造成游戏版本号超前,与目前开放版本不相同的问题,此问...
- 魔兽国服炸服勇士带你进入技术测试(一)
-
6月6日的通告,正式拉开了国服回归的序幕。经历了几日的等待,终于来到了技术测试环节,胖儿坨坨第一时间等待在战网前准备迎接这盛况的景象。当时太激动了,然后就把巫妖王之怒的动画重温了一遍。那个男人又回来了...
- 腾讯《暗区突围:无限》端游国服体验服限量招募
-
IT之家9月24日消息,腾讯游戏今日发文宣布,《暗区突围:无限》端游国服体验服将于10月上线,现开启体验服限量招募。IT之家此前报道,该游戏海外版已于今年8月开启不限号测试,新增前线要...
- 兔玩网分享下载美服测试客户端登陆国服方法
-
德拉诺之王国服测试服客户端下载链接,魔兽世界国服6.0内测客户端下载,其实美服和国服的客户端是可以通用,目前小编还没有找到国服的客户端下载,为了满足一些饥渴的玩家,所以小编现将美服客户端下的下载地址以...
- 英雄联盟手游不限号测试开服活动指南:快速入手丰厚福利
-
经过广大玩家漫长而热切的期盼,英雄联盟手游国服终于在10月8日开启了不限号测试。而为了回报玩家的久等与支持,英雄联盟手游国服推出了大量内容精彩奖励丰厚的开服活动。刚刚加入游戏的萌新玩家,是否还对复杂多...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- navicat无法连接mysql服务器 (65)
- 下横线怎么打 (71)
- flash插件怎么安装 (60)
- lol体验服怎么进 (66)
- ae插件怎么安装 (62)
- yum卸载 (75)
- .key文件 (63)
- cad一打开就致命错误是怎么回事 (61)
- rpm文件怎么安装 (66)
- linux取消挂载 (81)
- ie代理配置错误 (61)
- ajax error (67)
- centos7 重启网络 (67)
- centos6下载 (58)
- mysql 外网访问权限 (69)
- centos查看内核版本 (61)
- ps错误16 (66)
- nodejs读取json文件 (64)
- centos7 1810 (59)
- 加载com加载项时运行错误 (67)
- php打乱数组顺序 (68)
- cad安装失败怎么解决 (58)
- 因文件头错误而不能打开怎么解决 (68)
- js判断字符串为空 (62)
- centos查看端口 (64)