Mysql伺服器的啟動與停止(二)

來源:互聯網
上載者:User

三、停止伺服器
要手工啟動伺服器,使用MySQLadmin:

%mysqladmin shutdown

要自動停止伺服器,你不需做特別的事情。BSD系統一般通過向進程發一個TERM訊號停止服務,它們或者正確應答它或被粗魯地殺死。mysqld在它收到這個訊號時以終止作為應答。對於用mysql.server啟動伺服器的System V風格的系統,停止進程將用一個stop參數調用該指令碼,告訴伺服器終止,當然假定你已安裝了mysql.server。

四、如果你不能串連伺服器,如何重新獲得對伺服器的控制

在某些情況下,你可能由於不能串連它而手工重啟伺服器。當然,這有點矛盾。因為一般你通過串連伺服器而手工關掉它,那麼這種情況如何會出現。

首先,MySQL root口令可以已經設定為你不知道的值,這可能發生在你修改口令時,例如,如果你在輸入新口令時偶然鍵入一個不可見的控制字元。你也可能忘記口令。

其次,串連localhost通常通過一個Unix域通訊端檔案進行,一般是/tmp/mysql.sock。如果通訊端檔案被刪除了,本地客戶就不能串連。這可能發生在你的系統運行一個cron任務刪除了/tmp下的臨時檔案。

如果你因為丟失通訊端檔案而不能串連,你可以簡單地通過重啟伺服器重新建立得到它。因為伺服器在啟動時重新建立它。這裡的騙局是你不能用通訊端建立串連因為它不見了,你必須建立一個TCP/IP串連,例如,如果伺服器主機是pit.snake.net,你可以這樣串連:

%mysqladmin -p -u root -h pit.snake.net shutdown

如果通訊端檔案被一個cron任務刪除,問題將重複出現,除非你修改cron任務或使用一個或使用一個不同的通訊端檔案,你可以使用全域選項檔案指定一個不同的通訊端,例如,如果資料目錄是/usr/local/var,你可以通過將下列行加入/etc/my.cnf中,將通訊端檔案移到那裡:

[mysqld]
socket=/usr/local/var/mysql.sock

[client]
socket=/usr/local/var/mysql.sock
對伺服器和客戶均指定路徑名,使得它們都使用同一個通訊端檔案。如果你只為伺服器設定路徑,客戶程式將仍然期望在原位置執行通訊端,在修改後重啟伺服器,使它在新位置建立通訊端。

如果你由於忘記root口令或已經將它設定為不同於認為的值而不能串連,你需要重新獲得對伺服器的控制,是你能再次設定口令:

中斷伺服器

如果你以root登入伺服器主機,你可以用kill命令終止伺服器。你可以使用ps命令或通過尋找伺服器的PID檔案(通常在資料目錄中)找出伺服器處理序的ID。

最好是首先嘗試用一個向伺服器發出一個TERM訊號的正常kill看它是否將以正常終止應答。這種方式下,表和日誌將正確地被清空。如果伺服器阻塞並且不應答一個正常終止訊號,你可以用kill -9強制終止它。這是最後的手段了,因為這可能有未清空的修改,而且你冒著讓表處於一個不一致狀態的風險。

如果你用kill -9終止伺服器,要確保在啟動伺服器前用myisamchk和isamchk檢查你的表。
用--skip-grant-table選項重啟伺服器。
這告訴伺服器不使用授權表驗證串連,這允許你以root串連而無須口令。在你已經串連後,改變root口令。
用mysqladmin flush-privileges告訴伺服器再次使用授權表啟動
如果你的mysqladmin版本不認識Flash-privileges,試一試reload。

五、運行多個伺服器

大多數再一台給定的機器上運行單個MySQL伺服器,但在很多情況下,運行多個伺服器是很有用的:

你可能想測試一個伺服器的新版本,而保留你正在啟動並執行生產伺服器。在這種情況下,你會運行不同的伺服器代碼。
作業系統一般限制每個進程的開啟檔案控制代碼數量。如果你的系統很難提高這個限制,運行多個伺服器是解決限制的一種方法。在這種情況下,你可能運行統一伺服器的多個執行個體。
ISP經常為其客戶提供自己的MySQL安裝,有必要涉及單獨的伺服器。在這種情況下,你可能運行同一版本的多個執行個體或不同版本,如果不同的客戶想要不同版本的MySQL。
很自然地,運行多個伺服器比只運行一個伺服器要複雜得多。如果你安裝多個版本,你不能在同一個地方安裝所有東西。當伺服器運行時,某些參數必須或很可能對每個伺服器是唯一的,它們包括伺服器在哪安裝、其資料目錄的路徑名、TCP/IP連接埠和UNIX域通訊端路徑名以及用於運行伺服器的UNIX帳號(如果你不再同一帳號下運行所有伺服器)。如果你決定運行多個伺服器,一定要注意你使用的參數,是你不至於。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.