十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
mysql存儲(chǔ)數(shù)據(jù)的時(shí)候都會(huì)把數(shù)據(jù)文件存儲(chǔ)到固定的位置,那么我們?nèi)绾尾榭催@個(gè)存儲(chǔ)數(shù)據(jù)文件的位置在哪里那?下面我給大家分享一下。
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的寧陽網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
首先我們進(jìn)入mysql的安裝目錄,如下圖所示,打開my.ini文件
接下來在打開的my.ini文件中,我們找到datadir所在行,如下圖所示,復(fù)制此行的路徑
然后我們?cè)诼窂捷斎肟蛑姓迟N此路徑,回車即可進(jìn)入數(shù)據(jù)文件所在的位置,如下圖所示
最后如果你想修改數(shù)據(jù)文件的位置,那么直接修改my.ini文件中datadir對(duì)應(yīng)的路徑即可,如下圖所示
my.cnf 是mysql啟動(dòng)時(shí)加載的配置文件,一般會(huì)放在mysql的安裝目錄中,用戶也可以放在其他目錄加載。
安裝mysql后,系統(tǒng)中會(huì)有多個(gè) my.cnf 文件,有些是用于測(cè)試的。
安裝locate
命令
輸出
當(dāng)我們需要修改配置文件時(shí),需要找到mysql啟動(dòng)時(shí)是加載了哪個(gè) my.cnf 文件。
啟動(dòng)mysql后,我們查看mysql的進(jìn)程,看看是否有設(shè)置使用指定目錄的 my.cnf 文件,如果有則表示mysql啟動(dòng)時(shí)是加載了這個(gè)配置文件。
命令
輸出
可以看到 /usr/local/Cellar/mysql/5.6.24/my.cnf 就是mysql啟動(dòng)加載的配置文件。
如果上面的命令沒有輸出,表示沒有設(shè)置使用指定目錄的 my.cnf 。
如果沒有設(shè)置使用指定目錄的 my.cnf ,mysql啟動(dòng)時(shí)會(huì)讀取安裝目錄根目錄及默認(rèn)目錄下的 my.cnf 文件。
查看mysql啟動(dòng)時(shí)讀取配置文件的默認(rèn)目錄
命令
輸出
這些就是mysql默認(rèn)會(huì)搜尋 my.cnf 的目錄,順序排前的優(yōu)先。
如果沒有設(shè)置使用指定目錄 my.cnf 文件及默認(rèn)讀取目錄沒有 my.cnf 文件,表示mysql啟動(dòng)時(shí)并沒有加載配置文件,而是使用默認(rèn)配置。
需要修改配置,可以在mysql默認(rèn)讀取的目錄中,創(chuàng)建一個(gè) my.cnf 文件(例如: /etc/my.cnf ),把需要修改的配置內(nèi)容寫入,重啟mysql后即可生效。
一、查看文件安裝路徑
由于軟件安裝的地方不止一個(gè)地方,所有先說查看文件安裝的所有路徑(地址)。
這里以mysql為例。比如說我安裝了mysql,但是不知道文件都安裝在哪些地方、放在哪些文件夾里,可以用下面的命令查看所有的文件路徑
在終端輸入:
whereis mysql
回車,如果你安裝好了mysql,就會(huì)顯示文件安裝的地址,例如我的顯示(安裝地址可能會(huì)不同)
root@ubuntu:/# whereis mysql
mysql: /usr/bin/mysql /usr/bin/X11/mysql /usr/local/mysql
二、查詢運(yùn)行文件所在路徑(文件夾地址)
如果你只要查詢文件的運(yùn)行文件所在地址,直接用下面的命令就可以了(還是以mysql為例):
which mysql
終端顯示:
root@ubuntu:/# which mysql
/usr/bin/mysql
(望樓主采納哦)
有兩種方法,一種方法使用mysql的check table和repair table 的sql語句,另一種方法是使用MySQL提供的多個(gè)myisamchk, isamchk數(shù)據(jù)檢測(cè)恢復(fù)工具。前者使用起來比較簡(jiǎn)便。推薦使用。
1. check table 和 repair table
登陸mysql 終端:
mysql -uxxxxx -p dbname
check table tabTest;
如果出現(xiàn)的結(jié)果說Status是OK,則不用修復(fù),如果有Error,可以用:
repair table tabTest;
進(jìn)行修復(fù),修復(fù)之后可以在用check table命令來進(jìn)行檢查。在新版本的phpMyAdmin里面也可以使用check/repair的功能。
2. myisamchk, isamchk
其中myisamchk適用于MYISAM類型的數(shù)據(jù)表,而isamchk適用于ISAM類型的數(shù)據(jù)表。這兩條命令的主要參數(shù)相同,一般新的系統(tǒng)都使用MYISAM作為缺省的數(shù)據(jù)表類型,這里以myisamchk為例子進(jìn)行說明。當(dāng)發(fā)現(xiàn)某個(gè)數(shù)據(jù)表出現(xiàn)問題時(shí)可以使用:
myisamchk tablename.MYI
進(jìn)行檢測(cè),如果需要修復(fù)的話,可以使用:
myisamchk -of tablename.MYI
關(guān)于myisamchk的詳細(xì)參數(shù)說明,可以參見它的使用幫助。需要注意的時(shí)在進(jìn)行修改時(shí)必須確保MySQL服務(wù)器沒有訪問這個(gè)數(shù)據(jù)表,保險(xiǎn)的情況下是最好在進(jìn)行檢測(cè)時(shí)把MySQL服務(wù)器Shutdown掉。
-----------------------------
另外可以把下面的命令放在你的rc.local里面啟動(dòng)MySQL服務(wù)器前:
[ -x /tmp/mysql.sock ] /pathtochk/myisamchk -of /DATA_DIR/*/*.MYI
其中的/tmp/mysql.sock是MySQL監(jiān)聽的Sock文件位置,對(duì)于使用RPM安裝的用戶應(yīng)該是/var/lib/mysql/mysql.sock,對(duì)于使用源碼安裝則是/tmp/mysql.sock可以根據(jù)自己的實(shí)際情況進(jìn)行變更,而pathtochk則是myisamchk所在的位置,DATA_DIR是你的MySQL數(shù)據(jù)庫存放的位置。
需要注意的時(shí),如果你打算把這條命令放在你的rc.local里面,必須確認(rèn)在執(zhí)行這條指令時(shí)MySQL服務(wù)器必須沒有啟動(dòng)!檢測(cè)修復(fù)所有數(shù)據(jù)庫(表)