明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

教你如何打開與停止Mysql服務(wù)之二

[摘要]三、停止服務(wù)器 要手工啟動服務(wù)器,使用MySQLadmin: %mysqladmin shutdown 要自動停止服務(wù)器,你不需做特別的事情。BSD系統(tǒng)一般通過向進(jìn)程發(fā)一個TERM信號停止服務(wù),它們或者正確應(yīng)答它或被粗魯?shù)貧⑺馈ysqld在它收到這個信號時以終止作為...
三、停止服務(wù)器
要手工啟動服務(wù)器,使用MySQLadmin:

%mysqladmin shutdown

要自動停止服務(wù)器,你不需做特別的事情。BSD系統(tǒng)一般通過向進(jìn)程發(fā)一個TERM信號停止服務(wù),它們或者正確應(yīng)答它或被粗魯?shù)貧⑺。mysqld在它收到這個信號時以終止作為應(yīng)答。對于用mysql.server啟動服務(wù)器的System V風(fēng)格的系統(tǒng),停止進(jìn)程將用一個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域套接字文件進(jìn)行,一般是/tmp/mysql.sock。如果套接字文件被刪除了,本地客戶就不能連接。這可能發(fā)生在你的系統(tǒng)運行一個cron任務(wù)刪除了/tmp下的臨時文件。

如果你因為丟失套接字文件而不能連接,你可以簡單地通過重啟服務(wù)器重新創(chuàng)建得到它。因為服務(wù)器在啟動時重新創(chuàng)建它。這里的騙局是你不能用套接字建立連接因為它不見了,你必須建立一個TCP/IP連接,例如,如果服務(wù)器主機(jī)是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è)置為不同于認(rèn)為的值而不能連接,你需要重新獲得對服務(wù)器的控制,是你能再次設(shè)置口令:



中斷服務(wù)器

如果你以root登錄服務(wù)器主機(jī),你可以用kill命令終止服務(wù)器。你可以使用ps命令或通過尋找服務(wù)器的PID文件(通常在數(shù)據(jù)目錄中)找出服務(wù)器進(jìn)程的ID。

最好是首先嘗試用一個向服務(wù)器發(fā)出一個TERM信號的正常kill看它是否將以正常終止應(yīng)答。這種方式下,表和日志將正確地被清空。如果服務(wù)器阻塞并且不應(yīng)答一個正常終止信號,你可以用kill -9強(qiáng)制終止它。這是最后的手段了,因為這可能有未清空的修改,而且你冒著讓表處于一個不一致狀態(tài)的風(fēng)險。

如果你用kill -9終止服務(wù)器,要確保在啟動服務(wù)器前用myisamchk和isamchk檢查你的表。
用--skip-grant-table選項重啟服務(wù)器。
這告訴服務(wù)器不使用授權(quán)表驗證連接,這允許你以root連接而無須口令。在你已經(jīng)連接后,改變root口令。
用mysqladmin flush-privileges告訴服務(wù)器再次使用授權(quán)表啟動
如果你的mysqladmin版本不認(rèn)識Flash-privileges,試一試reload。

五、運行多個服務(wù)器

大多數(shù)再一臺給定的機(jī)器上運行單個MySQL服務(wù)器,但在很多情況下,運行多個服務(wù)器是很有用的:

你可能想測試一個服務(wù)器的新版本,而保留你正在運行的生產(chǎn)服務(wù)器。在這種情況下,你會運行不同的服務(wù)器代碼。
操作系統(tǒng)一般限制每個進(jìn)程的打開文件句柄數(shù)量。如果你的系統(tǒng)很難提高這個限制,運行多個服務(wù)器是解決限制的一種方法。在這種情況下,你可能運行統(tǒng)一服務(wù)器的多個實例。
ISP經(jīng)常為其客戶提供自己的MySQL安裝,有必要涉及單獨的服務(wù)器。在這種情況下,你可能運行同一版本的多個實例或不同版本,如果不同的客戶想要不同版本的MySQL。
很自然地,運行多個服務(wù)器比只運行一個服務(wù)器要復(fù)雜得多。如果你安裝多個版本,你不能在同一個地方安裝所有東西。當(dāng)服務(wù)器運行時,某些參數(shù)必須或很可能對每個服務(wù)器是唯一的,它們包括服務(wù)器在哪安裝、其數(shù)據(jù)目錄的路徑名、TCP/IP端口和UNIX域套接字路徑名以及用于運行服務(wù)器的UNIX賬號(如果你不再同一賬號下運行所有服務(wù)器)。如果你決定運行多個服務(wù)器,一定要注意你使用的參數(shù),是你不至于。

以上就是教你如何啟動和停止Mysql服務(wù)之二的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。