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

MYSQL數(shù)據(jù)庫管理之權(quán)限管理解讀

 更新時間:2023年03月20日 09:20:30   作者:李雄  
這篇文章主要介紹了MYSQL數(shù)據(jù)庫管理之權(quán)限管理解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

工作中經(jīng)常遇到mysql權(quán)限不會搞或者在QQ群或者論壇上問關(guān)于mysql權(quán)限的問題,今天抽空總結(jié)一下關(guān)于這斷時間使用MYSQL的時候關(guān)于MYSQL數(shù)據(jù)庫的權(quán)限管理的經(jīng)驗。

一、MYSQL權(quán)限簡介

關(guān)于mysql的權(quán)限簡單的理解就是mysql允許你做你權(quán)利以內(nèi)的事情,不可以越界。比如只允許你執(zhí)行select操作,那么你就不能執(zhí)行update操作。

只允許你從某臺機(jī)器上連接mysql,那么你就不能從除那臺機(jī)器以外的其他機(jī)器連接mysql。

那么MYSQL的權(quán)限是如何實(shí)現(xiàn)的呢?這就要說到mysql的兩階段的驗證,下面詳細(xì)來介紹:

第一階段:服務(wù)器首先會檢查你是否允許連接。因為創(chuàng)建用戶的時候會加上主機(jī)限制,可以限制成本地、某個IP、某個IP段、以及任何地方等,只允許你從配置的指定地方登錄。后面在實(shí)戰(zhàn)的時候會詳細(xì)說關(guān)于主機(jī)的限制。

第二階段:如果你能連接,MYSQL會檢查你發(fā)出的每個請求,看你是否有足夠的權(quán)限實(shí)施它。比如你要更新某個表、或者查詢某個表,MYSQL會檢查你對哪個表或者某個列是否有權(quán)限。再比如,你要運(yùn)行某個存儲過程,MYSQL會檢查你對存儲過程是否有執(zhí)行權(quán)限等。

1.MYSQL到底都有哪些權(quán)限呢?

從官網(wǎng)復(fù)制一個表來看看:

權(quán)限

權(quán)限級別

權(quán)限說明

CREATE

數(shù)據(jù)庫、表或索引

創(chuàng)建數(shù)據(jù)庫、表或索引權(quán)限

DROP

數(shù)據(jù)庫或表

刪除數(shù)據(jù)庫或表權(quán)限

GRANT OPTION

數(shù)據(jù)庫、表或保存的程序

賦予權(quán)限選項

REFERENCES

數(shù)據(jù)庫或表

ALTER

更改表,比如添加字段、索引等

DELETE

刪除數(shù)據(jù)權(quán)限

INDEX

索引權(quán)限

INSERT

插入權(quán)限

SELECT

查詢權(quán)限

UPDATE

更新權(quán)限

CREATE VIEW

視圖

創(chuàng)建視圖權(quán)限

SHOW VIEW

視圖

查看視圖權(quán)限

ALTER ROUTINE

存儲過程

更改存儲過程權(quán)限

CREATE ROUTINE

存儲過程

創(chuàng)建存儲過程權(quán)限

EXECUTE

存儲過程

執(zhí)行存儲過程權(quán)限

FILE

服務(wù)器主機(jī)上的文件訪問

文件訪問權(quán)限

CREATE TEMPORARY TABLES

服務(wù)器管理

創(chuàng)建臨時表權(quán)限

LOCK TABLES

服務(wù)器管理

鎖表權(quán)限

CREATE USER

服務(wù)器管理

創(chuàng)建用戶權(quán)限

PROCESS

服務(wù)器管理

查看進(jìn)程權(quán)限

RELOAD

服務(wù)器管理

執(zhí)行flush-hosts, flush-logs, flush-privileges, flush-status, flush-tables, flush-threads, refresh, reload等命令的權(quán)限

REPLICATION CLIENT

服務(wù)器管理

復(fù)制權(quán)限

REPLICATION SLAVE

服務(wù)器管理

復(fù)制權(quán)限

SHOW DATABASES

服務(wù)器管理

查看數(shù)據(jù)庫權(quán)限

SHUTDOWN

服務(wù)器管理

關(guān)閉數(shù)據(jù)庫權(quán)限

SUPER

服務(wù)器管理

執(zhí)行kill線程權(quán)限

2.MYSQL的權(quán)限如何分布

就是針對表可以設(shè)置什么權(quán)限,針對列可以設(shè)置什么權(quán)限等等,這個可以從官方文檔中的一個表來說明:

權(quán)限分布

可能的設(shè)置的權(quán)限

表權(quán)限

'Select', 'Insert', 'Update', 'Delete', 'Create', 'Drop', 'Grant', 'References', 'Index', 'Alter'

列權(quán)限

'Select', 'Insert', 'Update', 'References'

過程權(quán)限

'Execute', 'Alter Routine', 'Grant'

針對權(quán)限這部分,最主要的是要知道MYSQL是如何驗證的(兩階段驗證),以及mysql各個權(quán)限是做什么用的,以及那些權(quán)限用在什么地方(表or列?)。

如果這些把握了那么MYSQL權(quán)限對你來說就是小菜一碟了,只要看一下后面的權(quán)限管理就可以融會貫通了。        

二、MYSQL權(quán)限經(jīng)驗原則

權(quán)限控制主要是出于安全因素,因此需要遵循一下幾個經(jīng)驗原則:

1.  只授予能滿足需要的最小權(quán)限,防止用戶干壞事。哈哈。比如用戶只是需要查詢,那就只給select權(quán)限就可以了,不要給用戶賦予update、insert或者delete權(quán)限。

2.  創(chuàng)建用戶的時候限制用戶的登錄主機(jī),一般是限制成指定IP或者內(nèi)網(wǎng)IP段。

3.  初始化數(shù)據(jù)庫的時候刪除沒有密碼的用戶。安裝完數(shù)據(jù)庫的時候會自動創(chuàng)建一些用戶,這些用戶默認(rèn)沒有密碼。

4.  為每個用戶設(shè)置滿足密碼復(fù)雜度的密碼。

5.  定期清理不需要的用戶?;厥諜?quán)限或者刪除用戶。

三、MYSQL權(quán)限實(shí)戰(zhàn)

1.GRANT命令使用說明

先來看一個例子,創(chuàng)建一個只允許從本地登錄的超級用戶feihong,并允許將權(quán)限賦予別的用戶,密碼為test@feihong.111

GRANT ALL PRIVILEGES ON *.* TO feihong@'localhost' IDENTIFIED BY 'test@feihong.111' WITH GRANT OPTION;

GRANT命令說明:

  • ALL PRIVILEGES 是表示所有權(quán)限,你也可以使用select、update等權(quán)限提到的權(quán)限。
  • ON 用來指定權(quán)限針對哪些庫和表。
  • *.* 中前面的*號用來指定數(shù)據(jù)庫名,后面的*號用來指定表名。
  • TO 表示將權(quán)限賦予某個用戶。
  • feihong@'localhost' 表示feihong用戶,@后面接限制的主機(jī),可以是IP、IP段、域名以及%,%表示任何地方。注意:這里%有的版本不包括本地,以前碰到過給某個用戶設(shè)置了%允許任何地方登錄,但是在本地登錄不了,這個和版本有關(guān)系,遇到這個問題再加一個localhost的用戶就可以了。
  • IDENTIFIED BY 指定用戶的登錄密碼。
  • WITH GRANT OPTION 這個選項表示該用戶可以將自己擁有的權(quán)限授權(quán)給別人。注意:經(jīng)常有人在創(chuàng)建操作用戶的時候不指定WITH GRANT OPTION選項導(dǎo)致后來該用戶不能使用GRANT命令創(chuàng)建用戶或者給其他用戶授權(quán)。

備注:可以使用GRANT重復(fù)給用戶添加權(quán)限,權(quán)限疊加,比如你先給用戶添加了一個select權(quán)限,然后又給用戶添加了一個insert權(quán)限,那么該用戶就同時擁有了select和insert權(quán)限。

2.創(chuàng)建一個超級用戶

創(chuàng)建一個只允許從本地登錄的超級用戶feihong,并允許將權(quán)限賦予別的用戶,密碼為test@feihong.111

GRANT ALL PRIVILEGES ON *.* TO feihong@'localhost' IDENTIFIED BY 'test@feihong.111' WITH GRANT OPTION;

3.創(chuàng)建一個網(wǎng)站用戶(程序用戶)

創(chuàng)建一個一般的程序用戶,這個用戶可能只需要SELECT, INSERT, UPDATE, DELETE, CREATE TEMPORARY TABLES等權(quán)限如果有存儲過程還需要加上EXECUTE權(quán)限,一般是指定內(nèi)網(wǎng)網(wǎng)段192.168.100網(wǎng)段。

GRANT??USAGE,SELECT, INSERT, UPDATE, DELETE, SHOW VIEW ,CREATE TEMPORARY TABLES,EXECUTE ON `test`.* TO webuser@'192.168.100.%' IDENTIFIED BY??'test@feihong.111';

4.創(chuàng)建一個普通用戶(僅有查詢權(quán)限)

GRANT USAGE,SELECT ON `test`.* TO public@'192.168.100.%' IDENTIFIED BY??'public@feihong.111';

5.刷新權(quán)限

使用這個命令使權(quán)限生效,尤其是你對那些權(quán)限表user、db、host等做了update或者delete更新的時候。

以前遇到過使用grant后權(quán)限沒有更新的情況,大家可以養(yǎng)成習(xí)慣,只要對權(quán)限做了更改就使用FLUSH PRIVILEGES命令來刷新權(quán)限。

FLUSH PRIVILEGES;

6.查看權(quán)限

使用如下命令可以方便的查看到某個用戶的權(quán)限:

SHOW GRANTS FOR 'webuser'@'192.168.100.%';

7.回收權(quán)限

將前面創(chuàng)建的webuser用戶的DELETE權(quán)限回收,使用如下命令

REVOKE DELETE ON test.* FROM 'webuser'@'192.168.100.%';

8.刪除用戶

注意刪除用戶不要使用DELETE直接刪除,因為使用DELETE刪除后用戶的權(quán)限并未刪除,新建同名用戶后又會繼承以前的權(quán)限。

正確的做法是使用DROP USER命令刪除用戶,比如要刪除'webuser'@'192.168.100.%'用戶采用如下命令:

DROP USER 'webuser'@'192.168.100.%';

大家可以采用percona-toolkit工具中的pt-show-grants工具來輔助管理mysql權(quán)限

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql千萬級數(shù)據(jù)量根據(jù)索引優(yōu)化查詢速度的實(shí)現(xiàn)

    mysql千萬級數(shù)據(jù)量根據(jù)索引優(yōu)化查詢速度的實(shí)現(xiàn)

    這篇文章主要介紹了mysql千萬級數(shù)據(jù)量根據(jù)索引優(yōu)化查詢速度的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MySQL約束類型及舉例介紹

    MySQL約束類型及舉例介紹

    今天小編就為大家分享一篇關(guān)于MySQL約束類型及介紹的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • 分享mysql的current_timestamp小坑及解決

    分享mysql的current_timestamp小坑及解決

    這篇文章主要介紹了mysql的current_timestamp小坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 基于Linux的mysql主從配置全過程記錄

    基于Linux的mysql主從配置全過程記錄

    這篇文章主要給大家介紹了基于Linux的mysql主從配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • MySQL 權(quán)限控制細(xì)節(jié)分析

    MySQL 權(quán)限控制細(xì)節(jié)分析

    這篇文章主要介紹了MySQL 權(quán)限控制細(xì)節(jié)分析的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • MySQL數(shù)據(jù)庫主從復(fù)制與讀寫分離

    MySQL數(shù)據(jù)庫主從復(fù)制與讀寫分離

    大家好,本篇文章主要講的是MySQL數(shù)據(jù)庫主從復(fù)制與讀寫分離,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 分析Mysql事務(wù)和數(shù)據(jù)的一致性處理問題

    分析Mysql事務(wù)和數(shù)據(jù)的一致性處理問題

    本篇文章主要給大家介紹了Mysql事務(wù)和數(shù)據(jù)的一致性處理問題,跟著小編一起學(xué)習(xí)下吧。
    2017-12-12
  • MySQL深分頁問題的原因及解決方案

    MySQL深分頁問題的原因及解決方案

    MySQL?作為最受歡迎的開源關(guān)系數(shù)據(jù)庫之一,被廣泛用于各種規(guī)模的應(yīng)用程序中,分頁是一種常見的數(shù)據(jù)檢索技術(shù),它允許用戶在大量數(shù)據(jù)中瀏覽和檢索信息,當(dāng)涉及到“深分頁”時,即查詢大量數(shù)據(jù)后的頁面時,MySQL?的性能可能會顯著下降,本文介紹了MySQL深分頁問題的原因及解決方案
    2024-09-09
  • Windows 8下MySQL Community Server 5.6安裝配置方法圖文教程

    Windows 8下MySQL Community Server 5.6安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了Windows 8下MySQL Community Server 5.6安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • 查找MySQL中查詢慢的SQL語句方法

    查找MySQL中查詢慢的SQL語句方法

    這篇文章主要介紹了查找MySQL中查詢慢的SQL語句方法,需要的朋友可以參考下
    2017-05-05

最新評論