溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL中怎么重定位數(shù)據(jù)庫目錄的內(nèi)容

發(fā)布時(shí)間:2021-08-04 16:57:47 來源:億速云 閱讀:299 作者:Leah 欄目:數(shù)據(jù)庫

今天就跟大家聊聊有關(guān)MySQL中怎么重定位數(shù)據(jù)庫目錄的內(nèi)容,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

◆MySQL 允許您重定位其中的數(shù)據(jù)目錄或元素。這樣做有幾個(gè)原因:

◆可以用比缺省定位的文件系統(tǒng)更大的容量在文件系統(tǒng)中放置數(shù)據(jù)目錄。

◆如果數(shù)據(jù)目錄在繁忙的磁盤上,可以將其放置到較少使用的驅(qū)動器上,以平衡物理設(shè)備之間的磁盤活動。為了類似的原因,可以將數(shù)據(jù)庫和日志文件放在不同的驅(qū)動器上,或在驅(qū)動器之間對數(shù)據(jù)庫進(jìn)行再分布。

◆您可以運(yùn)行多個(gè)服務(wù)器,并且每個(gè)服務(wù)器都有屬于自己的數(shù)據(jù)目錄。這是一種解決總進(jìn)程文件描述符限制問題的方法,尤其是當(dāng)不能重新配置系統(tǒng)的核心以得到更高的限制值時(shí)。

◆某些系統(tǒng)將 PID 文件保存在諸如 /var/run 的目錄中。為了系統(tǒng)運(yùn)作的一致性,您可以將 MySQL PID 文件也放在那里。

重定位方法
 

有兩種對數(shù)據(jù)目錄重定位的方法:
 

◆可以在命令行或在一個(gè)選項(xiàng)文件的 [mysqld] 組上,在服務(wù)器啟動時(shí)間指定一個(gè)選項(xiàng)。

 
◆可以移動要重定位的內(nèi)容,然后在原始的位置中做一個(gè)指向新位置的 symlink (symbolic link,符號鏈接)。
 

兩種方法的任何一種都不能為您進(jìn)行全部的重定位工作。表5-3 綜合了可重定位的內(nèi)容以及可用于重定位的方法。

 
如果您使用一個(gè)選項(xiàng)文件,可以指定在全局選項(xiàng)文件 /etc/my.cnf(Windows 中的 c:my.cnf)中的選項(xiàng)。當(dāng)前的 Windows 版本還訪問系統(tǒng)目錄(c: 或 c:WINNT)。
 

您還可以使用缺省數(shù)據(jù)目錄的選項(xiàng)文件 my.cnf(該目錄編譯在服務(wù)器中)。筆者不建議使用此文件。如果要重定位數(shù)據(jù)目錄本身,必須保持缺省數(shù)據(jù)目錄的完整性,以便在數(shù)據(jù)目錄中放置一個(gè)選項(xiàng)文件,該文件將說明服務(wù)器應(yīng)該在哪里找到“真正”的數(shù)據(jù)目錄!真亂。如果想要用一個(gè)選項(xiàng)文件來指定服務(wù)器的選項(xiàng),則最好使用 /etc/my.cnf。


重定位數(shù)據(jù)目錄
 

現(xiàn)在說明重定位目錄的方法與步驟。

 
1、關(guān)閉服務(wù)器,例如:

 
$ admin –u root -p shutdown
 

2、將數(shù)據(jù)庫目錄移動到新的位置

 
3、然后刪除原來的數(shù)據(jù)庫

 
4、如果用symlink方法(Unix平臺上),例如:

 
$ ln –s NEWDIR DATADIR

 
DATADIR是標(biāo)準(zhǔn)的數(shù)據(jù)庫目錄的位置,也是原來的數(shù)據(jù)庫目錄路徑

如果用起動選項(xiàng)的方法,可以這樣啟動:

 
$safe_mysqld --basedir=/path/to/dir/  & (Unix)
$mysqld --basedir=x:datadir  (Windows)

 
如果用選項(xiàng)文件的方法:

 
在/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ù)庫,應(yīng)關(guān)閉數(shù)據(jù)庫,移動數(shù)據(jù)庫的目錄。刪除原來的數(shù)據(jù)庫目錄,用指向新位置的symlink來代替她,然后啟動服務(wù)器。

 
下面用一個(gè)實(shí)際的例子――備份bigdb――說明這個(gè)過程:
 

$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 &


應(yīng)該以數(shù)據(jù)庫目錄所有者的身份執(zhí)行這些命令。服務(wù)器工作正常之后,可以刪除備份目錄bigdb.old:

$rm –rf bigdb.old

重定位數(shù)據(jù)庫表

對單個(gè)數(shù)據(jù)庫表重新定位并不是特別有用,有時(shí)反而會造成很大的麻煩??梢酝ㄟ^將表的文件移動到另一個(gè)位置不再該書據(jù)庫目錄中創(chuàng)建指向這些文件的symlink來進(jìn)行。方法類似于重定位數(shù)據(jù)庫的方法。

但是,如果曾經(jīng)發(fā)布過 ALTER TABLE或OPTIMIZE TABLE語句,則所做的這些重定位工作將被取消。其原因就不介紹了。

重定位狀態(tài)文件

狀態(tài)文件中PID文件、常規(guī)日志褐更新日志,可以用起動選項(xiàng)或者選項(xiàng)文件的方法重新定位。錯誤日志由safe_mysqld創(chuàng)建且不能夠重新定位,除非編輯safe_mysqld腳本。

為了在另一個(gè)位置寫狀態(tài)文件,因關(guān)閉服務(wù)器,然后用制定新狀態(tài)文件位置的恰當(dāng)選項(xiàng)啟動他。

啟動選項(xiàng):

--pid-file=pidfile PID文件
--log=logfile 常規(guī)日志
--log-update=updatefile 更新日志

選項(xiàng)文件

[mysqld]
pid-file=pidfile
log=logfile
log-update=updatefile

狀態(tài)文件的命名規(guī)則:

1、如果以絕對路徑指定一個(gè)狀態(tài)文件的名稱,則用該路徑創(chuàng)建改文件。
例如,你指定—pid-file=/var/run/mysqld.pid,則該P(yáng)ID文件的就是/var/run/mysqld.pid

2、如果你只給出文件名,則文件在數(shù)據(jù)庫目錄下創(chuàng)建。

例如,你指定—pid-file=mysqld.pid則該P(yáng)ID文件為DATADIR/mysqld.pid

3、如果沒有給出文件,則狀態(tài)文件使用缺省的名字。
這樣做將告訴服務(wù)器啟用狀態(tài)文件,這對PID文件沒有意義,因?yàn)榉?wù)器總是使用它。例如:

$safe_mysqld --log --log-update &

或者,使用選項(xiàng)文件:

[mysqld]
log
log-update

對于常規(guī)日志,將生成DATADIR/hostname.log文件,hostname是運(yùn)行服務(wù)器的主機(jī)名。對于更新日志,生成DATADIR/hostname.nnn的順序文件。

4、對于更新日志,如果指定一個(gè)沒有擴(kuò)展名的更新日志,則MySQL在打開該更新日志是將生成數(shù)據(jù)的名字。這些名字用.nnn擴(kuò)展名創(chuàng)建,這里的.nnn是違背已有的更新日志文件使用過的第一個(gè)號碼(如,hostname.001、hostname.002等等)??梢酝ㄟ^指定明確的擴(kuò)展名來忽略順序名字的生成,然后服務(wù)器將僅使用您指定的名字。

總結(jié)

在本節(jié)中你將學(xué)到如何重新定位數(shù)據(jù)庫目錄,以及狀態(tài)文件等。你可能需要重定位的內(nèi)容有:

1、數(shù)據(jù)庫目錄
2、數(shù)據(jù)庫
3、狀態(tài)文件,包括常規(guī)日志,更新日志等

重定位的方法有:

1、符號鏈接
2、指定命令行參數(shù)
3、使用選項(xiàng)文件

看完上述內(nèi)容,你們對MySQL中怎么重定位數(shù)據(jù)庫目錄的內(nèi)容有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI