今天就跟大家聊聊有關(guān)MySQL中怎么重定位數(shù)據(jù)庫目錄的內(nèi)容,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
創(chuàng)新互聯(lián)專注于企業(yè)網(wǎng)絡營銷推廣、網(wǎng)站重做改版、龍川網(wǎng)站定制設計、自適應品牌網(wǎng)站建設、H5響應式網(wǎng)站、商城系統(tǒng)網(wǎng)站開發(fā)、集團公司官網(wǎng)建設、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應式網(wǎng)頁設計等建站業(yè)務,價格優(yōu)惠性價比高,為龍川等各大城市提供網(wǎng)站開發(fā)制作服務。
◆MySQL 允許您重定位其中的數(shù)據(jù)目錄或元素。這樣做有幾個原因:
◆可以用比缺省定位的文件系統(tǒng)更大的容量在文件系統(tǒng)中放置數(shù)據(jù)目錄。
◆如果數(shù)據(jù)目錄在繁忙的磁盤上,可以將其放置到較少使用的驅(qū)動器上,以平衡物理設備之間的磁盤活動。為了類似的原因,可以將數(shù)據(jù)庫和日志文件放在不同的驅(qū)動器上,或在驅(qū)動器之間對數(shù)據(jù)庫進行再分布。
◆您可以運行多個服務器,并且每個服務器都有屬于自己的數(shù)據(jù)目錄。這是一種解決總進程文件描述符限制問題的方法,尤其是當不能重新配置系統(tǒng)的核心以得到更高的限制值時。
◆某些系統(tǒng)將 PID 文件保存在諸如 /var/run 的目錄中。為了系統(tǒng)運作的一致性,您可以將 MySQL PID 文件也放在那里。
重定位方法
有兩種對數(shù)據(jù)目錄重定位的方法:
◆可以在命令行或在一個選項文件的 [mysqld] 組上,在服務器啟動時間指定一個選項。
◆可以移動要重定位的內(nèi)容,然后在原始的位置中做一個指向新位置的 symlink (symbolic link,符號鏈接)。
兩種方法的任何一種都不能為您進行全部的重定位工作。表5-3 綜合了可重定位的內(nèi)容以及可用于重定位的方法。
如果您使用一個選項文件,可以指定在全局選項文件 /etc/my.cnf(Windows 中的 c:my.cnf)中的選項。當前的 Windows 版本還訪問系統(tǒng)目錄(c: 或 c:WINNT)。
您還可以使用缺省數(shù)據(jù)目錄的選項文件 my.cnf(該目錄編譯在服務器中)。筆者不建議使用此文件。如果要重定位數(shù)據(jù)目錄本身,必須保持缺省數(shù)據(jù)目錄的完整性,以便在數(shù)據(jù)目錄中放置一個選項文件,該文件將說明服務器應該在哪里找到“真正”的數(shù)據(jù)目錄!真亂。如果想要用一個選項文件來指定服務器的選項,則最好使用 /etc/my.cnf。
重定位數(shù)據(jù)目錄
現(xiàn)在說明重定位目錄的方法與步驟。
1、關(guān)閉服務器,例如:
$ admin –u root -p shutdown
2、將數(shù)據(jù)庫目錄移動到新的位置
3、然后刪除原來的數(shù)據(jù)庫
4、如果用symlink方法(Unix平臺上),例如:
$ ln –s NEWDIR DATADIR
DATADIR是標準的數(shù)據(jù)庫目錄的位置,也是原來的數(shù)據(jù)庫目錄路徑
。
如果用起動選項的方法,可以這樣啟動:
$safe_mysqld --basedir=/path/to/dir/ & (Unix)
$mysqld --basedir=x:datadir (Windows)
如果用選項文件的方法:
在/etc/my.cnf(Unix)或者c:my.cnf(Windows)中加入:
[mysqld]
datadir=/path/to/dir/
5、重新啟動數(shù)據(jù)庫
重定位數(shù)據(jù)庫
重定位數(shù)據(jù)庫只能通過symlink方法,因此windows平臺無法重定位數(shù)據(jù)庫。為了重定位數(shù)據(jù)庫,應關(guān)閉數(shù)據(jù)庫,移動數(shù)據(jù)庫的目錄。刪除原來的數(shù)據(jù)庫目錄,用指向新位置的symlink來代替她,然后啟動服務器。
下面用一個實際的例子――備份bigdb――說明這個過程:
$mysqladmin –u root –p
$cd DATADIR
$tar cf bigdb|(cd /var/db;tar xf)
$mv bigdb bigdb.old
$ln –s var/db/bigdb .
$safe_mysqld &
應該以數(shù)據(jù)庫目錄所有者的身份執(zhí)行這些命令。服務器工作正常之后,可以刪除備份目錄bigdb.old:
$rm –rf bigdb.old
重定位數(shù)據(jù)庫表
對單個數(shù)據(jù)庫表重新定位并不是特別有用,有時反而會造成很大的麻煩??梢酝ㄟ^將表的文件移動到另一個位置不再該書據(jù)庫目錄中創(chuàng)建指向這些文件的symlink來進行。方法類似于重定位數(shù)據(jù)庫的方法。
但是,如果曾經(jīng)發(fā)布過 ALTER TABLE或OPTIMIZE TABLE語句,則所做的這些重定位工作將被取消。其原因就不介紹了。
重定位狀態(tài)文件
狀態(tài)文件中PID文件、常規(guī)日志褐更新日志,可以用起動選項或者選項文件的方法重新定位。錯誤日志由safe_mysqld創(chuàng)建且不能夠重新定位,除非編輯safe_mysqld腳本。
為了在另一個位置寫狀態(tài)文件,因關(guān)閉服務器,然后用制定新狀態(tài)文件位置的恰當選項啟動他。
啟動選項:
--pid-file=pidfile PID文件
--log=logfile 常規(guī)日志
--log-update=updatefile 更新日志
選項文件
[mysqld]
pid-file=pidfile
log=logfile
log-update=updatefile
狀態(tài)文件的命名規(guī)則:
1、如果以絕對路徑指定一個狀態(tài)文件的名稱,則用該路徑創(chuàng)建改文件。
例如,你指定—pid-file=/var/run/mysqld.pid,則該PID文件的就是/var/run/mysqld.pid
2、如果你只給出文件名,則文件在數(shù)據(jù)庫目錄下創(chuàng)建。
例如,你指定—pid-file=mysqld.pid則該PID文件為DATADIR/mysqld.pid
3、如果沒有給出文件,則狀態(tài)文件使用缺省的名字。
這樣做將告訴服務器啟用狀態(tài)文件,這對PID文件沒有意義,因為服務器總是使用它。例如:
$safe_mysqld --log --log-update &
或者,使用選項文件:
[mysqld]
log
log-update
對于常規(guī)日志,將生成DATADIR/hostname.log文件,hostname是運行服務器的主機名。對于更新日志,生成DATADIR/hostname.nnn的順序文件。
4、對于更新日志,如果指定一個沒有擴展名的更新日志,則MySQL在打開該更新日志是將生成數(shù)據(jù)的名字。這些名字用.nnn擴展名創(chuàng)建,這里的.nnn是違背已有的更新日志文件使用過的第一個號碼(如,hostname.001、hostname.002等等)??梢酝ㄟ^指定明確的擴展名來忽略順序名字的生成,然后服務器將僅使用您指定的名字。
總結(jié)
在本節(jié)中你將學到如何重新定位數(shù)據(jù)庫目錄,以及狀態(tài)文件等。你可能需要重定位的內(nèi)容有:
1、數(shù)據(jù)庫目錄
2、數(shù)據(jù)庫
3、狀態(tài)文件,包括常規(guī)日志,更新日志等
重定位的方法有:
1、符號鏈接
2、指定命令行參數(shù)
3、使用選項文件
看完上述內(nèi)容,你們對MySQL中怎么重定位數(shù)據(jù)庫目錄的內(nèi)容有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。