Mysql服務(wù)器的啟動(dòng)與停止(二)
要手工啟動(dòng)服務(wù)器,使用MySQLadmin:
%mysqladmin shutdown
要自動(dòng)停止服務(wù)器,你不需做特別的事情。BSD系統(tǒng)一般通過(guò)向進(jìn)程發(fā)一個(gè)TERM信號(hào)停止服務(wù),它們或者正確應(yīng)答它或被粗魯?shù)貧⑺?。mysqld在它收到這個(gè)信號(hào)時(shí)以終止作為應(yīng)答。對(duì)于用mysql.server啟動(dòng)服務(wù)器的System V風(fēng)格的系統(tǒng),停止進(jìn)程將用一個(gè)stop參數(shù)調(diào)用該腳本,告訴服務(wù)器終止,當(dāng)然假定你已安裝了mysql.server。
四、如果你不能連接服務(wù)器,如何重新獲得對(duì)服務(wù)器的控制
在某些情況下,你可能由于不能連接它而手工重啟服務(wù)器。當(dāng)然,這有點(diǎn)矛盾。因?yàn)橐话隳阃ㄟ^(guò)連接服務(wù)器而手工關(guān)掉它,那么這種情況如何會(huì)出現(xiàn)。
首先,MySQL root口令可以已經(jīng)設(shè)置為你不知道的值,這可能發(fā)生在你修改口令時(shí),例如,如果你在輸入新口令時(shí)偶然鍵入一個(gè)不可見(jiàn)的控制字符。你也可能忘記口令。
其次,連接localhost通常通過(guò)一個(gè)Unix域套接字文件進(jìn)行,一般是/tmp/mysql.sock。如果套接字文件被刪除了,本地客戶(hù)就不能連接。這可能發(fā)生在你的系統(tǒng)運(yùn)行一個(gè)cron任務(wù)刪除了/tmp下的臨時(shí)文件。
如果你因?yàn)閬G失套接字文件而不能連接,你可以簡(jiǎn)單地通過(guò)重啟服務(wù)器重新創(chuàng)建得到它。因?yàn)榉?wù)器在啟動(dòng)時(shí)重新創(chuàng)建它。這里的騙局是你不能用套接字建立連接因?yàn)樗灰?jiàn)了,你必須建立一個(gè)TCP/IP連接,例如,如果服務(wù)器主機(jī)是pit.snake.net,你可以這樣連接:
%mysqladmin -p -u root -h pit.snake.net shutdown
如果套接字文件被一個(gè)cron任務(wù)刪除,問(wèn)題將重復(fù)出現(xiàn),除非你修改cron任務(wù)或使用一個(gè)或使用一個(gè)不同的套接字文件,你可以使用全局選項(xiàng)文件指定一個(gè)不同的套接字,例如,如果數(shù)據(jù)目錄是/usr/local/var,你可以通過(guò)將下列行加入/etc/my.cnf中,將套接字文件移到那里:
[mysqld]
socket=/usr/local/var/mysql.sock
[client]
socket=/usr/local/var/mysql.sock
對(duì)服務(wù)器和客戶(hù)均指定路徑名,使得它們都使用同一個(gè)套接字文件。如果你只為服務(wù)器設(shè)置路徑,客戶(hù)程序?qū)⑷匀黄谕谠恢脠?zhí)行套接字,在修改后重啟服務(wù)器,使它在新位置創(chuàng)建套接字。
如果你由于忘記root口令或已經(jīng)將它設(shè)置為不同于認(rèn)為的值而不能連接,你需要重新獲得對(duì)服務(wù)器的控制,是你能再次設(shè)置口令:
中斷服務(wù)器
如果你以root登錄服務(wù)器主機(jī),你可以用kill命令終止服務(wù)器。你可以使用ps命令或通過(guò)尋找服務(wù)器的PID文件(通常在數(shù)據(jù)目錄中)找出服務(wù)器進(jìn)程的ID。
最好是首先嘗試用一個(gè)向服務(wù)器發(fā)出一個(gè)TERM信號(hào)的正常kill看它是否將以正常終止應(yīng)答。這種方式下,表和日志將正確地被清空。如果服務(wù)器阻塞并且不應(yīng)答一個(gè)正常終止信號(hào),你可以用kill -9強(qiáng)制終止它。這是最后的手段了,因?yàn)檫@可能有未清空的修改,而且你冒著讓表處于一個(gè)不一致?tīng)顟B(tài)的風(fēng)險(xiǎn)。
如果你用kill -9終止服務(wù)器,要確保在啟動(dòng)服務(wù)器前用myisamchk和isamchk檢查你的表。
用--skip-grant-table選項(xiàng)重啟服務(wù)器。
這告訴服務(wù)器不使用授權(quán)表驗(yàn)證連接,這允許你以root連接而無(wú)須口令。在你已經(jīng)連接后,改變r(jià)oot口令。
用mysqladmin flush-privileges告訴服務(wù)器再次使用授權(quán)表啟動(dòng)
如果你的mysqladmin版本不認(rèn)識(shí)Flash-privileges,試一試reload。
五、運(yùn)行多個(gè)服務(wù)器
大多數(shù)再一臺(tái)給定的機(jī)器上運(yùn)行單個(gè)MySQL服務(wù)器,但在很多情況下,運(yùn)行多個(gè)服務(wù)器是很有用的:
你可能想測(cè)試一個(gè)服務(wù)器的新版本,而保留你正在運(yùn)行的生產(chǎn)服務(wù)器。在這種情況下,你會(huì)運(yùn)行不同的服務(wù)器代碼。
操作系統(tǒng)一般限制每個(gè)進(jìn)程的打開(kāi)文件句柄數(shù)量。如果你的系統(tǒng)很難提高這個(gè)限制,運(yùn)行多個(gè)服務(wù)器是解決限制的一種方法。在這種情況下,你可能運(yùn)行統(tǒng)一服務(wù)器的多個(gè)實(shí)例。
ISP經(jīng)常為其客戶(hù)提供自己的MySQL安裝,有必要涉及單獨(dú)的服務(wù)器。在這種情況下,你可能運(yùn)行同一版本的多個(gè)實(shí)例或不同版本,如果不同的客戶(hù)想要不同版本的MySQL。
很自然地,運(yùn)行多個(gè)服務(wù)器比只運(yùn)行一個(gè)服務(wù)器要復(fù)雜得多。如果你安裝多個(gè)版本,你不能在同一個(gè)地方安裝所有東西。當(dāng)服務(wù)器運(yùn)行時(shí),某些參數(shù)必須或很可能對(duì)每個(gè)服務(wù)器是唯一的,它們包括服務(wù)器在哪安裝、其數(shù)據(jù)目錄的路徑名、TCP/IP端口和UNIX域套接字路徑名以及用于運(yùn)行服務(wù)器的UNIX賬號(hào)(如果你不再同一賬號(hào)下運(yùn)行所有服務(wù)器)。如果你決定運(yùn)行多個(gè)服務(wù)器,一定要注意你使用的參數(shù),是你不至于。
- Mysql服務(wù)器的啟動(dòng)與停止(一)
- MySQL服務(wù)器的啟動(dòng)和關(guān)閉
- mysql服務(wù)無(wú)法啟動(dòng)報(bào)錯(cuò)誤1067解決方法(mysql啟動(dòng)錯(cuò)誤1067 )
- Linux下啟動(dòng)多個(gè)mysql服務(wù)器例子
- mysql不能啟動(dòng)報(bào)error2013錯(cuò)誤的多種解決方案
- MySQL 啟動(dòng)報(bào)錯(cuò):File ./mysql-bin.index not found (Errcode: 13)
- 解決Mysql服務(wù)器啟動(dòng)時(shí)報(bào)錯(cuò)問(wèn)題的方法
相關(guān)文章
十個(gè)節(jié)省時(shí)間的MySQL命令小結(jié)
編者在工作中積累起來(lái)了一些MySQL命令行客戶(hù)端技巧,這些技巧或多或少會(huì)幫助您節(jié)省大量的時(shí)間。2011-03-03MySQL?Replication中的并行復(fù)制示例詳解
MySQL在5.6版本之前,主從復(fù)制的從節(jié)點(diǎn)上有兩個(gè)線(xiàn)程,分別是I/O線(xiàn)程和SQL線(xiàn)程,今天通過(guò)本文給大家介紹MySQL?Replication中的并行復(fù)制示例詳解,感興趣的朋友一起看看吧2022-07-07navicat連接mysql時(shí)出現(xiàn)1045錯(cuò)誤的解決方法
這篇文章主要為大家詳細(xì)介紹了navicat連接mysql時(shí)出現(xiàn)1045錯(cuò)誤的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02MySQL數(shù)據(jù)庫(kù)遠(yuǎn)程訪(fǎng)問(wèn)權(quán)限設(shè)置方式
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)遠(yuǎn)程訪(fǎng)問(wèn)權(quán)限設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04MySQL ERROR 1045 (28000) 錯(cuò)誤的解決辦法
這篇文章主要介紹了MySQL ERROR 1045 (28000) 錯(cuò)誤的解決辦法,很實(shí)用的解決方法,感興趣的小伙伴們可以參考一下2016-06-06MySQL數(shù)據(jù)庫(kù)命名規(guī)范及約定
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)的操作規(guī)范及、表名約定、列名約定,需要的朋友可以參考下2014-03-03Mongodb中關(guān)于GUID的顯示問(wèn)題詳析
這篇文章主要給大家介紹了關(guān)于Mongodb中GUID的顯示問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Mongodb具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05mysql一次將多條不同sql查詢(xún)結(jié)果并封裝到一個(gè)結(jié)果集的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于mysql一次將多條不同sql查詢(xún)結(jié)果并封裝到一個(gè)結(jié)果集的實(shí)現(xiàn)方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-03-03