linux下MySQL伺服器的啟動與停止工作

2021-03-04 09:46:03 字數 4744 閱讀 8911

**:網際網路作者:佚名時間:09-08 17:06:46 【大中小】 點評:

一、以非特權使用者執行mysql伺服器在討論如何啟動mysql伺服器之前,讓我們考慮一下應該以什麼使用者身份執行mysql伺服器。伺服器可以手動或自動啟動。如果你手動啟動它,伺服器以你登入unix(linux)的使用者身份啟動,即如果你用paul登入unix並啟動伺服器,它用paul執行;-

一、以非特權使用者執行mysql伺服器

在討論如何啟動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 go-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 &

fi對於對於system v風格的系統,你可以通過將mysql.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/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在系統啟動時,s99mysql指令碼將自動用乙個start引數呼叫。如果你有chkconfig命令(linux上有),你可以由它幫助安裝mysql.server指令碼而不是象上面那樣手工執行上述命令。

2.1 指定啟動選項

如果你想在伺服器啟動時指定額外的啟動選項,你可有兩種方法。你可以修改你使用的啟動指令碼(safe_mysqld或mysql.server)並直接在呼叫伺服器的行上指定選項,或在乙個選項檔案中指定選項。

建議你如果可能在乙個全域性選項檔案中指定選項,它通常位於/etc/或c:\

某些種類的資訊無法以伺服器選項指定。對於這些你可能需要修改safe_mysqld。例如,如果你的伺服器不能正確選擇本地時區而以gmt返回時間值,你可以設定tz環境變數給它乙個指示。

如果你用safe_mysqld或mysql.server啟動伺服器,你可以將乙個時區設定加到safe_mysqld。找到啟動伺服器的行並在該行前加入下列命令:

tz=us/central

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

2.2 在啟動時檢查你的表

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

三、停止伺服器

要手工啟動伺服器,使用mysqladmin:

%mysqladmin shutdown

要自動停止伺服器,你不需做特別的事情。bsd系統一般通過向程序發乙個term訊號停止服務,它們或者正確應答它或被粗魯地殺死。mysqld在它收到這個訊號時以終止作為應答。

對於用mysql.server啟動伺服器的system v風格的系統,停止程序將用乙個stop引數呼叫該指令碼,告訴伺服器終止,當然假定你已安裝了mysql.server。

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

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

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

Linux1 DNS伺服器構建從網域名稱伺服器

從網域名稱伺服器作為主網域名稱伺服器的冗餘備份,可以與主網域名稱伺服器一起,同時提供本域內計算機名到ip位址的解析,從網域名稱伺服器的位址資料庫需要從主網域名稱伺服器中定期更新。從網域名稱伺服器的主配置檔案也是 etc 也需要設定伺服器的 options 主語句和根區域,方法與配置主網域名稱伺服器的...

linux下mysql命令大全

如增加乙個使用者test密碼為123,讓他可以在任何主機上登入,並對所有資料庫有查詢 插入 修改 刪除的許可權。首先用以root使用者連入mysql,然後鍵入以下命令 grantselect,insert,update,delete on to identified by 123 7.跳過授權訪問m...

Linux伺服器儲存空間巧妙管理

對於linux使用者而言,在安裝一台linux機器的時候,遇到的問題之一就是給各分割槽估計和分派足夠的硬碟空間。無論對乙個正在為伺服器尋找空間的系統管理員,還是乙個磁碟即將用盡的普通使用者來說,這都是乙個非常常見的問題。一般我們會想到解決的方法是 1.掛接乙個新的硬碟,然後使用符號鏈結,鏈結到新的硬...