當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]用Ubuntu的apt包管理工具安裝的mysql數(shù)據(jù)庫,默認(rèn)將數(shù)據(jù)庫文件保存在/var/lib/mysql目錄下,時(shí)間久了數(shù)據(jù)庫越來越大,所以準(zhǔn)備掛載個(gè)新的硬盤專門存放mysql數(shù)據(jù)庫。1、確定mys

用Ubuntu的apt包管理工具安裝的mysql數(shù)據(jù)庫,默認(rèn)將數(shù)據(jù)庫文件保存在/var/lib/mysql目錄下,時(shí)間久了數(shù)據(jù)庫越來越大,所以準(zhǔn)備掛載個(gè)新的硬盤專門存放mysql數(shù)據(jù)庫。


1、確定mysql數(shù)據(jù)庫文件存放目錄


一般默認(rèn)是在/var/lib/mysql目錄下。先登錄自己的mysql數(shù)據(jù)庫,比如我用root賬戶登錄,然后使用下面查詢語句查詢:


[plain]?view plaincopyshow?variables?like?'%dir%';??


得到數(shù)據(jù)庫文件配置信息:

可以看到其中datadir的值為/var/lib/mysql/即為當(dāng)前數(shù)據(jù)庫文件存放目錄。

另外一個(gè)basedir參數(shù)表示mysql數(shù)據(jù)庫的安裝位置,遷移數(shù)據(jù)庫文件位置不需要改動(dòng)這個(gè)參數(shù)。


2、遷移數(shù)據(jù)庫文件到新的目錄下


先使用下面命令將mysql數(shù)據(jù)庫服務(wù)停止:


[plain]?view plaincopysudo?/etc/init.d/mysql?stop??


我新的數(shù)據(jù)盤掛載在/mnt/data目錄下,因此要將數(shù)據(jù)庫遷移到/mnt/data。

2.1 可以使用mv命令將原數(shù)據(jù)庫目錄文件移動(dòng)到新的目錄,好處是不會(huì)簡單,不會(huì)修改原數(shù)據(jù)庫文件的權(quán)限,以及用戶和用戶組歸屬:


[plain]?view plaincopysudo?mv?/var/lib/mysql?/mnt/data/??


2.2 也可以使用cp復(fù)制命令將原數(shù)據(jù)庫目錄文件復(fù)制到新的目錄,好處是。。萬一遷移失敗,恢復(fù)工作相對簡單一點(diǎn),等確認(rèn)遷移成功再來刪掉原數(shù)據(jù)庫目錄文件也不遲。為了不影響復(fù)制過來數(shù)據(jù)庫目錄文件權(quán)限和用戶用戶組歸屬問題,使用cp命令時(shí)要加上-a參數(shù):


[plain]?view plaincopysudo?cp?-a?/var/lib/mysql?/mnt/data/?? 注:由于/var/lib/mysql目錄歸屬于mysql數(shù)據(jù)庫創(chuàng)建的mysql用戶和mysql用戶組,所以遷移文件的時(shí)候需要使用root權(quán)限,命令要使用sudo



遷移成功后,可以看到/mnt/data/目錄下已經(jīng)將mysql數(shù)據(jù)庫文件遷移過來了,并且目錄文件的用戶用戶組歸屬還是mysql,沒有變化:



3、修改配置文件


一共有三個(gè)配置文件需要修改:


3.1 my.cnf文件


mysql數(shù)據(jù)庫會(huì)按順序優(yōu)先級從/etc/my.cnf、/etc/mysql/my.cnf、/usr/etc/my.cnf、~/.my.cnf四個(gè)位置找my.cnf配置文件,一旦找到就不再繼續(xù)往下找。Ubuntu默認(rèn)將my.cnf配置文件放在/etc/mysql/my.cnf位置,所以在/etc/my.cnf位置沒有找到這個(gè)配置文件。

選擇自己使用的文本編輯器編輯my.cnf配置文件,我用vim,所以sudo vim /etc/mysql/my.cnf。一樣需要sudo,使用root權(quán)限編輯。將其中[mysqld]標(biāo)簽下的datadir屬性值改為新數(shù)據(jù)庫目錄路徑/mnt/data/mysql,如圖:

修改后保存并退出。


3.2 usr.bin.mysqld文件


由于Ubuntu使用了apparmor安全模塊,就是類似于沙盒運(yùn)行的一種機(jī)制,它可以限制軟件在運(yùn)行時(shí)的一些行為,比如對哪些目錄和文件可以讀寫加鎖等等。

由于修改了數(shù)據(jù)庫文件路徑,所以要修改mysql數(shù)據(jù)庫的apparmor配置文件,在其中將新數(shù)據(jù)庫文件目錄和文件的讀寫及加鎖權(quán)限添加上去,同時(shí)可以刪除或者注釋掉原先/var/lib/mysql數(shù)據(jù)庫文件目錄的權(quán)限。mysql數(shù)據(jù)庫的apparmor配置文件路徑在/etc/apparmor.d/usr.sbin.mysqld。使用下面命令編輯這個(gè)配置文件:

sudo vim /etc/apparmor.d/usr.sbin.mysqld?

找到其中的

? /var/lib/mysql/ r,
? /var/lib/mysql/** rwk,

兩行權(quán)限聲明,可以在前面加上#好注釋掉。然后對照格式,加入新路徑的權(quán)限聲明:
? /mnt/data/mysql/ r,
? /mnt/data/mysql/** rwk,

結(jié)果如圖:

保存并關(guān)閉。


3.3 abstractions/mysql文件


由于usr.bin.mysqld文件中引用了abstractions/mysql文件,也就是會(huì)將abstractions/mysql文件中的權(quán)限聲明導(dǎo)入進(jìn)來。因此,也修改下這個(gè)文件:

sudo vim /etc/apparmor.d/abstractions/mysql

同樣也是將新數(shù)據(jù)庫文件路徑中的socket文件權(quán)限添加進(jìn)去,同時(shí)可以刪除或者注釋掉全路徑中申請的權(quán)限,效果如圖:

?保存后退出。


4、重啟數(shù)據(jù)庫


配置文件修改成功后就可以重啟數(shù)據(jù)庫,重啟數(shù)據(jù)庫之前需要先重新載入apparmor配置文件,使用下面命令重新載入:


[plain]?view plaincopysudo?/etc/init.d/apparmor?restart??


重載成功就可以使用下面命令啟動(dòng)數(shù)據(jù)庫:


[plain]?view plaincopysudo?/etc/init.d/mysql?start??



5、權(quán)限問題


經(jīng)過上訴步驟之后,你有可能數(shù)據(jù)庫無法啟動(dòng)。忽略繼續(xù)登錄數(shù)據(jù)庫出現(xiàn)下面關(guān)于sock的錯(cuò)誤:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)


查看數(shù)據(jù)庫的啟動(dòng)錯(cuò)誤日志,sudo vim /var/log/mysql/error.log,還能看到Table 'plugin' is read only這樣的錯(cuò)誤:


出現(xiàn)這種情況的原因還是在于新數(shù)據(jù)庫文件目錄的權(quán)限。

mysql數(shù)據(jù)庫啟動(dòng)的時(shí)候需要以mysql用戶的身份執(zhí)行,所以mysql用戶需要具備能讀寫數(shù)據(jù)庫文件目錄的權(quán)限。雖然上面遷移數(shù)據(jù)庫文件的時(shí)候無論是使用mv還是cp -a命令都沒有更改mysql目錄的用戶和用戶組,上面也看到了/mnt/data/mysql所屬的用戶和用戶組都還是mysql。因此可以肯定mysql用戶具備讀寫/mnt/data/mysql的權(quán)限,但是這并沒有保證上級目錄/mnt/data和上上級目錄/mnt也具備讓mysql用戶讀取的權(quán)限。如果mysql用戶不具備上級目錄/mnt/data和上上級目錄/mnt的讀取權(quán)限,mysql用戶一樣讀寫不了自己的/mnt/data/mysql目錄,因此就會(huì)出現(xiàn)上面的問題。

可以過頭來看看原本數(shù)據(jù)庫文件目錄/var/lib/mysql的結(jié)構(gòu):


可以看出原本數(shù)據(jù)庫文件目錄/var/lib/mysql的上級目錄/var/lib屬于雖然屬于root用戶,但是它為同組用戶和其它組用戶都開放了’r'和‘x'權(quán)限,所以即使上級目錄不屬于mysql用戶,mysql用戶同樣也能正常進(jìn)入并訪問到自己的數(shù)據(jù)庫文件。

解決這個(gè)問題的方法說起來就是這么簡單,只要保證mysql用戶具備最終數(shù)據(jù)庫文件目錄的所有上級目錄的'r'和‘x'權(quán)限就可以了。

例如,使用下面命令修改本文中/mnt/data的權(quán)限:

sudo chmod 755 /mnt/data

再上級目錄/mnt是系統(tǒng)目錄,歸屬于root用戶,root用戶默認(rèn)的目錄的權(quán)限都是755,所以不用修改。

權(quán)限修改后再次啟動(dòng)數(shù)據(jù)庫sudo /etc/init.d/mysql start,應(yīng)該就能成功啟動(dòng)了。

進(jìn)入數(shù)據(jù)庫,查看當(dāng)前路徑配置信息:

數(shù)據(jù)庫已經(jīng)正常啟動(dòng), 并且數(shù)據(jù)庫文件路徑也已經(jīng)替換到/mnt/data/mysql目標(biāo)路徑,數(shù)據(jù)庫文件遷移成功。



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉