首頁 >資料庫 >mysql教程 >教你如何啟動和停止Mysql服務之一

教你如何啟動和停止Mysql服務之一

Y2J
Y2J原創
2017-05-23 14:42:092813瀏覽

在討論如何啟動MySQL伺服器之前,讓我們先考慮一下應該以什麼使用者身分執行MySQL伺服器。伺服器可以手動或自動啟動。如果你手動啟動它,伺服器以你登入Unix(Linux)的使用者身分啟動,即如果你用paul登入Unix並啟動伺服器,它用paul運行;如果你用su指令切換到root,然後運啟動伺服器,則它以root運行。然而,大多數情況下你可能不想手動啟動伺服器,最有可能是你安排MySQL伺服器在系統引導時自動啟動,作為標準引導過程的一部分,在Unix下,該引導過程由系統的Unix用戶root執行,並且任何在該過程中運行的進程均以root權限運行。 
    你應該牢記MySQL伺服器啟動過程的兩個目標: 

#    你卻是想要讓伺服器以某個非root使用者運作。一般地,你想限制任何運行進程的能力,除非確實需要root權限,而MySQL不需要。

    你想讓伺服器始終以同一個用戶運行,此時用一個用戶而其他時候以另一個不同的用戶運行伺服器是很不方便的,這造成了為文件和目錄以具有不同屬主的資料目錄下被創建,並可能導致伺服器不能存取資料庫或表,這看你以哪個使用者運行。統一用同一個使用者運行伺服器是你避免這個問題。  

    想要一個普通的非特權使用者來運作伺服器,請依照下列步驟: 

    選擇以使用伺服器的用戶,mysqld可使用任何使用者運作。但在概念上較清晰的是為MySQL操作創建一個單獨的使用者。你也可以特別為MySQL選擇一個使用者群組。本文使用mysqladm和mysqlgrp分別作為使用者名稱和使用者群組名稱。 

    如果你已在自己的帳號下安裝好了MySQL且沒有系統上的特殊管理權限,你將可能在你自己的用戶ID下運行伺服器。在這種情況下,用你自己的登入名稱和使用者群組取代mysqladm和mysqlgrp。 

    如果你在RedHat Linux上以rpm檔案安裝MySQL,此安裝會自動建立名為mysql的帳號,用該帳號取代mysqladm。 

    如果必要,用系統通常的建立使用者的流程建立伺服器帳號,你需要用root來做它。  
    如果伺服器在運行,停止它。  

    修改資料目錄和任何子目錄和檔案的屬主,這使得mysqladm使用者擁有它們。例如,如果資料目錄是/usr/local/var,你可以如下設定mysqladm的屬主(你需要以root執行這些指令): 

    #cd /usr/local/var 
     ##chown -R mysqladm.mysqlgrp 

    修改資料目錄和任何子目錄和檔案的權限,使得它們只能由mysqladm使用者存取。如果資料目錄是/usr/local/var,你可以設定mysqladm擁有的任何東西: 

    # cd /usr/local/var 
    # #chmod## -R rwx       當你設定資料目錄及其內容的屬主與模式時,請注意符號連結。你需要順著它們並改變它們指向的文件或目錄的屬主和模式。如果連接檔案的目錄位於不屬於你的地方,會有些麻煩,你可能需要root身分。

    在你完成了上述過程後,你應該確保總是在以mysqladm或root登入時啟動伺服器,在後者,確定指定--user=mysqladm選項,使伺服器能將其使用者ID切換到mysqladm(同時也適用於系統啟動過程)。 

    --user選項在MySQL 3.22中引入,如果你有舊版本,你可以使用su指令告訴系統在以root運作時在特定的使用者下執行伺服器。 



啟動伺服器的方法 

    在我們確定了用於運作伺服器的帳號後,你可以選擇如何安排啟動伺服器。你可以從命令列手動或在系統引導過程中自動地運行它。對於啟動伺服器由三種主要方法: 

    直接呼叫mysqld。 

    這可能是最不常用的方法,建議不要多使用,因此本文不詳細介紹。  

    呼叫safe_mysqld腳本。 

    safe_mysqld試圖確定伺服器程式和資料目錄的位置。然後用反映這些值的選項呼叫服器。 safe_mysqld將標準出錯設備從伺服器重定位到資料目錄下的一個出錯文件,使得有它的一筆記錄。在啟動伺服器後,safe_mysqld也監視它並且如果它死掉則重啟它。 safe_mysqld常​​用於BSD風格的Unix系統。

  如果你以root或在系統引導期間啟動sqfe_mysqld,出錯日誌由root擁有,這可能在你以後試圖用一個非特權用戶調用safe_mysqld時將導致“permission denied”(權限拒絕)錯誤, 刪除出錯日誌再試一次。  

    呼叫mysql.server腳本。

    這個腳本透過有意用於System V的啟動和停止系統上的safe_mysqld.mysql.server來啟動伺服器,該系統包含幾個包含在機器進入或退出一個給定運行等級時被點用的腳本目錄。它可以用一個start或stop參數點用以表示你是想啟動還是想停止伺服器。  

    safe_mysqld腳本安裝在MySQL安裝目錄的bin目錄下,或可在MySQL原始碼分發的scripts目錄下找到。 mysql.server腳本安裝在MySQL安裝目錄下的share/mysqld目錄下或可以在MySQL原始碼分發的support_files目錄下找到。如果你想使用它們,你需要將它們拷貝到適當的目錄下。

    對BSD風格的系統(FreeBSD,OpenBSD等),通常在/etc目錄下有幾個檔案在引導時初始化服務,這些檔案通常有以「rc」開頭的名字,且它有可能由一個名為“rc.local”的檔案(或類似​​的東西),特意用於啟動本地安裝的服務。在這樣的系統上,你可能將類似於下列的行加入rc.local檔案中以啟動伺服器(如果safe_mysqld的目錄在你的系統上不同,修改它即可): 

    ## if [ -x /usr/local/bin/safe_mysqld ]; then 
    /usr/local/bin/safe_mysqld &  ##卷 .server放在/etc下適當的啟動目錄下來安裝它。如果你執行Linux並從一個RPM檔案安裝MySQL,這些已經為你做好了,否則將腳本安裝在主啟動目錄下,並將指向它的連線放在適當的運行等級目錄下。你也可以使腳本只能由root啟動。  

    啟動檔案的目錄佈局各系統不同,所以你需要檢查一下看看你的系統如何組織它們。例如在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/rcln.d-d/rc .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  ###   #chmod 500 my ln -s ../init.d/mysql.server S99mysql  ###    在系統啟動時,S99mysql腳本會自動以一個start參數呼叫。如果你有chkconfig指令(Linux上有),你可以用它來幫助安裝mysql.server腳本而不是像上面那樣手動執行上述指令。  ######    指定啟動選項  ######    如果你想在伺服器啟動時指定額外的啟動選項,你可有兩種方法。你可以修改你使用的啟動腳本(safe_mysqld或mysql.server)並直接在呼叫伺服器的行上指定選項,或在一個選項檔中指定選項。建議你如果可能在一個全域選項檔案中指定選項,它通常位於/etc/my.cnf(Unix)或c:my.cnf(Windows)。  ###
    某些種類的資訊無法以伺服器選項指定。對於這些你可能需要修改safe_mysqld。例如,如果你的伺服器不能正確選擇本地時區而以GMT傳回時間值,你可以設定TZ環境變數給它一個指示。如果你用safe_mysqld或mysql.server啟動伺服器,你可以將一個時區設定加到safe_mysqld。找到啟動伺服器的行並在該行前加入下列指令: 

    TZ=US/Central 
    export TZ 

    上面指令的語法是Solaris,對於其他系統語法可能的,對於其他系統語法可能的,對於其他系統語法可能的,對於其他系統語法可能的方法,請查閱相關手冊。如果你確實修改了你的啟動腳本,要記住下次你安裝MySQL時(如昇級到新版本),你的修改將會失去,除非你先在別處複製了啟動腳本。在安裝了新版本後,比較新舊版本的腳本,看看你需要重建什麼改變。 

    在啟動時檢查你的表格 

    除了安排你的伺服器在系統引導時啟動,你可能要安裝myisamchk和isamchk腳本,以便在伺服器啟動前檢查你的表。你可能在一個崩潰後重啟,有可能表已經損害,在啟動前檢查它是一個發現問題的好方法。

以上是教你如何啟動和停止Mysql服務之一的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn