久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

如何啟動和關閉MySQL服務器

155次閱讀
沒有評論

共計 4365 個字符,預計需要花費 11 分鐘才能閱讀完成。

這篇文章主要講解了“如何啟動和關閉 MySQL 服務器”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學習“如何啟動和關閉 MySQL 服務器”吧!

作為 MySQL 管理員,一個普通的目標就是確保服務器盡可能地處于運行狀態,使得客戶機能夠隨時訪問它。但是,有時最好關閉服務器(例如,如果正在進行數據庫的重定位,不希望服務器在該數據庫中更新表)。保持服務器運行和偶爾關閉它的需求關系不是本文所解決的。但是我們至少可以討論如何使服務器啟動和停止,以便您具備進行這兩個操作的能力。

本章的說明只用于 UNIX 系統。

調用本章給出的命令

為了簡潔,在大多數情況中,諸如 mysqla d m i n、mysqldump 等程序在本章中沒有給出任何 - h、- u 或 - p 選項。筆者假定您將會用連接服務器所需的任何選項調用這些程序。

用無特權的用戶賬號運行 MySQL 服務器

在討論如何啟動服務器之前,考慮一下在服務器啟動時應該運行哪個賬號。服務器可以手工和自動啟動。如果手工啟動,則服務器以 UNIX 用戶身份運行(您恰好作為該用戶進行了注冊)。即,如果筆者以 paul 進行注冊并啟動服務器,則它將以 paul 身份運行。如果用 s u 命令將用戶切換到 root 然后啟動服務器,則服務器以 root 身份運行。

但是,大多數時候可能都不會采用手工啟動服務器。您很可能將安排服務器在系統引導時作為標準啟動過程的一部分自動地運行。在 UNIX 中,該啟動過程由系統以 UNIX 的 r o o t 用戶的身份執行,該過程中啟動的任何進程都用 root 的權限運行。

應該緊記 MySQL 服務器啟動過程的兩個目標:

要服務器以某些非 root 的用戶身份啟動。通常,除非進程真的需要 root 訪問權而 mysql 辦不到,否則應限制任何進程的能力。

要服務器始終以同一個用戶的身份運行。服務器有時作為一個用戶運行而有時又作為另一個用戶運行時會產生矛盾。這將導致文件和目錄以不同的所有權在該數據下被創建,甚至引起服務器不能訪問數據庫或表。以同一個用戶的身份一致地運行服務器可以避免該問題。

為了以標準的、非特權的用戶身份運行數據庫,可按如下步驟執行該過程:

1) 選擇用于運行服務器的賬號。mysqld 可以以任何用戶身份運行,但是很明顯,它只為 MySQL 活動創建了一個單獨的賬號。您也可以為 MySQL 專門指定一個組。筆者將調用的這些用戶和組的名字命名為 mysqladm 和 mysqlg r p。如果您使用了其他的名字,則在本書中有 mysqladm 和 mysqlgrp 的地方替換它們

如果您在自己的賬號下安裝了 MySQL 并且系統中沒有特定的管理權限,則您可以在自己的 ID 用戶下運行服務器。在這種情況下,應使用您自己的注冊名和組名替代 mysqladm 和 mysqlgrp。

如果您利用 RPM 文件在 RedHat   下安裝了 MySQL,則該安裝程序將在名下自動創建了一個賬號。應使用該名字替換 mysqladm。

2) 如果必要的話,可用系統常用的賬號創建過程 (a c count – c r e a t i o n) 來創建服務器賬號。這需要以 root 身份進行操作。

3) 關閉服務器(如果它在運行)。

4) 修改數據目錄以及任何子目錄和文件的所有權,使 mysqladm 用戶擁有它們。例如,如果數據目錄是 / us r / l o c a l / v a r,則可按以下設置 mysqladm 用戶的所有權:

# cd /usr/local/var 移動到數據目錄

# chown -r mysqladmin.mysqlgrp 設置所有目錄和文件的所有權

5) 修改數據目錄以及任何子目錄和文件的許可權,使得只有 mysqladm 用戶能夠訪問它們。設置該方式以避免其他人員訪問是一種好得安全預防措施。如果數據目錄是 / us r / l o c a l / v a r,則可通過 mysqladm 用戶按下列操作設置應具有的一切(您需要以 root 身份運行這些命令):

# cd /usr/local/var 移動到數據目錄

# chmod -R go -rwx 使所有一切只對 mysqladm 可訪問

在設置數據目錄及其內容的所有權和方式時,觀察符號連接。您需要跟蹤符號連接并修改所指向的文件或目錄的所有權和方式。如果這些連接文件所定位的目錄不屬于您,則這樣做可能會引起麻煩,因此您必須是 root 用戶。

在完成前述過程后,應確保無論是作為 mysqladm 還是作為 root 用戶注冊都始終啟動服務器。在后者中,要確保指定了 –user = mysqladm 的選項,使服務器可以將其用戶 ID 切換到 mysqla d m(該選項在系統啟動過程中也可使用)。

–user 選項被增加到 MySQL3.22 的 mysql 中。如果您的版本比 MySQL3.22 舊,則在啟動服務器并作為 root 用戶運行時,可以使用 su 命令指示系統在指定賬號下運行服務器。您需要閱讀有關 su 的人工頁,因為作為一個指定用戶運行命令的語法被改變了。
啟動服務器的方法

如果您已經確定了用來運行服務器的賬號,則可以選擇安排怎樣啟動服務器。可以從命令行手工運行,或在系統啟動過程中自動運行服務器。有三種啟動服務器的主要方法:

直接調用 mysqld。這或許是最小的命令方法。除了說明 mysqld –help 是一個有用的命令 (用它可以查找您可利用其他啟動方法使用的選項) 外,筆者不打算進一步討論它。

調用 safe_mysqld 腳本。safe_mysqld 試圖確定服務器程序和數據目錄的位置,然后利用反映這些位置的選項調用服務器。safe_mysqld 將服務器的標準錯誤輸出重定向到數據目錄的錯誤文件中,并以記錄的形式出現。在啟動服務器后,safe_mysqld 還監控服務器,并在其死機時重新啟動。safe_mysqld 通常用于 UNIX 的 BSD 風格的版本。

如果您曾經作為 root 或在系統啟動程序中啟動 s a f e _ mysqld,則錯誤日志將由 r o o t 擁有。如果您試著以非特權的用戶身份調用 s a f e _ mysqld,則可能引起“所有權被拒絕”的錯誤。刪除該錯誤文件再試一次。

調用 mysql.server 腳本。通過運行 s a f e _ mysqld . mysql. server,該腳本啟動服務器。該腳本建議在使用 System V 啟動 / 關閉系統的系統中使用。這個系統包括幾個包含在機器登錄或退出一個特定運行級時被調用的腳本的目錄。它可以利用 start 或 stop 參數進行調用,以指明希望啟動還是關閉服務器。

safe_mysqld 腳本被安裝在 MySQL 安裝目錄的 bin 目錄下,或者在 MySQL 源程序分發包的 scripts 目錄中。mysql.server 腳本安裝在 MySQL 安裝目錄的 s h a r e / mysql 目錄下,或者在 MySQL 源程序分發包的 support-files 目錄中。如果要使用它,應將其拷貝到合適的啟動目錄中。

對于 BSD 風格的系統,在 /etc 目錄中有幾個文件相對應,它們在引導期間開始服務。這些文件的名字通常以‘r c’開始,因此很可能會有一個名為 rc.local (或類似的名字)的文件來啟動本地的安裝服務。在這樣的系統中,您可能要按如下方法添加一些行到 rc.local 文件中以啟動服務器(如果路徑與您系統中的不同,可將其修改成 s a f e _ mysqld):

if (-x /usr/local/bin/safe_mysqld);then
/usr/local/bin/safe_mysqld
fi

對于 System V 風格的系統,可以通過將其放置在 /etc 下的合適的啟動目錄中來安裝 mysql. server。如果您運行 Linux 并從 RPM 文件中安裝了 MySQL,那么這此操作可能已經完成了。否則,應該在主啟動腳本目錄中安裝該腳本,并在合適的運行級目錄中設置對它的連接。您還可使該腳本僅對 root 用戶可執行。

啟動文件目錄的布局隨系統而變化,因此將需要全面檢查來弄清系統是怎樣組織它們的。例如,在 LinuxPPC 中,這些目錄為 /etc/rc.d/init.d 和 / e t c / r c . d / r c 3 . d。應該按如下方法安裝該腳本:

  # cp mysql.server /etc/rc.d/init.d
# cd /etc/init.d
# chmod 500 mysql.server
# cd /etc/rc.d/rc3.d
# In -s ../init.d/mysql.server S99mysql 在 Solaris 中,主腳本目錄為 / e t c / i n i t . d,運行級目錄為 / e t c / r c 2 . d,因此上述命令將替換為:
#cp mysql.server /etc/init.d
# cd /etc/init.d
# chmod 500 mysql.server
# cd /etc/rc2.d
# In -s ../init.d/mysql.server s99mysql 在系統啟動期間,S99mysql 腳本利用 start 參數自動調用。

如果您擁有 chkconfig 命令(它在 Linux 中很常用),則可用其幫助安裝 mysql.server 腳本來代替手工運行上述的命令。

1. 指定啟動選項

在啟動服務器時,如果想要指定附加的啟動選項,可用兩種方法進行操作。您可以修改所使用的啟動腳本(safe_mysqld 或 mysql. server),并在調用服務器的命令行中直接指定這些選項。您還可以在選項文件中指定選項。筆者建議,如果可能的話,應在全局選項文件中指定服務器選項。通常該文件的位置是 UNIX 中的 / e t c / my.cnf 和 Windows 中的 c:my.cnf(有關使用選項文件的細節,請參閱附錄 E)。

某些種類的信息不能作為服務器的選項指定。為了這些選項,您可能需要修改 s a f e _ mysqld。例如,如果服務器不能正確地拾取 GMT 中的本地時區 (local time zone) 和返回時間值,可以設置 TZ 環境變量以給該變量一個提示。如果用 safe_mysqld 或 mysql. ser ver 啟動服務器,可以將時區設置增加到 safe_mysqld 中。找到啟動服務器的命令行,并在該行之前增加下列命令:

TZ=US/Central
export TZ

這個命令將 TZ 設置為 US Central 時區。您需要使用合適位置的時區。該語法是 S o l a r i s 的,您的系統可能會有所不同。例如,設置 TZ 變量的另一個常用語法為:

TZ=CST6CDT
export TZ

如果修改了啟動腳本,當下次安裝 MySQL 時(如,升級到更新的版本),將失去這些修改,除非在之前將該啟動腳本拷貝到了其他地方。在安裝新的版本之后,將您的腳本與新安裝的腳本進行比較,以便看看重新建立還需要做什么改動。

感謝各位的閱讀,以上就是“如何啟動和關閉 MySQL 服務器”的內容了,經過本文的學習后,相信大家對如何啟動和關閉 MySQL 服務器這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關知識點的文章,歡迎關注!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-08-01發表,共計4365字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 金乡县| 永清县| 宣武区| 盐源县| 平武县| 永州市| 博野县| 吴忠市| 江山市| 全椒县| 利津县| 宁武县| 五华县| 多伦县| 桑日县| 庄河市| 海丰县| 宜良县| 永昌县| 铁岭县| 兴国县| 揭东县| 兰考县| 洪湖市| 麻城市| 始兴县| 浦北县| 邳州市| 丰镇市| 丹寨县| 阳江市| 盖州市| 城步| 黑水县| 丹江口市| 甘孜| 铜陵市| 杭锦旗| 昌邑市| 彝良县| 浦江县|