欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql8.0 用戶角色管理及授權(quán)的實(shí)現(xiàn)

 更新時(shí)間:2024年04月24日 10:45:33   作者:傲驕鹿先生  
MySQL是一種常見的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它提供了強(qiáng)大的安全機(jī)制來管理用戶權(quán)限,本文主要介紹了mysql8.0 用戶角色管理及授權(quán)的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下

一、用戶管理

1.1 用戶授權(quán)

MySQL8.0的用戶授權(quán)和之前有所區(qū)別,老版本的常用授權(quán)語句在8.0中會(huì)報(bào)錯(cuò):

MySQL8.0之前版本:

GRANT ALL ON *.* TO `wangwei`@`127.0.0.1` IDENTIFIED BY 'passowrd' WITH GRANT OPTION;

MySQL8.0版本:

# 8.0版本需要將創(chuàng)建用戶和授權(quán)進(jìn)行分步進(jìn)行:

# 創(chuàng)建賬號密碼
CREATE USER `wangwei`@`127.0.0.1` IDENTIFIED BY 'passowrd';

# 授予權(quán)限
GRANT ALL ON *.* TO `wangwei`@`127.0.0.1` WITH GRANT OPTION;

# 刪除權(quán)限
REVOKE all privileges ON databasename.tablename FROM 'username'@'host';

# 修改密碼
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的密碼';


# 創(chuàng)建帶過期時(shí)間的用戶:
CREATE USER `wangwei`@`127.0.0.1` IDENTIFIED BY 'wangwei' PASSWORD EXPIRE INTERVAL 90 DAY;

GRANT ALL ON *.* TO `wangwei`@`127.0.0.1` WITH GRANT OPTION;

1.2、修改密碼

密碼過期時(shí)間管理,要全局建立自動(dòng)密碼到期策略,請使用default_password_lifetime系統(tǒng)變量。其默認(rèn)值為0,禁用自動(dòng)密碼過期。

如果值default_password_lifetime正整數(shù)N,則表示允許的密碼生存期,以便密碼必須每天更改N??梢约釉谂渲梦募校?/p>

1:要建立全局策略,密碼的使用期限大約為六個(gè)月,請?jiān)诜?wù)器my.cnf文件中使用以下行啟動(dòng)服務(wù)器:

[mysqld]default_password_lifetime=180

2:要建立全局策略,以便密碼永不過期,請將其設(shè)置default_password_lifetime為0:

[mysqld]default_password_lifetime=0

這個(gè)參數(shù)是可以動(dòng)態(tài)設(shè)置并保存的:

SET PERSIST default_password_lifetime = 180;SET PERSIST default_password_lifetime = 0;

創(chuàng)建和修改帶有密碼過期的用戶,帳戶特定的到期時(shí)間設(shè)置示例:

# 要求每90天更換密碼:
CREATE USER 'wangwei'@'localhost' PASSWORD EXPIRE INTERVAL 90 DAY;
ALTER  USER 'wangwei'@'localhost' PASSWORD EXPIRE INTERVAL 90 DAY;
# 禁用密碼過期:
CREATE USER 'wangwei'@'localhost' PASSWORD EXPIRE NEVER;
ALTER  USER 'wangwei'@'localhost' PASSWORD EXPIRE NEVER;
# 遵循全局到期政策:
CREATE USER 'wangwei'@'localhost' PASSWORD EXPIRE DEFAULT;
ALTER  USER 'wangwei'@'localhost' PASSWORD EXPIRE DEFAULT;

1.3 MySQL用戶密碼重用策略設(shè)置

MySQL允許限制重復(fù)使用以前的密碼??梢愿鶕?jù)密碼更改次數(shù)、已用時(shí)間或兩者來建立重用限制。帳戶的密碼歷史由過去分配的密碼組成。

MySQL可以限制從此歷史記錄中選擇新密碼:

1、如果根據(jù)密碼更改次數(shù)限制帳戶,則無法從指定數(shù)量的最新密碼中選擇新密碼。例如,如果密碼更改的最小數(shù)量設(shè)置為3,則新密碼不能與任何最近的3個(gè)密碼相同。

2、如果帳戶因時(shí)間的限制而被限制,則無法從歷史記錄中的新密碼中選擇新密碼,該新密碼不會(huì)超過指定的天數(shù)。例如,如果密碼重用間隔設(shè)置為60,則新密碼不得在最近60天內(nèi)選擇的密碼之間。

注意:空密碼不記錄在密碼歷史記錄中,并隨時(shí)可以重復(fù)使用。

要全局建立密碼重用策略,請使用password_history和password_reuse_interval系統(tǒng)變量。要在服務(wù)器啟動(dòng)時(shí)指定變量值,請?jiān)诜?wù)器my.cnf文件中定義它們。

示例:

要禁止重復(fù)使用最近6個(gè)密碼或密碼超過365天的任何密碼,請將這些行放入您的服務(wù)器 my.cnf文件中:

[mysqld]password_history=6 password_reuse_interval=365

要?jiǎng)討B(tài)設(shè)置和保存配置,請使用如下所示的語句:

SET PERSIST password_history = 6;

SET PERSIST password_reuse_interval = 365;

二、MySQL8.0的角色管理

MySQL角色是指定的權(quán)限集合。像用戶帳戶一樣,角色可以擁有授予和撤消的權(quán)限??梢允谟栌脩魩艚巧谟柙搸襞c每個(gè)角色相關(guān)的權(quán)限。用戶被授予角色權(quán)限,則該用戶擁有該角色的權(quán)限。

以下列表總結(jié)了MySQL提供的角色管理功能:

  • CREATE ROLE、 DROP ROLE角色創(chuàng)建和刪除;

  • GRANT、 REVOKE為用戶和角色分配和撤銷權(quán)限;

  • SHOW GRANTS 顯示用戶和角色的權(quán)限和角色分配;

  • SET DEFAULT ROLE 指定哪些帳戶角色默認(rèn)處于活動(dòng)狀態(tài);

  • SET ROLE 更改當(dāng)前會(huì)話中的活動(dòng)角色。

  • CURRENT_ROLE()功能顯示當(dāng)前會(huì)話中的活動(dòng)角色。

2.1 創(chuàng)建角色并授予用戶角色權(quán)限

 考慮如下幾種場景:

  • 應(yīng)用程序使用名為app_db的數(shù)據(jù)庫 。

  • 與應(yīng)用程序相關(guān)聯(lián),可以為創(chuàng)建和維護(hù)應(yīng)用程序的開發(fā)人員以及管理員賬戶。

  • 開發(fā)人員需要完全訪問數(shù)據(jù)庫。有的用戶只需要讀取權(quán)限,有的用戶需要讀取/寫入權(quán)限。

為清楚區(qū)分角色的權(quán)限,將角色創(chuàng)建為所需權(quán)限集的名稱。通過授權(quán)適當(dāng)?shù)慕巧?,可以輕松地為用戶帳戶授予所需的權(quán)限。

要?jiǎng)?chuàng)建角色,請使用CREATE ROLE:

create role 'app_developer', 'app_read', 'app_write';

角色名稱與用戶帳戶名稱非常相似,由格式中的用戶部分和主機(jī)部分組成。

主機(jī)部分,如果省略,則默認(rèn)為%。用戶和主機(jī)部分可以不加引號,除非它們包含特殊字符。

與帳戶名稱不同,角色名稱的用戶部分不能為空。為角色分配權(quán)限,使用與為用戶分配權(quán)限相同的語法執(zhí)行:

GRANT ALL ON app_db.* TO 'app_developer';
GRANT SELECT ON app_db.* TO 'app_read';
GRANT INSERT, UPDATE, DELETE ON app_db.* TO 'app_write';
CREATE ROLE 'app_developer', 'app_read', 'app_write';

現(xiàn)在假設(shè)您最初需要一個(gè)開發(fā)人員帳戶,兩個(gè)需要只讀訪問權(quán)的用戶以及一個(gè)需要讀取/寫入權(quán)限的用戶。

CREATE USER 'dev1'@'localhost'       IDENTIFIED BY 'dev1pass';
CREATE USER 'read_user1'@'localhost' IDENTIFIED BY 'read_user1pass';
CREATE USER 'read_user2'@'localhost' IDENTIFIED BY 'read_user2pass';
CREATE USER 'rw_user1'@'localhost'   IDENTIFIED BY 'rw_user1pass';

要為每個(gè)用戶分配其所需的權(quán)限,可以使用GRANT與剛才顯示的形式相同的語句,但這需要列舉每個(gè)用戶的個(gè)人權(quán)限。

相反,使用GRANT允許授權(quán)角色而非權(quán)限的替代語法:

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

結(jié)合角色所需的讀取和寫入權(quán)限,在GRANT中授權(quán) rw_user1用戶讀取和寫入的角色。

在GRANT授權(quán)角色的語法和授權(quán)用戶的語法不同:有一個(gè)ON來區(qū)分角色和用戶的授權(quán),有ON的為用戶授權(quán),而沒有ON用來分配角色。

由于語法不同,因此不能在同一語句中混合分配用戶權(quán)限和角色。(允許為用戶分配權(quán)限和角色,但必須使用單獨(dú)的GRANT語句,每種語句的語法都要與授權(quán)的內(nèi)容相匹配。)

2.2 檢查角色權(quán)限

要驗(yàn)證分配給用戶的權(quán)限,使用 SHOW GRANTS。例如:

mysql> SHOW GRANTS FOR 'dev1'@'localhost';

但是,它會(huì)顯示每個(gè)授予的角色,而不會(huì)將其顯示為角色所代表的權(quán)限。如果要顯示角色權(quán)限,添加一個(gè) USING來顯示:

mysql> SHOW GRANTS FOR 'dev1'@'localhost' USING 'app_developer';

同樣驗(yàn)證其他類型的用戶:

mysql> SHOW GRANTS FOR 'read_user1'@'localhost' USING 'app_read';

2.3 撤消角色或角色權(quán)限

正如可以授權(quán)某個(gè)用戶的角色一樣,可以從帳戶中撤銷這些角色:

REVOKE role FROM user;

REVOKE可以用于角色修改角色權(quán)限。這不僅影響角色本身權(quán)限,還影響任何授予該角色的用戶權(quán)限。假設(shè)想臨時(shí)讓所有用戶只讀,使用REVOKE從該app_write角色中撤消修改權(quán)限 :

REVOKE INSERT, UPDATE, DELETE ON app_db.* FROM 'app_write';

碰巧,某個(gè)角色完全沒有任何權(quán)限,正如可以看到的那樣SHOW GRANTS (這個(gè)語句可以和角色一起使用,而不僅僅是查詢用戶權(quán)限可用):

mysql> SHOW GRANTS FOR 'app_write';

從角色中撤銷權(quán)限會(huì)影響到該角色中任何用戶的權(quán)限,因此 rw_user1現(xiàn)在已經(jīng)沒有表修改權(quán)限(INSERT, UPDATE,和 DELETE權(quán)限已經(jīng)沒有了):

mysql> SHOW GRANTS FOR 'rw_user1'@'localhost' USING 'app_read', 'app_write';

 實(shí)際上,rw_user1讀/寫用戶已成為只讀用戶。對于被授予app_write角色的任何其他用戶也會(huì)發(fā)生這種情況,說明修改使用角色而不必修改個(gè)人帳戶的權(quán)限。

要恢復(fù)角色的修改權(quán)限,只需重新授予它們即可:

GRANT INSERT, UPDATE, DELETE ON app_db.* TO 'app_write';

現(xiàn)在rw_user1再次具有修改權(quán)限,就像授權(quán)該app_write角色的其他任何帳戶一樣。

2.4 刪除角色

要?jiǎng)h除角色,請使用DROP ROLE:

DROP ROLE 'app_read', 'app_write';

刪除角色會(huì)從授權(quán)它的每個(gè)帳戶中撤消該角色。

2.5 角色和用戶在實(shí)際中的應(yīng)用

假設(shè)遺留應(yīng)用開發(fā)項(xiàng)目在MySQL中的角色出現(xiàn)之前開始,因此與該項(xiàng)目相關(guān)聯(lián)的所有用戶都是直接授予權(quán)限(而不是授予角色權(quán)限)。其中一個(gè)帳戶是最初被授予權(quán)限的開發(fā)者用戶,如下所示:

CREATE USER 'old_app_dev'@'localhost' IDENTIFIED BY 'old_app_devpass';

GRANT ALL ON old_app.* TO 'old_app_dev'@'localhost';

如果此開發(fā)人員離開項(xiàng)目,則有必要將權(quán)限分配給其他用戶,或者項(xiàng)目參與人增多,則可能需要多個(gè)用戶。以下是解決該問題的一些方法:

不使用角色:更改帳戶密碼,以便原始開發(fā)人員不能使用它,并讓新的開發(fā)人員使用該帳戶:

ALTER USER 'old_app_dev'@'localhost' IDENTIFIED BY 'new_password';

使用角色:鎖定帳戶以防止任何人使用它來連接服務(wù)器:

ALTER USER 'old_app_dev'@'localhost' ACCOUNT LOCK;

然后將該帳戶視為角色。對于每個(gè)新開發(fā)項(xiàng)目的開發(fā)者,創(chuàng)建一個(gè)新帳戶并授予其原始開發(fā)者帳戶:

CREATE USER 'new_app_dev1'@'localhost' IDENTIFIED BY 'new_password';GRANT 'old_app_dev'@'localhost' TO 'new_app_dev1'@'localhost';

其效果是將原始開發(fā)者帳戶權(quán)限分配給新帳戶。

MySQL8.0的用戶和角色管理也越來越像Oracle了,8.0中有不少新的特性,變化還是很大的,需要DBA不斷的學(xué)習(xí)和測試,更新對MySQL新版的認(rèn)知,更好地運(yùn)維MySQL數(shù)據(jù)庫。未來MySQL數(shù)據(jù)庫自治和智能數(shù)據(jù)庫是必然發(fā)展趨勢,對DBA來說是解放,也是挑戰(zhàn)。

到此這篇關(guān)于mysql8.0 用戶角色管理及授權(quán)的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)mysql8.0用戶管理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 安裝rpm包時(shí)提示錯(cuò)誤:依賴檢測失敗的解決方法

    安裝rpm包時(shí)提示錯(cuò)誤:依賴檢測失敗的解決方法

    今天在虛擬機(jī)中裝MySQL的時(shí)候,突然出現(xiàn)了這個(gè)依賴檢測錯(cuò)誤,下面這篇文章主要給大家介紹了關(guān)于安裝rpm包時(shí)提示錯(cuò)誤:依賴檢測失敗的解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • 快速學(xué)習(xí)MySQL索引的入門超級教程

    快速學(xué)習(xí)MySQL索引的入門超級教程

    這篇文章主要介紹了快速學(xué)習(xí)MySQL索引的入門教程,包括索引的創(chuàng)建和刪除等基礎(chǔ)知識,需要的朋友可以參考下
    2015-11-11
  • MySQL 中處理 BLOB 和 CLOB 數(shù)據(jù)類型小結(jié)

    MySQL 中處理 BLOB 和 CLOB 數(shù)據(jù)類型小結(jié)

    在MySQL中,BLOB和CLOB 數(shù)據(jù)類型用于存儲大量的二進(jìn)制數(shù)據(jù)和字符數(shù)據(jù),可以使用SQL 語句或編程語言將二進(jìn)制數(shù)據(jù)和字符數(shù)據(jù)插入到BLOB 和CLOB列中,這篇文章主要介紹了MySQL 中處理 BLOB 和 CLOB 數(shù)據(jù)類型,需要的朋友可以參考下
    2025-03-03
  • MySQL 5.7 學(xué)習(xí)心得之安全相關(guān)特性

    MySQL 5.7 學(xué)習(xí)心得之安全相關(guān)特性

    這篇文章主要介紹了MySQL 5.7 學(xué)習(xí)心得之安全相關(guān)特性 的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • MySQL中的隱藏列的具體查看

    MySQL中的隱藏列的具體查看

    mysql中存在一些隱藏列,例如行標(biāo)識、事務(wù)ID、回滾指針等,不知道大家是否和我一樣好奇過,要怎樣才能實(shí)際地看到這些隱藏列的值呢,感興趣的可以了解一下
    2021-09-09
  • ubuntu下設(shè)置mysql自動(dòng)備份的例子

    ubuntu下設(shè)置mysql自動(dòng)備份的例子

    ubuntu下設(shè)置mysql自動(dòng)備份的例子,供大家學(xué)習(xí)參考
    2013-01-01
  • mysql優(yōu)化配置參數(shù)

    mysql優(yōu)化配置參數(shù)

    mysql安裝好需要優(yōu)化配置一下,打開c:\windows\my.ini文件
    2011-03-03
  • MySQL事務(wù)管理的作用詳解

    MySQL事務(wù)管理的作用詳解

    事務(wù)就是一組DML語句組成,這些語句在邏輯上存在相關(guān)性,這一組DML語句要么全部成功,要么全部失敗,是一個(gè)整體。MySQL提供一種機(jī)制,保證我們達(dá)到這樣的效果。事務(wù)還規(guī)定不同的客戶端看到的數(shù)據(jù)是不相同的
    2022-08-08
  • mysql could not be resolved: Name or service not known

    mysql could not be resolved: Name or service not known

    今天查看mysql日志的時(shí)候發(fā)現(xiàn)[Warning] IP address '10.0.0.220' could not be resolved: Name or service not known,原來是mysql DNS反解:skip-name-resolve的原因,屏蔽一下就可以了
    2015-08-08
  • Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法

    Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法

    這篇文章主要介紹了Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法,需要的朋友可以參考下
    2015-10-10

最新評論