亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL 角色(role)功能介紹

瀏覽:4日期:2023-10-03 16:38:05
前言:

上篇文章,我們介紹了 MySQL 權(quán)限管理相關(guān)知識(shí)。當(dāng)數(shù)據(jù)庫(kù)實(shí)例中存在大量的庫(kù)或用戶時(shí),權(quán)限管理將會(huì)變得越來(lái)越繁瑣,可能要頻繁進(jìn)行權(quán)限變更。MySQL 8.0 新增了 role 功能,使得權(quán)限管理更加方便,本篇文章我們來(lái)看下 8.0 下的 role 功能。

1. role 簡(jiǎn)介

role 角色功能對(duì)于 Oracle 數(shù)據(jù)庫(kù)來(lái)說(shuō)不算是什么特殊,在 Oracle 中經(jīng)常被用到。MySQL 8.0 版本終于新增了 role 功能,為數(shù)據(jù)庫(kù)用戶權(quán)限管理提供了一種新思路。

role 可以看做一個(gè)權(quán)限的集合,這個(gè)集合有一個(gè)統(tǒng)一的名字 role 名。可以給多個(gè)數(shù)據(jù)庫(kù)用戶授予同個(gè) role 的權(quán)限,權(quán)限變更可直接通過(guò)修改 role 來(lái)實(shí)現(xiàn),不需要每個(gè)用戶一個(gè)一個(gè)的去變更,方便運(yùn)維和管理。role 可以創(chuàng)建、刪除、修改并作用到它管理的用戶上。

下面我們具體來(lái)體驗(yàn)下 role 角色功能:

# 創(chuàng)建rolemysql> create role ’dev_role’;Query OK, 0 rows affected (0.15 sec)# 給role授予權(quán)限mysql> grant select on db1.* to ’dev_role’@’%’;Query OK, 0 rows affected (0.12 sec)# 查看role的權(quán)限mysql> show grants for ’dev_role’@’%’;+-------------------------------------------+| Grants for dev_role@% |+-------------------------------------------+| GRANT USAGE ON *.* TO `dev_role`@`%` || GRANT SELECT ON `db1`.* TO `dev_role`@`%` |+-------------------------------------------+# 創(chuàng)建用戶 并賦予角色權(quán)限mysql> create user ’dev1’@’%’ identified by ’123456’;Query OK, 0 rows affected (0.68 sec)mysql> grant ’dev_role’ to ’dev1’@’%’;Query OK, 0 rows affected (0.38 sec)# 查看用戶權(quán)限mysql> show grants for ’dev1’@’%’;+------------------------------------+| Grants for dev1@% |+------------------------------------+| GRANT USAGE ON *.* TO `dev1`@`%` || GRANT `dev_role`@`%` TO `dev1`@`%` |+------------------------------------+2 rows in set (0.63 sec)# 使用dev1用戶登錄root@localhost ~]# mysql -udev1 -p123456mysql> show databases;+--------------------+| Database |+--------------------+| information_schema |+--------------------+1 row in set (0.34 sec)mysql> select CURRENT_ROLE();+----------------+| CURRENT_ROLE() |+----------------+| NONE |+----------------+1 row in set (0.59 sec)

什么情況?貌似和我們想象不同,賦予用戶某個(gè)角色權(quán)限后,該用戶并沒(méi)有獲得相應(yīng)權(quán)限。

出現(xiàn)上述情況的原因是,在用戶會(huì)話中,授予該用戶的角色處于非活動(dòng)狀態(tài)。只有授予的角色在會(huì)話中處于活動(dòng)狀態(tài)時(shí),該用戶才擁有此角色的權(quán)限,要確定當(dāng)前會(huì)話中哪些角色處于活動(dòng)狀態(tài),可以使用 CURRENT_ROLE() 函數(shù)。

# 使用 set default role 命令激活角色mysql> SET DEFAULT ROLE ALL TO dev1;Query OK, 0 rows affected (0.77 sec)# 重新登錄 發(fā)現(xiàn)權(quán)限正常root@localhost ~]# mysql -udev1 -p123456mysql> select CURRENT_ROLE();+----------------+| CURRENT_ROLE() |+----------------+| `dev_role`@`%` |+----------------+1 row in set (0.57 sec)mysql> show databases;+--------------------+| Database |+--------------------+| db1|| information_schema |+--------------------+2 rows in set (1.05 sec)

除了使用 set default role 命令激活角色外,還可以修改系統(tǒng)變量 activate_all_roles_on_login ,該變量決定是否自動(dòng)激活 role ,默認(rèn)為 OFF 即不自動(dòng)激活,建議將該變量改為 ON ,這樣以后賦予角色給新用戶后就不需要再手動(dòng)激活了。

# 查看 activate_all_roles_on_login 變量mysql> show variables like ’activate_all_roles_on_login’;+-----------------------------+-------+| Variable_name | Value |+-----------------------------+-------+| activate_all_roles_on_login | OFF |+-----------------------------+-------+1 row in set (1.53 sec)# 啟用該變量 先動(dòng)態(tài)啟用 之后可以將此參數(shù)加入my.cnf配置文件中mysql> set global activate_all_roles_on_login = on;Query OK, 0 rows affected (0.50 sec)# 之后角色就會(huì)自動(dòng)激活mysql> create user ’dev2’@’%’ identified by ’123456’;Query OK, 0 rows affected (0.68 sec)mysql> grant ’dev_role’ to ’dev2’@’%’;Query OK, 0 rows affected (0.38 sec)root@localhost ~]# mysql -udev2 -p123456mysql> select CURRENT_ROLE();+----------------+| CURRENT_ROLE() |+----------------+| `dev_role`@`%` |+----------------+1 row in set (0.57 sec)mysql> show databases;+--------------------+| Database |+--------------------+| db1|| information_schema |+--------------------+2 rows in set (1.05 sec) 2. role 相關(guān)操作

上面我們介紹了創(chuàng)建角色及給用戶授予角色權(quán)限,關(guān)于 role 相關(guān)操作還有很多,我們接著來(lái)看下。

# 變更角色權(quán)限mysql> grant select on db2.* to ’dev_role’@’%’;Query OK, 0 rows affected (0.33 sec)# 擁有該角色的用戶 重新登錄后權(quán)限也會(huì)對(duì)應(yīng)變化root@localhost ~]# mysql -udev1 -p123456mysql> show databases;+--------------------+| Database |+--------------------+| db1|| db2|| information_schema |+--------------------+3 rows in set (2.01 sec)# 回收角色權(quán)限mysql> revoke SELECT ON db2.* from ’dev_role’@’%’;Query OK, 0 rows affected (0.31 sec)# 撤銷用戶的角色mysql> revoke ’dev_role’@’%’ from ’dev1’@’%’;Query OK, 0 rows affected (0.72 sec)mysql> show grants for ’dev1’@’%’;+----------------------------------+| Grants for dev1@%|+----------------------------------+| GRANT USAGE ON *.* TO `dev1`@`%` |+----------------------------------+1 row in set (1.06 sec)# 刪除角色 (刪除角色后 對(duì)應(yīng)的用戶也會(huì)失去該角色的權(quán)限)mysql> drop role dev_role;Query OK, 0 rows affected (0.89 sec)

我們還可以通過(guò) mandatory_roles 變量來(lái)配置強(qiáng)制性角色。使用強(qiáng)制性角色,服務(wù)器會(huì)為全部的用戶戶默認(rèn)賦予該角色,而不需要顯示執(zhí)行授予角色。可以使用 my.cnf 文件或者使用 SET PERSIST 進(jìn)行配置,例如:

# my.cnf 配置[mysqld]mandatory_roles=’dev_role’# set 更改變量SET PERSIST mandatory_roles = ’dev_role’;

需要注意的是,配置在 mandatory_roles 中的角色不能撤銷其權(quán)限,也不能刪除。

總結(jié):

關(guān)于 role 角色相關(guān)知識(shí),簡(jiǎn)單總結(jié)幾點(diǎn)如下:

role 是一個(gè)權(quán)限的集合,可以被賦予不同權(quán)限。 開(kāi)啟 activate_all_roles_on_login 變量,才可以自動(dòng)激活角色。 一個(gè)用戶可以擁有多個(gè)角色,一個(gè)角色也可以授予多個(gè)用戶。 角色權(quán)限變化會(huì)應(yīng)用到對(duì)應(yīng)用戶。 刪除角色,則擁有此角色的用戶也會(huì)喪失此角色的權(quán)限。 可設(shè)置強(qiáng)制性角色,使得所有用戶都擁有此角色的權(quán)限。 角色管理和用戶管理相似,只是角色不能用于登錄數(shù)據(jù)庫(kù)。

以上就是MySQL 角色(role)功能介紹的詳細(xì)內(nèi)容,更多關(guān)于MySQL 角色(role)功能的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 黄色视频毛片 | 91色在线观看国产 | 国产九色在线播放 | 亚洲色图欧美视频 | 欧美日韩国产超高清免费看片 | 青青青视频精品中文字幕 | a毛片免费全部在线播放毛 a毛片免费全部播放毛 | 中国国产一级毛片视频 | 伊人网综合在线视频 | 国产麻豆一级在线观看 | 国产在线播 | 麻豆视频免费观看 | 亚洲天堂婷婷 | 国产成人综合久久精品红 | 91精品国产免费久久久久久青草 | 国产xxxxx片免费观看 | 国产乱理 | 亚洲精品一区二区三区中文字幕 | 亚洲第成色999久久网站 | 日本老太婆一级毛片免费 | 一级毛片不卡片免费观看 | 亚洲成人黄色网址 | 中文字幕 日韩在线 | 久热re这里只有精品视频 | 国产亚洲女人久久久久久 | 激情网址在线观看 | 毛片免费观看日本中文 | 2020年国产精品午夜福利在线观看 | 欧美日韩中文字幕久久伊人 | 国产三级在线看 | 在线精品国精品国产不卡 | 亚洲国产日韩欧美高清片a 亚洲国产日韩欧美一区二区三区 | 免费观看日本污污ww网站一区 | 欧美色片在线观看 | 中国一级特黄毛片 | a男人的天堂久久a毛片 | 51精品国产| 中国黄色片视频 | 国产亚洲精品成人a在线 | 9i9精品国产免费久久 | 在线观看亚洲一区二区 |