包含linux系統中的mysqld的詞條

本文目錄一覽:

linux怎麼啟動mysqld伺服器

一、以非特權用戶運行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/my.cnf(Unix)或c:\my.cnf(Windows)。

某些種類的信息無法以伺服器選項指定。對於這些你可能需要修改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口令可以已經設置為你不知道的值,這可能發生在你修改口令時,例如,如果你在輸入新口令時偶然鍵入一個不可見的控制字元。你也可能忘記口令。

其次,連接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.1 配置和安裝多個伺服器

如果你要運行不同版本的伺服器而不是同一版本的多個實例,你必須在不同地點安裝它們。如果你安裝二進位分發(不用RPM),它們將安裝在包含不同版本號的目錄名下。如果你從源代碼安裝,最簡單的方法是在每個版本運行configure配置MySQL安裝過程中使用–with-prefix選項使得不同分發分開,這將使得所有東西安裝在一個單獨的目錄下,你可以將目錄域分發版本號聯繫起來,如,你可以象這樣配置一個MySQL分發,其中version是MySQL版本號:

%.configure –with-prefix=/usr/local/mysql-version

–with-prefix選項也決定了伺服器的一個唯一數據目錄。你可能想加上其它伺服器特定的選項,如TCP/IP埠號和套接字路徑名(–with-tcp-port和–with-unix-socket)。

如果你想運行同一版本伺服器的多個實例,任何必須基於一個伺服器特定設置的選項將需要在運行時指定。

5.2 多伺服器的啟動過程

啟動多個伺服器比使用一個伺服器要複雜。因為safe_mysqld和mysql.server均在單個伺服器設置上工作得最好。建議你仔細研究一下safe_mysqld並用它作為你的啟動過程的基礎,使用你修改的版本,你能針對你自己的需要更精確地裁剪它。

你必須處理的一個問題是如何在選項文件(my.cnf)中指定選項。對於多伺服器,你不能對於每個不同的伺服器設置使用/etc/my.cnf,你只能對所有伺服器相同的設置使用該文件。如果伺服器有一個不同的編譯進去的數據目錄位置,你可以在每個伺服器數據目錄中的my.cnf中指定所有伺服器要使用的設置,而使用DATADIR/my.cnf指定伺服器特定的設置,這裡DATADIR以伺服器不同而不同。

另一種指定伺服器選項的方法是用–default-file=path_name作為命令行的第一個選項,告訴伺服器從名為path_name中的文件中讀取選項,這樣你可以把一個伺服器選項放在一個對該伺服器唯一的文件中,然後告訴伺服器在啟動時讀取該文件。注意,如果你指定這個選項,將不使用通常的選項文件如/etc/my.cnf的任何一個。

可以看看。

在linux中,怎樣查看Mysql服務運行狀態?

使用命令 # service mysqld status 命令來查看mysql 的啟動狀態如圖所示: mysqld is stopped 那就說明mysql服務是停止狀態,如果是 mysqld is running 那就說明mysql服務是啟動狀態。

2.使用命令chkconfig –list 命令來查看mysql 的啟動狀態如圖所示:在一下服務中找到mysqld的服務沒如果狀態為off,說明mysql服務沒有啟動。

3.使用命令chkconfig –list mysqld 命令來查看mysql 的啟動狀態如圖所示:在一下服務中找到mysqld的服務沒如果狀態為off,說明mysql服務沒有啟動。

4.使用命令chkconfig –list | grep on 命令來查看mysql 的啟動狀態如圖所示:如果mysql服務已經啟動那麼這裡就會有這個服務。

5.使用命令chkconfig –list | grep off 命令來查看mysql 的啟動狀態如圖所示:如果mysql服務沒有啟動那麼這裡就會有這個服務。

6.使用命令ps aux | grep mysqld 命令來查看mysql 的啟動狀態如圖所示:下圖對比是啟動與不啟動的狀態。

7.使用命令 pidof mysqld 命令來查看mysql 的啟動狀態如圖所示:如果顯示PID說明程序啟動,不顯示PID即為程序沒有啟動。

擴展資料:

linux文件類型:

普通文件(regular file):就是一般存取的文件,由ls -al顯示出來的屬性中,第一個屬性為 [-],例如 [-rwxrwxrwx]。另外,依照文件的內容,又大致可以分為:

1、純文本文件(ASCII):這是Unix系統中最多的一種文件類型,之所以稱為純文本文件,是因為內容可以直接讀到的數據,例如數字、字母等等。設 置文件幾乎都屬於這種文件類型。舉例來說,使用命令「cat ~/.bashrc」就可以看到該文件的內容(cat是將文件內容讀出來)。

2、二進位文件(binary):系統其實僅認識且可以執行二進位文件(binary file)。Linux中的可執行文件(腳本,文本方式的批處理文件不算)就是這種格式的。舉例來說,命令cat就是一個二進位文件。

3、數據格式的文件(data):有些程序在運行過程中,會讀取某些特定格式的文件,那些特定格式的文件可以稱為數據文件(data file)。舉例來說,Linux在用戶登入時,都會將登錄數據記錄在 /var/log/wtmp文件內,該文件是一個數據文件,它能通過last命令讀出來。但使用cat時,會讀出亂碼。因為它是屬於一種特殊格式的文件。

目錄文件(directory):就是目錄,第一個屬性為 [d],例如 [drwxrwxrwx]。

連接文件(link):類似Windows下面的快捷方式。第一個屬性為 [l],例如 [lrwxrwxrwx]。

設備與設備文件(device):與系統外設及存儲等相關的一些文件,通常都集中在 /dev目錄。通常又分為兩種:

塊設備文件:就是存儲數據以供系統存取的介面設備,簡單而言就是硬碟。例如一號硬碟的代碼是 /dev/hda1等文件。第一個屬性為 [b]。

字元設備文件:即串列埠的介面設備,例如鍵盤、滑鼠等等。第一個屬性為 [c]。

套接字(sockets):這類文件通常用在網路數據連接。可以啟動一個程序來監聽客戶端的要求,客戶端就可以通過套接字來進行數據通信。第一個屬性為 [s],最常在 /var/run目錄中看到這種文件類型。

管道(FIFO,pipe):FIFO也是一種特殊的文件類型,它主要的目的是,解決多個程序同時存取一個文件所造成的錯誤。FIFO是first-in-first-out(先進先出)的縮寫。第一個屬性為 [p]。

參考資料:php中文網-linux如何查看mysql是否啟動?

linux下怎麼啟動mysql服務

一、啟動方式

1、使用linux命令service 啟動:

service mysqld start

2、使用 mysqld 腳本啟動:

/etc/inint.d/mysqld start

3、使用 safe_mysqld 啟動:

safe_mysqld    命令使用方法及介紹可如下查找:

linux怎麼啟動mysql服務

1、首先,我們需要修改mysql的配置文件,一般文件存放在/etc下面,文件名為my.cnf。

2、對於mysql服務的啟動,我們通常使用命令service mysqld start,沒問題的話就能啟動mysql服務了。

3、如何判斷mysql服務有沒有啟動成功了,一個是通過查看進程的方式,我們使用命令ps -ef|grep mysqld,來查看。

4、當然,更為穩妥的方法是使用命令mysql -uuser -p passwd 來進行連接,看看是否能接上。

5、如何停止mysql的服務呢。方法也很簡單,使用命令:service mysqld stop命令即可。

6、一般,如果mysql服務沒有啟動成功,可以通過查看錯誤日誌的方式,日誌默認路徑/var/log/mysqld.log,

7、完成效果圖。

linux mysql啟動命令(命令行啟動mysql)

1、linux開啟mysql命令。

2、啟動MySQL的命令。

3、linux啟動mysql。

4、linux中如何啟動mysql。

1.”linux啟動mysql的命令,為您提供linux啟動mysql的命令圖文信息,打開linux系統,在linux的桌面的空白處右擊。

2.在彈出的下拉選項里,點擊打開終端。

3.在啟動之前需要修改mysql的配置文件。

4.修改之後可以使用servicemysqldstart命令來啟動mysql服務。

5.可以使用命令ps-ef|grepmysqld來查看有沒有啟動成功。

linux mysql 的mysqld 在什麼目錄下

MySQL是一個關係型資料庫管理系統,由瑞典MySQL AB 公司開發,目前屬於 Oracle 旗下公司。1.安裝方法有兩種,一種是yum安裝,另外一種是源碼安裝 rpm安裝命令如下 yum install mysql-server -y 2.查看相關路徑的方法如下 [root@rhel5 ~]# find /…

原創文章,作者:DVBZL,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/129156.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
DVBZL的頭像DVBZL
上一篇 2024-10-03 23:26
下一篇 2024-10-03 23:26

相關推薦

  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬碟。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • 如何在樹莓派上安裝Windows 7系統?

    隨著樹莓派的普及,許多用戶想在樹莓派上安裝Windows 7操作系統。 一、準備工作 在開始之前,需要準備以下材料: 1.樹莓派4B一台; 2.一張8GB以上的SD卡; 3.下載並…

    編程 2025-04-29
  • 分銷系統開發搭建

    本文主要介紹如何搭建一套完整的分銷系統,從需求分析、技術選型、開發、部署等方面進行說明。 一、需求分析 在進行分銷系統的開發之前,我們首先需要對系統進行需求分析。一般來說,分銷系統…

    編程 2025-04-29
  • EulerOS V2R7:企業級開發首選系統

    本文將從多個方面為您介紹EulerOS V2R7,包括系統簡介、安全性、易用性、靈活性和應用場景等。 一、系統簡介 EulerOS V2R7是一個華為公司開發的企業級操作系統,該系…

    編程 2025-04-28
  • 雲盤開源系統哪個好?

    本文將會介紹幾種目前主流的雲盤開源系統,從不同方面對它們做出分析比較,以此來確定哪個雲盤開源系統是最適合您的。 一、Seafile Seafile是一款非常出色的雲盤開源系統,它的…

    編程 2025-04-28
  • 基於Python點餐系統的實現

    在當前瞬息萬變的社會,餐飲行業也在加速發展,如何更好地為客戶提供更加便捷、高效、個性化的點餐服務,成為每個餐飲企業需要思考的問題。本文以基於Python的點餐系統為例,通過優化用戶…

    編程 2025-04-28
  • Ubuntu系統激活Python環境

    本文將從以下幾個方面詳細介紹在Ubuntu系統中如何激活Python環境: 一、安裝Python 在Ubuntu系統中默認已經預裝了Python解釋器,可以通過以下命令來檢查: $…

    編程 2025-04-28
  • 如何在Windows系統下載和使用cygwin?

    如果你是一名Windows系統的開發者,你可能會遇到一個問題,那就是缺少Unix/Linux系統下常用的命令行工具,這時候,你可以使用cygwin來解決這個問題。 一、cygwin…

    編程 2025-04-27
  • Python智能測評系統答案解析

    Python智能測評系統是一款用於自動批改Python代碼的工具,它通過較為底層的方法對代碼進行分析,在編譯和執行代碼時自動判斷正確性,從而評估代碼的得分情況。下面將從多個方面對P…

    編程 2025-04-27

發表回復

登錄後才能評論