linux系統(tǒng)MySQL服務(wù)器的啟動與停止的方法步驟? 一、以非特權(quán)用戶運行MySQL服務(wù)器 在討論如何啟動MySQL服務(wù)器之前,讓我們考慮一下應(yīng)該以什么用戶身份運行MySQL服務(wù)器。服務(wù)器可以手動或自動啟動。如果你手動啟動它,服務(wù)器以你登錄Unix(Linux)的用戶身份啟動,即如果你用paul登錄Unix并啟動服務(wù)器,它用paul運行;如果你用su命令切換到root,然后運啟動服務(wù)器,則它以root運行。然而,大多數(shù)情況下你可能不想手動啟動服務(wù)器,最有可能是你安排MySQL服務(wù)器在系統(tǒng)引導(dǎo)時自動啟動,作為標準引導(dǎo)過程的一部分,在Unix下,該引導(dǎo)過程由系統(tǒng)的Unix用戶root執(zhí)行,并且任何在該過程中運行的進程均以root權(quán)限運行。 你應(yīng)該牢記MySQL服務(wù)器啟動過程的兩個目標:
要一個普通的非特權(quán)用戶運行服務(wù)器,按照下列步驟:
當(dāng)你設(shè)置數(shù)據(jù)目錄及其內(nèi)容的屬主和模式時,注意符號連接。你需要順著它們并改變它們指向的文件或目錄的屬主和模式。如果連接文件的目錄位于不屬于你的地方,會有些麻煩,你可能需要root身份。 在你完成了上述過程后,你應(yīng)該確保總是在以mysqladm或root登錄時啟動服務(wù)器,在后者,確定指定--user=mysqladm選項,使服務(wù)器能將其用戶ID切換到mysqladm(同時也適用于系統(tǒng)啟動過程)。 --user選項在MySQL 3.22中引入,如果你有老版本,你可以使用su命令告訴系統(tǒng)在以root運行時在特定的用戶下運行服務(wù)器。 二、啟動服務(wù)器的方法在我們確定了用于運行服務(wù)器的賬號后,你可以選擇如何安排啟動服務(wù)器。你可以從命令行手動或在系統(tǒng)引導(dǎo)過程中自動地運行它。對于啟動服務(wù)器由三種主要方法:
safe_mysqld腳本安裝在MySQL安裝目錄的bin目錄下,或可在MySQL源代碼分發(fā)的scripts目錄下找到。mysql.server腳本安裝在MySQL安裝目錄下的share/mysqld目錄下或可以在MySQL源代碼分發(fā)的support_files目錄下找到。如果你想使用它們,你需要將它們拷貝到適當(dāng)?shù)哪夸浵隆?/p> 對BSD風(fēng)格的系統(tǒng)(FreeBSD,OpenBSD等),通常在/etc目錄下有幾個文件在引導(dǎo)時初始化服務(wù),這些文件通常有以“rc”開頭的名字,且它有可能由一個名為“rc.local”的文件(或類似的東西),特意用于啟動本地安裝的服務(wù)。在這樣的系統(tǒng)上,你可能將類似于下列的行加入rc.local文件中以啟動服務(wù)器(如果safe_mysqld的目錄在你的系統(tǒng)上不同,修改它即可):
if [ -x /usr/local/bin/safe_mysqld ]; then
/usr/local/bin/safe_mysqld &
fi
對于對于System V風(fēng)格的系統(tǒng),你可以通過將mysql.server放在/etc下適當(dāng)?shù)膯幽夸浵聛戆惭b它。如果你運行Linux并從一個RPM文件安裝MySQL,這些已經(jīng)為你做好了,否則將腳本安裝在主啟動目錄下,并將指向它的連接放在適當(dāng)?shù)倪\行級別目錄下。你也可以使腳本只能由root啟動。 啟動文件的目錄布局各系統(tǒng)不同,所以你需要檢查一下看看你的系統(tǒng)如何組織它們。例如在Linux PPC上,目錄是/etc/rc.d和/etc/rc.d/rc3.d,這樣你可以這樣安裝腳本:
#cp mysql.server /etc/rc.d/init.d
#cd /etc/init.d
#chmod 500 mysql.server
#cd /etc/rc.d/rc3.d
#ln -s ../init.d/mysql.server S99mysql
在solaris上,主腳本目錄是/etc/init.d,并且運行級別目錄是/etc/rd2.d,所以命令看上去像這樣:
#cp mysql.server /etc/rc.d/init.d
#cd /etc/init.d
#chmod 500 mysql.server
#cd /etc/rc2.d
#ln -s ../init.d/mysql.server S99mysql
在系統(tǒng)啟動時,S99mysql腳本將自動用一個start參數(shù)調(diào)用。如果你有chkconfig命令(Linux上有),你可以由它幫助安裝mysql.server腳本而不是象上面那樣手工運行上述命令。 2.1 指定啟動選項如果你想在服務(wù)器啟動時指定額外的啟動選項,你可有兩種方法。你可以修改你使用的啟動腳本(safe_mysqld或mysql.server)并直接在調(diào)用服務(wù)器的行上指定選項,或在一個選項文件中指定選項。建議你如果可能在一個全局選項文件中指定選項,它通常位于/etc/my.cnf(Unix)或c:\my.cnf(Windows)。 某些種類的信息無法以服務(wù)器選項指定。對于這些你可能需要修改safe_mysqld。例如,如果你的服務(wù)器不能正確選擇本地時區(qū)而以GMT返回時間值,你可以設(shè)置TZ環(huán)境變量給它一個指示。如果你用safe_mysqld或mysql.server啟動服務(wù)器,你可以將一個時區(qū)設(shè)置加到safe_mysqld。找到啟動服務(wù)器的行并在該行前加入下列命令:
TZ=US/Central
export TZ
上面命令的語法是Solaris的,對于其他系統(tǒng)語法可能不同,請查閱相關(guān)手冊。如果你確實修改了你的啟動腳本,要記住下次你安裝MySQL時(如升級到新版本),你的修改將失去,除非你首先在別處復(fù)制了啟動腳本。在安裝了新版本后,比較新舊版本的腳本,看看你需要重建什么改變。 2.2 在啟動時檢查你的表除了安排你的服務(wù)器在系統(tǒng)引導(dǎo)時啟動,你可能要安裝myisamchk和isamchk腳本,以在服務(wù)器啟動前檢查你的表。你可能在一個崩潰后重啟,有可能表已經(jīng)損害,在啟動前檢查它是一個發(fā)現(xiàn)問題的好方法。 三、停止服務(wù)器要手工啟動服務(wù)器,使用mysqladmin: %mysqladmin shutdown 要自動停止服務(wù)器,你不需做特別的事情。BSD系統(tǒng)一般通過向進程發(fā)一個TERM信號停止服務(wù),它們或者正確應(yīng)答它或被粗魯?shù)貧⑺馈ysqld在它收到這個信號時以終止作為應(yīng)答。對于用mysql.server啟動服務(wù)器的System V風(fēng)格的系統(tǒng),停止進程將用一個stop參數(shù)調(diào)用該腳本,告訴服務(wù)器終止,當(dāng)然假定你已安裝了mysql.server。 四、如果你不能連接服務(wù)器,如何重新獲得對服務(wù)器的控制在某些情況下,你可能由于不能連接它而手工重啟服務(wù)器。當(dāng)然,這有點矛盾。因為一般你通過連接服務(wù)器而手工關(guān)掉它,那么這種情況如何會出現(xiàn)。 首先,MySQL root口令可以已經(jīng)設(shè)置為你不知道的值,這可能發(fā)生在你修改口令時,例如,如果你在輸入新口令時偶然鍵入一個不可見的控制字符。你也可能忘記口令。 其次,連接localhost通常通過一個Unix域套接字文件進行,一般是/tmp/mysql.sock。如果套接字文件被刪除了,本地客戶就不能連接。這可能發(fā)生在你的系統(tǒng)運行一個cron任務(wù)刪除了/tmp下的臨時文件。 如果你因為丟失套接字文件而不能連接,你可以簡單地通過重啟服務(wù)器重新創(chuàng)建得到它。因為服務(wù)器在啟動時重新創(chuàng)建它。這里的騙局是你不能用套接字建立連接因為它不見了,你必須建立一個TCP/IP連接,例如,如果服務(wù)器主機是pit.snake.net,你可以這樣連接: %mysqladmin -p -u root -h pit.snake.net shutdown 如果套接字文件被一個cron任務(wù)刪除,問題將重復(fù)出現(xiàn),除非你修改cron任務(wù)或使用一個或使用一個不同的套接字文件,你可以使用全局選項文件指定一個不同的套接字,例如,如果數(shù)據(jù)目錄是/usr/local/var,你可以通過將下列行加入/etc/my.cnf中,將套接字文件移到那里:
[mysqld]
socket=/usr/local/var/mysql.sock
[client]
socket=/usr/local/var/mysql.sock
對服務(wù)器和客戶均指定路徑名,使得它們都使用同一個套接字文件。如果你只為服務(wù)器設(shè)置路徑,客戶程序?qū)⑷匀黄谕谠恢脠?zhí)行套接字,在修改后重啟服務(wù)器,使它在新位置創(chuàng)建套接字。 如果你由于忘記root口令或已經(jīng)將它設(shè)置為不同于認為的值而不能連接,你需要重新獲得對服務(wù)器的控制,是你能再次設(shè)置口令:
五、運行多個服務(wù)器大多數(shù)再一臺給定的機器上運行單個MySQL服務(wù)器,但在很多情況下,運行多個服務(wù)器是很有用的:
很自然地,運行多個服務(wù)器比只運行一個服務(wù)器要復(fù)雜得多。如果你安裝多個版本,你不能在同一個地方安裝所有東西。當(dāng)服務(wù)器運行時,某些參數(shù)必須或很可能對每個服務(wù)器是唯一的,它們包括服務(wù)器在哪安裝、其數(shù)據(jù)目錄的路徑名、TCP/IP端口和UNIX域套接字路徑名以及用于運行服務(wù)器的UNIX賬號(如果你不再同一賬號下運行所有服務(wù)器)。如果你決定運行多個服務(wù)器,一定要注意你使用的參數(shù),是你不至于丟失對所發(fā)生的事情的蹤跡。 5.1 配置和安裝多個服務(wù)器如果你要運行不同版本的服務(wù)器而不是同一版本的多個實例,你必須在不同地點安裝它們。如果你安裝二進制分發(fā)(不用RPM),它們將安裝在包含不同版本號的目錄名下。如果你從源代碼安裝,最簡單的方法是在每個版本運行configure配置MySQL安裝過程中使用--with-prefix選項使得不同分發(fā)分開,這將使得所有東西安裝在一個單獨的目錄下,你可以將目錄域分發(fā)版本號聯(lián)系起來,如,你可以象這樣配置一個MySQL分發(fā),其中version是MySQL版本號: %.configure --with-prefix=/usr/local/mysql-version 如果你想運行同一版本服務(wù)器的多個實例,任何必須基于一個服務(wù)器特定設(shè)置的選項將需要在運行時指定。 5.2 多服務(wù)器的啟動過程啟動多個服務(wù)器比使用一個服務(wù)器要復(fù)雜。因為safe_mysqld和mysql.server均在單個服務(wù)器設(shè)置上工作得最好。建議你仔細研究一下safe_mysqld并用它作為你的啟動過程的基礎(chǔ),使用你修改的版本,你能針對你自己的需要更精確地裁剪它。 你必須處理的一個問題是如何在選項文件(my.cnf)中指定選項。對于多服務(wù)器,你不能對于每個不同的服務(wù)器設(shè)置使用/etc/my.cnf,你只能對所有服務(wù)器相同的設(shè)置使用該文件。如果服務(wù)器有一個不同的編譯進去的數(shù)據(jù)目錄位置,你可以在每個服務(wù)器數(shù)據(jù)目錄中的my.cnf中指定所有服務(wù)器要使用的設(shè)置,而使用DATADIR/my.cnf指定服務(wù)器特定的設(shè)置,這里DATADIR以服務(wù)器不同而不同。 另一種指定服務(wù)器選項的方法是用--default-file=path_name作為命令行的第一個選項,告訴服務(wù)器從名為path_name中的文件中讀取選項,這樣你可以把一個服務(wù)器選項放在一個對該服務(wù)器唯一的文件中,然后告訴服務(wù)器在啟動時讀取該文件。注意,如果你指定這個選項,將不使用通常的選項文件如/etc/my.cnf的任何一個。 以上linux系統(tǒng)MySQL服務(wù)器的啟動與停止的方法步驟?就是小編為大家收集整理的全部內(nèi)容了,希望對大家有所幫助。如果您喜歡這篇文章,可以收藏或分享給您的小伙伴們吧!歡迎持續(xù)關(guān)注我們的后續(xù)更新。 |
免責(zé)聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡(luò)收集,旨在傳播知識,文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請勿用于商業(yè)用途,如果損害了您的權(quán)利,請聯(lián)系我們及時修正或刪除。謝謝!
始終以前瞻性的眼光聚焦站長、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領(lǐng)域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長轉(zhuǎn)型升級,為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質(zhì)的創(chuàng)業(yè)信息和品牌營銷服務(wù),與站長一起進步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨!
掃一掃,關(guān)注站長網(wǎng)微信