日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

MySQL 8.0用戶和角色管理原理與用法詳解

瀏覽:32日期:2023-10-15 12:57:45

本文實例講述了MySQL 8.0用戶和角色管理。分享給大家供大家參考,具體如下:

MySQL8.0新加了很多功能,其中在用戶管理中增加了角色的管理,

默認(rèn)的密碼加密方式也做了調(diào)整,由之前的sha1改為了sha2,同時加上5.7的禁用用戶和用戶過期的設(shè)置,

這樣方面用戶的管理和權(quán)限的管理,也增加了用戶的安全性。

MySQL8.0中,MySQL庫中表的文件合并到數(shù)據(jù)根目錄中的mysql.ibd中(MySQL8.0 Innodb引擎重構(gòu))。

同時MySQL8.0可以使用SET PERSIST動態(tài)修改參數(shù)并保存在配置文件中(mysqld-auto.cnf,保存的格式為JSON串),

這個是DBA同學(xué)的福音,不必?fù)?dān)心設(shè)置之后忘記保存在配置文件中,重啟之后會被還原的問題了。

查閱了MySQL8.0的官方文檔,通過官方的示例來查看新的管理方式。

MySQL 8.0用戶和角色管理原理與用法詳解

1、MySQL用戶管理

1.1、驗證插件和密碼加密方式的變化在MySQL 8.0中,caching_sha2_password是默認(rèn)的身份驗證插件而不是之前版本的mysql_native_password,

默認(rèn)的密碼加密方式是sha2。

如果需要保持之前的驗證方式并保持之前版本的密碼加密方式需要在配置文件中修改,暫不支持動態(tài)修改,需要重啟生效:default_authentication_plugin = mysql_native_password。

將8.0已有的sha2密碼修改為sha1的模式:

ALTER USER ’root’@’127.0.0.1’ IDENTIFIED BY ’passowrd’ PASSWORD EXPIRE NEVER;

#修改加密規(guī)則為永不過期

ALTER USER ’root’@’127.0.0.1’ IDENTIFIED WITH mysql_native_password BY ’password’;

#更新一下用戶的密碼加密方式為之前版本的方式

FLUSH PRIVILEGES; #刷新權(quán)限

1.2 用戶授權(quán)和修改密碼

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

MySQL8.0之前版本:

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

MySQL8.0版本:

# 創(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 ’你的密碼’;

MySQL8.0中帶過期時間用戶的創(chuàng)建:

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;

MySQL8.0修改用戶密碼:

1.2、密碼過期時間管理

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

如果值default_password_lifetime正整數(shù)N,則表示允許的密碼生存期,以便密碼必須每天更改N。可以加在配置文件中:

1:要建立全局策略,密碼的使用期限大約為六個月,請在服務(wù)器my.cnf文件中使用以下行啟動服務(wù)器:

[mysqld]default_password_lifetime=180

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

[mysqld]default_password_lifetime=0

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

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

創(chuàng)建和修改帶有密碼過期的用戶,帳戶特定的到期時間設(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ù)、已用時間或兩者來建立重用限制。帳戶的密碼歷史由過去分配的密碼組成。

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

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

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

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

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

示例:

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

[mysqld]password_history=6password_reuse_interval=365

要動態(tài)設(shè)置和保存配置,請使用如下所示的語句:

SET PERSIST password_history = 6;

SET PERSIST password_reuse_interval = 365;2、MySQL8.0的角色管理

MySQL角色是指定的權(quán)限集合。像用戶帳戶一樣,角色可以擁有授予和撤消的權(quán)限。

可以授予用戶帳戶角色,授予該帳戶與每個角色相關(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)處于活動狀態(tài); SET ROLE 更改當(dāng)前會話中的活動角色。 CURRENT_ROLE()功能顯示當(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ù)慕巧梢暂p松地為用戶帳戶授予所需的權(quán)限。

要創(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è)您最初需要一個開發(fā)人員帳戶,兩個需要只讀訪問權(quán)的用戶以及一個需要讀取/寫入權(quán)限的用戶。

使用CREATEUSER創(chuàng)建用戶:

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

要為每個用戶分配其所需的權(quán)限,可以使用GRANT與剛才顯示的形式相同的語句,但這需要列舉每個用戶的個人權(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)用戶的語法不同:有一個ON來區(qū)分角色和用戶的授權(quán),有ON的為用戶授權(quán),而沒有ON用來分配角色。

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

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

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

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

MySQL 8.0用戶和角色管理原理與用法詳解

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

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

同樣驗證其他類型的用戶:

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

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

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

REVOKE role FROM user;

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

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

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

mysql> SHOW GRANTS FOR ’app_write’;

從角色中撤銷權(quán)限會影響到該角色中任何用戶的權(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’;

實際上,rw_user1讀/寫用戶已成為只讀用戶。對于被授予app_write角色的任何其他用戶也會發(fā)生這種情況,說明修改使用角色而不必修改個人帳戶的權(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 刪除角色

要刪除角色,請使用DROP ROLE:

DROP ROLE ’app_read’, ’app_write’;

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

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

假設(shè)遺留應(yīng)用開發(fā)項目在MySQL中的角色出現(xiàn)之前開始,因此與該項目相關(guān)聯(lián)的所有用戶都是直接授予權(quán)限(而不是授予角色權(quán)限)。其中一個帳戶是最初被授予權(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ā)人員離開項目,則有必要將權(quán)限分配給其他用戶,或者項目參與人增多,則可能需要多個用戶。以下是解決該問題的一些方法:

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

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

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

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

然后將該帳戶視為角色。對于每個新開發(fā)項目的開發(fā)者,創(chuàng)建一個新帳戶并授予其原始開發(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)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
999国产精品视频| 国产精品毛片一区二区在线看| 日韩不卡在线观看日韩不卡视频 | 精品一区欧美| av资源中文在线天堂| 日韩av片子| 欧美gv在线| 欧美粗暴jizz性欧美20| 伊人影院久久| 综合色就爱涩涩涩综合婷婷| 亚洲三级精品| 欧美日韩18| 久久69成人| 日韩国产一区二区三区| 国产在线欧美| 只有精品亚洲| 国产日韩欧美中文在线| 国产一区二区三区不卡av| 久久亚洲黄色| 成人三级高清视频在线看| 精品三级久久| 99成人在线| 日韩三区四区| 精品一区二区三区中文字幕在线| 免费在线观看成人| 亚洲精品一级二级三级| 国产区精品区| 亚洲综合电影| 亚洲一区二区三区四区五区午夜 | 久久97视频| 日韩黄色大片| 亚洲欧美日韩视频二区| 亚洲精品国模| 麻豆成人综合网| 久久久久国产一区二区| 免费欧美日韩| 久久精品99国产精品| 国产成人久久精品一区二区三区| 亚洲a级精品| 欧美三区不卡| 日韩在线不卡| 亚洲免费成人av在线| 久久精品资源| 日韩午夜免费| 老司机精品在线| 欧美日韩黑人| 国产精品一国产精品k频道56| 性一交一乱一区二区洋洋av| 亚久久调教视频| 91视频一区| 视频一区在线视频| 久久精品二区亚洲w码 | 日韩欧美另类中文字幕| 国产欧美日韩在线观看视频 | 日韩精品91亚洲二区在线观看| 久久一级电影| 亚洲视频二区| 三上亚洲一区二区| 亚洲欧洲美洲国产香蕉| 91亚洲人成网污www| 亚洲综合图色| 天堂av在线| 亚洲精品黄色| 特黄毛片在线观看| 亚洲69av| 久久精品亚洲人成影院 | 精品久久在线| 午夜欧美精品| 精品久久久中文字幕| 日韩专区欧美专区| 欧美激情另类| 国产亚洲精品美女久久| 亚洲成人不卡| 国产欧美日韩一区二区三区在线| 久久国产乱子精品免费女| 福利在线一区| 日韩视频1区| 午夜精品成人av| 久久国产尿小便嘘嘘| 亚洲免费影视| 久久久精品久久久久久96 | 蜜芽一区二区三区| 国产一区二区三区四区五区 | 国产精品久久久久久久久久齐齐| 日韩国产欧美在线播放| 国产麻豆久久| 国产精品视频一区二区三区综合| 国产精久久久| 久久av一区| 久久精品免费一区二区三区| 久久99精品久久久久久园产越南 | 91精品电影| 加勒比视频一区| 国产伦理一区| 丝瓜av网站精品一区二区| 综合日韩av| 国产亚洲一区二区三区啪| 伊人影院久久| 久久精品动漫| 四虎8848精品成人免费网站| 日韩激情一二三区| 久久福利影视| 午夜欧美精品| 性欧美xxxx免费岛国不卡电影| 视频一区二区国产| 激情综合在线| 99久久夜色精品国产亚洲1000部| 国产偷自视频区视频一区二区| 久久国产成人| 欧美~级网站不卡| 成人日韩在线观看| 麻豆网站免费在线观看| 国产日本久久| 亚洲精品观看| 丝袜美腿亚洲色图| 欧美大黑bbbbbbbbb在线| 成人一二三区| 免费日韩成人| 欧美精品99| 国产乱人伦丫前精品视频| 奇米色欧美一区二区三区| 亚洲精品影视| 日韩精品导航| 日本a级不卡| 婷婷视频一区二区三区| 一区二区国产在线观看| 美美哒免费高清在线观看视频一区二区| 日韩高清欧美激情| 视频一区二区三区在线| 美女国产一区| 首页亚洲欧美制服丝腿| 久久高清国产| 亚洲精品护士| 久久狠狠亚洲综合| 国产福利一区二区三区在线播放| 日本一区二区高清不卡| 美女高潮久久久| 国产一区二区三区91| 国产一区二区三区91| 黄色在线网站噜噜噜| 丝袜诱惑一区二区| 婷婷综合在线| 久久国产精品久久w女人spa| 免费国产亚洲视频| 日韩精品福利一区二区三区| 国产精品日韩精品中文字幕| 久久国产三级| 欧美韩一区二区| 伊人网在线播放| 亚洲手机在线| 首页国产欧美日韩丝袜| 日韩激情网站| 亚洲精品影视| 国产精品中文字幕制服诱惑| 牛牛精品成人免费视频| 国产aⅴ精品一区二区四区| 国产传媒av在线| 欧美日韩国产综合网| 一区二区三区网站| 欧美久久亚洲| 日韩精品不卡一区二区| 亚洲二区三区不卡| 日韩有吗在线观看| 精品一区av| 激情偷拍久久| 日本不卡一区二区三区| 国产一区二区三区亚洲综合| 激情欧美亚洲| 国产视频网站一区二区三区| 粉嫩av一区二区三区四区五区 | 亚洲爱爱视频| 欧美日韩国产在线观看网站| 日韩影院在线观看| 国产精品亚洲综合久久| 成人污污视频| 国产亚洲精品自拍| 国产美女精品视频免费播放软件| 亚洲精品乱码| 国产欧美日韩一区二区三区四区 | 日韩欧美中文字幕电影| 久久99影视| 久久中文字幕av一区二区不卡| 国产精品极品在线观看| 久久一级电影| 日韩av中文字幕一区二区| 成人小电影网站| 在线精品一区| 国产精品久久久久蜜臀| 亚洲欧美日本日韩| 日本aⅴ免费视频一区二区三区| 99re国产精品| 欧美日本久久| 亚洲国产成人二区| 亚洲免费在线| 韩国女主播一区二区三区| 蜜桃久久av| 久久精品国产免费| 男人操女人的视频在线观看欧美| 伊人久久亚洲美女图片| 欧美亚洲免费|