詳解MySQL中的存取權(quán)限
看到很多網(wǎng)友提出關(guān)于MySQL登錄不上服務(wù)器的問(wèn)題,包括有的是在PHP中調(diào)用MySQL時(shí)發(fā)生的不能登錄MySQL數(shù)據(jù)庫(kù)服務(wù)器的問(wèn)題,以為是PHP出了問(wèn)題。其實(shí)是MySQL權(quán)限的問(wèn)題。
MySQL的權(quán)限系統(tǒng)在MySQL的手冊(cè)中是很長(zhǎng)的一章,我把它打印出來(lái)足足印了20多頁(yè)!這里就將我對(duì)它的理解簡(jiǎn)要地寫(xiě)出來(lái),希望能對(duì)剛剛接觸MySQL的同志有點(diǎn)幫助;有說(shuō)得不對(duì)的地方,也請(qǐng)同志們指出。
在我了解了MySQL的權(quán)限機(jī)制后,不由得不贊嘆它的嚴(yán)密與巧妙;也許所有的數(shù)據(jù)庫(kù)系統(tǒng)都是如此罷,只是別的大型數(shù)據(jù)庫(kù)把權(quán)限做得不需超級(jí)管理員親自干預(yù)數(shù)據(jù)表而已。
MySQL的權(quán)限保存在名為mysql的數(shù)據(jù)庫(kù)中,有user、db、host、tables_priv、columns_priv 等五個(gè)表。
首先,限制用戶(hù)的登錄的,只有 user 表,其中最常用的是 user、host、password這三個(gè)字段。其他的select_priv、update_priv、…… 這些字段分別表示該用戶(hù)是否有select、update、……等權(quán)限,這些字段設(shè)置為'Y'表示該用戶(hù)擁有對(duì)應(yīng)的權(quán)限,'N'表示用戶(hù)沒(méi)有對(duì)應(yīng)的權(quán)限。注意,這里指定的權(quán)限是全局的,一旦你在user表中給了一個(gè)用戶(hù)select或update權(quán)限,他就對(duì)這臺(tái)服務(wù)器上任何數(shù)據(jù)庫(kù)、任何表?yè)碛猩鲜鰴?quán)限!其中當(dāng)然包括mysql數(shù)據(jù)庫(kù)??!這意味著他可以通過(guò)更改user表里的數(shù)據(jù)非法地獲取更大的權(quán)限!?。∵@是非??膳碌?,所以建議除了給root用戶(hù)外,不要在user表中分配權(quán)限。特別的,你可以建立一個(gè)幾乎跟root擁有同樣權(quán)限的用戶(hù)(密碼可不要告訴別人喲?。┰谕浟藃oot密碼時(shí)就用得到了。在添加一個(gè)用戶(hù)時(shí),如果不指定權(quán)限字段的值,它們的默認(rèn)值都是'N',——也就是這個(gè)用戶(hù)什么權(quán)限也沒(méi)有——你可以放心的在user表中添加用戶(hù),因?yàn)榧词顾艿卿涍M(jìn)來(lái),卻什么也干不了。
還有一個(gè)應(yīng)該注意的問(wèn)題就是user表中的password字段。試想,既然root用戶(hù)可以瀏覽mysql數(shù)據(jù)庫(kù),可以看到user表的password字段,是不是就是看到了其他用戶(hù)的密碼呢?不是的!user表的password字段保存的是用password()函數(shù)加密了的用戶(hù)密碼,當(dāng)用戶(hù)登錄時(shí),服務(wù)器將收到的用戶(hù)輸入的密碼用password()函數(shù)加密,加密得到的字串與user表password字段如能匹配,則認(rèn)為密碼正確。password()沒(méi)有逆運(yùn)算,所以任何人無(wú)法從一個(gè)加密的字串得到密碼的明文。同時(shí),如果你手工修改user表,別忘了在更新password字段時(shí)一定要用password()函數(shù)加密。例如,你要允許一位名為 bill 的用戶(hù)登錄你的服務(wù)器,你給他設(shè)定一個(gè) 12345 的密碼,則應(yīng)該:
insert into user (user,host,password) values ('bill','%',password('12345'));
如果你直接
insert into user (user,host,password) values ('bill','%','12345');
的話(huà),恐怕他登不上你的服務(wù)器,也會(huì)到奧索網(wǎng)上發(fā)帖子問(wèn)的。
注意,每當(dāng)手工操作了跟權(quán)限有關(guān)的數(shù)據(jù)表以后,要執(zhí)行一條 flush privileges 命令才能使其生效。
下面的問(wèn)題就是如何給用戶(hù)分配權(quán)限了。如果你要給一個(gè)用戶(hù)開(kāi)一個(gè)數(shù)據(jù)庫(kù),并把有關(guān)這個(gè)數(shù)據(jù)庫(kù)的所有或部分權(quán)限開(kāi)放給他,這就用到了db表。db表的意義在于,當(dāng)一個(gè)用戶(hù)請(qǐng)求一個(gè)查詢(xún)時(shí),檢測(cè)該用戶(hù)對(duì)于他的查詢(xún)所針對(duì)的數(shù)據(jù)庫(kù)是否擁有進(jìn)行該查詢(xún)操作的權(quán)限,有,則允許查詢(xún);沒(méi)有,則進(jìn)一步咨詢(xún)tables_priv表。db表的最常用字段是 user、db、和那一大堆有關(guān)權(quán)限的字段。user,不用說(shuō)了,就是那個(gè)用戶(hù)的用戶(hù)名,跟user表中的對(duì)應(yīng);db,就是要分給他的數(shù)據(jù)庫(kù)名。然后就把要給他的權(quán)限相對(duì)應(yīng)的權(quán)限字段設(shè)為'Y'。同樣,這些字段的值在不指定的時(shí)候默認(rèn)是'N'。你也可以用GRANT/REVOKE命令給用戶(hù)分配權(quán)限,可以是這樣的:
grant select,update,insert,delete,creater,alter,drop,index on bill.* to bill;
這樣就把針對(duì)bill這個(gè)數(shù)據(jù)庫(kù)的幾乎所有的權(quán)限給了用戶(hù)bill。這里沒(méi)有給的只是grant權(quán)限,關(guān)于這個(gè)權(quán)限,建議不要輕易給人,因?yàn)橛脩?hù)有了grant權(quán)限,也就可以將權(quán)限分配給其他用戶(hù)。值得慶幸的是,擁有g(shù)rant權(quán)限的用戶(hù)能而且只能將他自己已經(jīng)擁有的權(quán)限分配給別人。
使用GRANT/REVOKE命令更改了權(quán)限后,不須執(zhí)行 flush privileges 命令就可以使更改生效。
上面討論的是給一個(gè)用戶(hù)完全開(kāi)放一個(gè)數(shù)據(jù)庫(kù)的問(wèn)題,如果只想給一個(gè)用戶(hù)一個(gè)特定的表的權(quán)限,就是 tables_priv 表發(fā)揮作用的時(shí)候啦。這里的關(guān)鍵性字段是user、db、table_name 。顯而易見(jiàn)的,要給一個(gè)用戶(hù)指定一個(gè)特定的數(shù)據(jù)庫(kù)中特定表的權(quán)限,三個(gè)關(guān)鍵要素就是:哪個(gè)用戶(hù)(user)、哪個(gè)數(shù)據(jù)庫(kù)(db)、哪個(gè)表(table_name)。它的機(jī)理跟db表是類(lèi)似的,我不必再重復(fù)。唯一不同的是這里用了一個(gè)SET類(lèi)型的字段 table_priv 來(lái)指定用戶(hù)對(duì)這個(gè)表權(quán)限,SET的成員有 SELECT, UPDATE, INSERT, DELETE, ALTER, CREATE, DROP, GRANT, INDEX, REFERENCE 等,你可以選擇其中任意一個(gè)或幾個(gè)分配給用戶(hù)。
在上述提及的幾個(gè)權(quán)限表中以及未提及的host表中,都有一個(gè)host字段,它用來(lái)區(qū)分來(lái)自不同主機(jī)的、用戶(hù)名可能相同的人,或者是給同一個(gè)用戶(hù)從不同的主機(jī)連接時(shí)給予不同的權(quán)限。這種用法不很常用,但為了安全起見(jiàn),建議root用戶(hù),如果不需要從遠(yuǎn)程連接,請(qǐng)將他的host設(shè)為 localhost,其他的則可以設(shè)為 % ,即任何主機(jī)。
相關(guān)文章
深入解析mysql中order by與group by的順序問(wèn)題
本篇文章是對(duì)mysql中order by與group by的順序問(wèn)題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06MySQL order by性能優(yōu)化方法實(shí)例
這篇文章主要介紹了MySQL order by性能優(yōu)化方法實(shí)例,本文講解了MySQL中order by的原理和優(yōu)化order by的三種方法,需要的朋友可以參考下2015-05-05MySQL 如何設(shè)計(jì)統(tǒng)計(jì)數(shù)據(jù)表
有些時(shí)候,改進(jìn)數(shù)據(jù)表查詢(xún)性能的最佳方式是在同一張數(shù)據(jù)表中冗余一些繼承的數(shù)據(jù)。然而,有些時(shí)候需要新建完全獨(dú)立的統(tǒng)計(jì)或緩存數(shù)據(jù)表,尤其是在需要反復(fù)查詢(xún)的需求情況下。如果業(yè)務(wù)允許一些時(shí)間上的誤差的話(huà),那么這種方式會(huì)更好。2021-06-06MySQL報(bào)錯(cuò)Lost connection to MySQL server&n
在確保網(wǎng)絡(luò)沒(méi)有問(wèn)題的情況下,服務(wù)器正常運(yùn)行一段時(shí)間后,數(shù)據(jù)庫(kù)拋出了異常"Lost connection to MySQL server during query",本文將給大家介紹MySQL報(bào)錯(cuò)Lost connection to MySQL server during query的解決方案,需要的朋友可以參考下2024-01-01Mysql添加用戶(hù)和設(shè)置權(quán)限的操作方法
這篇文章主要介紹了Mysql添加用戶(hù)和設(shè)置權(quán)限的操作方法,主要包括管理用戶(hù),權(quán)限控制的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07Windows下使用Cygwin編譯MySQL客戶(hù)端
這篇文章主要介紹了Windows下使用Cygwin編譯MySQL客戶(hù)端,本文詳細(xì)的講解了編譯過(guò)程,需要的朋友可以參考下2015-04-04使用canal監(jiān)控mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)elasticsearch索引實(shí)時(shí)更新問(wèn)題
這篇文章主要介紹了使用canal監(jiān)控mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)elasticsearch索引實(shí)時(shí)更新,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03