狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频

當前位置:系統(tǒng)之家 > 技術開發(fā)教程 > 詳細頁面

MySQL服務器的打開與停止

MySQL服務器的打開與停止

更新時間:2024-04-12 文章作者:未知 信息來源:網絡 閱讀次數:

MySQL服務器的啟動與停止


[晏子]

一、以非特權用戶運行MySQL服務器


在討論如何啟動MySQL服務器之前,讓我們考慮一下應該以什么用戶身份運行MySQL服務器。服務器可以手動或自動啟動。如果你手動啟動它,服務器以你登錄Unix(Linux)的用戶身份啟動,即如果你用paul登錄Unix并啟動服務器,它用paul運行;如果你用su命令切換到root,然后運啟動服務器,則它以root運行。然而,大多數情況下你可能不想手動啟動服務器,最有可能是你安排MySQL服務器在系統(tǒng)引導時自動啟動,作為標準引導過程的一部分,在Unix下,該引導過程由系統(tǒng)的Unix用戶root執(zhí)行,并且任何在該過程中運行的進程均以root權限運行。
你應該牢記MySQL服務器啟動過程的兩個目標:
  • 你想讓服務器以某個非root用戶運行。一般地,你想限制任何運行進程的能力,除非確實需要root權限,而MySQL不需要。
  • 你想讓服務器始終以同一個用戶運行,此時用一個用戶而其他時候以另一個不同的用戶運行服務器是很不方便的,這造成了為文件和目錄以具有不同屬主的數據目錄下被創(chuàng)建,并可能導致服務器不能訪問數據庫或表,這看你以哪個用戶運行。統(tǒng)一用同一個用戶運行服務器是你避免這個問題。

要一個普通的非特權用戶運行服務器,按照下列步驟:
  1. 選擇一個用于運行服務器的用戶,mysqld可以用任何用戶運行。但在概念上較清晰的是為MySQL操作創(chuàng)建一個單獨的用戶。你也可以特別為MySQL選擇一個用戶組。本文使用mysqladm和mysqlgrp分別作為用戶名和用戶組名。
    如果你已在自己的賬號下安裝好了MySQL且沒有系統(tǒng)上的特殊管理權限,你將可能在你自己的用戶ID下運行服務器。在這種情況下,用你自己的登錄名和用戶組代替mysqladm和mysqlgrp。
    如果你在RedHat Linux上用rpm文件安裝MySQL,該安裝將自動創(chuàng)建一個名為mysql的賬號,用該賬號代替mysqladm。
  2. 如果必要,用系統(tǒng)通常的創(chuàng)建用戶的過程創(chuàng)建服務器賬號,你需要用root做它。
  3. 如果服務器在運行,停止它。
  4. 修改數據目錄和任何子目錄和文件的屬主,這樣使得mysqladm用戶擁有它們。例如,如果數據目錄是/usr/local/var,你可以如下設置mysqladm的屬主(你需要以root運行這些命令):

    #cd /usr/local/var
    #chown -R mysqladm.mysqlgrp
  5. 修改數據目錄和任何子目錄和文件的權限,使得它們只能由mysqladm用戶訪問。如果數據目錄是/usr/local/var,你可以設置由mysqladm擁有的任何東西:

    # cd /usr/local/var
    # chmod -R go-rwx

當你設置數據目錄及其內容的屬主和模式時,注意符號連接。你需要順著它們并改變它們指向的文件或目錄的屬主和模式。如果連接文件的目錄位于不屬于你的地方,會有些麻煩,你可能需要root身份。
在你完成了上述過程后,你應該確保總是在以mysqladm或root登錄時啟動服務器,在后者,確定指定--user=mysqladm選項,使服務器能將其用戶ID切換到mysqladm(同時也適用于系統(tǒng)啟動過程)。
--user選項在MySQL 3.22中引入,如果你有老版本,你可以使用su命令告訴系統(tǒng)在以root運行時在特定的用戶下運行服務器。

二、啟動服務器的方法


在我們確定了用于運行服務器的賬號后,你可以選擇如何安排啟動服務器。你可以從命令行手動或在系統(tǒng)引導過程中自動地運行它。對于啟動服務器由三種主要方法:
  • 直接調用mysqld。
    這可能是最不常用的方法,建議不要多使用,因此本文不詳細介紹。
  • 調用safe_mysqld腳本。
    safe_mysqld試圖確定服務器程序和數據目錄的位置。然后用反映這些值的選項調用服務器。safe_mysqld將標準出錯設備從服務器重定位到數據目錄下的一個出錯文件,使得有它的一條記錄。在啟動服務器后,safe_mysqld也監(jiān)視它并且如果它死掉則重啟它。safe_mysqld常用于BSD風格的Unix系統(tǒng)。
    如果你以root或在系統(tǒng)引導期間啟動sqfe_mysqld,出錯日志由root擁有,這可能在你以后試圖用一個非特權用戶調用safe_mysqld時將導致“permission denied”(權限拒絕)錯誤,刪除出錯日志再試一下。
  • 調用mysql.server腳本。
    這個腳本通過有意用于System V的啟動和停止系統(tǒng)上的safe_mysqld.mysql.server來啟動服務器,該系統(tǒng)包含幾個包含在機器進入或退出一個給定運行級別時被點用的腳本目錄。它可以用一個start或stop參數點用以表明你是想啟動還是想停止服務器。

safe_mysqld腳本安裝在MySQL安裝目錄的bin目錄下,或可在MySQL源代碼分發(fā)的scripts目錄下找到。mysql.server腳本安裝在MySQL安裝目錄下的share/mysqld目錄下或可以在MySQL源代碼分發(fā)的support_files目錄下找到。如果你想使用它們,你需要將它們拷貝到適當的目錄下。
對BSD風格的系統(tǒng)(FreeBSD,OpenBSD等),通常在/etc目錄下有幾個文件在引導時初始化服務,這些文件通常有以“rc”開頭的名字,且它有可能由一個名為“rc.local”的文件(或類似的東西),特意用于啟動本地安裝的服務。在這樣的系統(tǒng)上,你可能將類似于下列的行加入rc.local文件中以啟動服務器(如果safe_mysqld的目錄在你的系統(tǒng)上不同,修改它即可):
if [ -x /usr/local/bin/safe_mysqld ]; then/usr/local/bin/safe_mysqld &fi

對于對于System V風格的系統(tǒng),你可以通過將mysql.server放在/etc下適當的啟動目錄下來安裝它。如果你運行Linux并從一個RPM文件安裝MySQL,這些已經為你做好了,否則將腳本安裝在主啟動目錄下,并將指向它的連接放在適當的運行級別目錄下。你也可以使腳本只能由root啟動。
啟動文件的目錄布局各系統(tǒng)不同,所以你需要檢查一下看看你的系統(tǒng)如何組織它們。例如在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

在系統(tǒng)啟動時,S99mysql腳本將自動用一個start參數調用。如果你有chkconfig命令(Linux上有),你可以由它幫助安裝mysql.server腳本而不是象上面那樣手工運行上述命令。

2.1 指定啟動選項


如果你想在服務器啟動時指定額外的啟動選項,你可有兩種方法。你可以修改你使用的啟動腳本(safe_mysqld或mysql.server)并直接在調用服務器的行上指定選項,或在一個選項文件中指定選項。建議你如果可能在一個全局選項文件中指定選項,它通常位于/etc/my.cnf(Unix)或c:\my.cnf(Windows)。
某些種類的信息無法以服務器選項指定。對于這些你可能需要修改safe_mysqld。例如,如果你的服務器不能正確選擇本地時區(qū)而以GMT返回時間值,你可以設置TZ環(huán)境變量給它一個指示。如果你用safe_mysqld或mysql.server啟動服務器,你可以將一個時區(qū)設置加到safe_mysqld。找到啟動服務器的行并在該行前加入下列命令:
TZ=US/Centralexport TZ

上面命令的語法是Solaris的,對于其他系統(tǒng)語法可能不同,請查閱相關手冊。如果你確實修改了你的啟動腳本,要記住下次你安裝MySQL時(如升級到新版本),你的修改將失去,除非你首先在別處復制了啟動腳本。在安裝了新版本后,比較新舊版本的腳本,看看你需要重建什么改變。

2.2 在啟動時檢查你的表


除了安排你的服務器在系統(tǒng)引導時啟動,你可能要安裝myisamchk和isamchk腳本,以在服務器啟動前檢查你的表。你可能在一個崩潰后重啟,有可能表已經損害,在啟動前檢查它是一個發(fā)現(xiàn)問題的好方法。

三、停止服務器


要手工啟動服務器,使用mysqladmin:
%mysqladmin shutdown
要自動停止服務器,你不需做特別的事情。BSD系統(tǒng)一般通過向進程發(fā)一個TERM信號停止服務,它們或者正確應答它或被粗魯地殺死。mysqld在它收到這個信號時以終止作為應答。對于用mysql.server啟動服務器的System V風格的系統(tǒng),停止進程將用一個stop參數調用該腳本,告訴服務器終止,當然假定你已安裝了mysql.server。

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


在某些情況下,你可能由于不能連接它而手工重啟服務器。當然,這有點矛盾。因為一般你通過連接服務器而手工關掉它,那么這種情況如何會出現(xiàn)。
首先,MySQL root口令可以已經設置為你不知道的值,這可能發(fā)生在你修改口令時,例如,如果你在輸入新口令時偶然鍵入一個不可見的控制字符。你也可能忘記口令。
其次,連接localhost通常通過一個Unix域套接字文件進行,一般是/tmp/mysql.sock。如果套接字文件被刪除了,本地客戶就不能連接。這可能發(fā)生在你的系統(tǒng)運行一個cron任務刪除了/tmp下的臨時文件。
如果你因為丟失套接字文件而不能連接,你可以簡單地通過重啟服務器重新創(chuàng)建得到它。因為服務器在啟動時重新創(chuàng)建它。這里的騙局是你不能用套接字建立連接因為它不見了,你必須建立一個TCP/IP連接,例如,如果服務器主機是pit.snake.net,你可以這樣連接:
%mysqladmin -p -u root -h pit.snake.net shutdown
如果套接字文件被一個cron任務刪除,問題將重復出現(xiàn),除非你修改cron任務或使用一個或使用一個不同的套接字文件,你可以使用全局選項文件指定一個不同的套接字,例如,如果數據目錄是/usr/local/var,你可以通過將下列行加入/etc/my.cnf中,將套接字文件移到那里:
[mysqld]socket=/usr/local/var/mysql.sock[client]socket=/usr/local/var/mysql.sock

對服務器和客戶均指定路徑名,使得它們都使用同一個套接字文件。如果你只為服務器設置路徑,客戶程序將仍然期望在原位置執(zhí)行套接字,在修改后重啟服務器,使它在新位置創(chuàng)建套接字。
如果你由于忘記root口令或已經將它設置為不同于認為的值而不能連接,你需要重新獲得對服務器的控制,是你能再次設置口令:
  • 中斷服務器
    如果你以root登錄服務器主機,你可以用kill命令終止服務器。你可以使用ps命令或通過尋找服務器的PID文件(通常在數據目錄中)找出服務器進程的ID。
    最好是首先嘗試用一個向服務器發(fā)出一個TERM信號的正常kill看它是否將以正常終止應答。這種方式下,表和日志將正確地被清空。如果服務器阻塞并且不應答一個正常終止信號,你可以用kill -9強制終止它。這是最后的手段了,因為這可能有未清空的修改,而且你冒著讓表處于一個不一致狀態(tài)的風險。
    如果你用kill -9終止服務器,要確保在啟動服務器前用myisamchk和isamchk檢查你的表。
  • 用--skip-grant-table選項重啟服務器。
    這告訴服務器不使用授權表驗證連接,這允許你以root連接而無須口令。在你已經連接后,改變root口令。
  • 用mysqladmin flush-privileges告訴服務器再次使用授權表啟動
    如果你的mysqladmin版本不認識flash-privileges,試一試reload。

五、運行多個服務器


大多數再一臺給定的機器上運行單個MySQL服務器,但在很多情況下,運行多個服務器是很有用的:
  • 你可能想測試一個服務器的新版本,而保留你正在運行的生產服務器。在這種情況下,你會運行不同的服務器代碼。
  • 操作系統(tǒng)一般限制每個進程的打開文件句柄數量。如果你的系統(tǒng)很難提高這個限制,運行多個服務器是解決限制的一種方法。在這種情況下,你可能運行統(tǒng)一服務器的多個實例。
  • ISP經常為其客戶提供自己的MySQL安裝,有必要涉及單獨的服務器。在這種情況下,你可能運行同一版本的多個實例或不同版本,如果不同的客戶想要不同版本的MySQL。

很自然地,運行多個服務器比只運行一個服務器要復雜得多。如果你安裝多個版本,你不能在同一個地方安裝所有東西。當服務器運行時,某些參數必須或很可能對每個服務器是唯一的,它們包括服務器在哪安裝、其數據目錄的路徑名、TCP/IP端口和UNIX域套接字路徑名以及用于運行服務器的UNIX賬號(如果你不再同一賬號下運行所有服務器)。如果你決定運行多個服務器,一定要注意你使用的參數,是你不至于丟失對所發(fā)生的事情的蹤跡。

5.1 配置和安裝多個服務器


如果你要運行不同版本的服務器而不是同一版本的多個實例,你必須在不同地點安裝它們。如果你安裝二進制分發(fā)(不用RPM),它們將安裝在包含不同版本號的目錄名下。如果你從源代碼安裝,最簡單的方法是在每個版本運行configure配置MySQL安裝過程中使用--with-prefix選項使得不同分發(fā)分開,這將使得所有東西安裝在一個單獨的目錄下,你可以將目錄域分發(fā)版本號聯(lián)系起來,如,你可以象這樣配置一個MySQL分發(fā),其中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的任何一個。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統(tǒng)下載排行

狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频
欧美日韩在线播放一区| 136国产福利精品导航| 国产日韩欧美高清免费| 欧美精品偷拍| 91香蕉视频在线| av在线不卡免费看| 9色porny自拍视频一区二区| 不卡影院免费观看| 91蝌蚪porny九色| 欧美视频观看一区| 亚洲大胆视频| 一区二区三区精品国产| 国产精品久久久久久模特| 亚洲专区免费| 91久久一区二区| 91成人免费在线视频| 制服丝袜亚洲色图| 日韩午夜激情av| 26uuu精品一区二区三区四区在线| 精品捆绑美女sm三区| 国产免费观看久久| 国产精品国产三级国产aⅴ原创| 亚洲欧美日本韩国| 亚洲6080在线| 精品一区二区三区在线观看国产 | 亚洲人成网站精品片在线观看| 亚洲欧美视频在线观看| 天天av天天翘天天综合网| 经典一区二区三区| 91亚洲永久精品| 国产色综合网| 欧美日韩一区二区三区四区| 日韩三级高清在线| 国产精品久久久久四虎| 日韩黄色一级片| 国产·精品毛片| 国产一区在线免费观看| 一本大道久久a久久精品综合| 91精品国产欧美日韩| 一区二区三区小说| 麻豆一区二区三| 91香蕉视频污在线| 午夜在线视频一区二区区别 | 蜜臀久久久久久久| 91小视频免费看| 美女网站久久| 久久亚洲免费视频| 五月天久久比比资源色| www.久久精品| 久久久99爱| 久久久久久久精| 日韩av电影免费观看高清完整版在线观看 | 亚洲同性gay激情无套| 五月天视频一区| 99riav久久精品riav| 久久男女视频| 国产欧美综合在线| 九九精品一区二区| 精品成人国产| 日韩欧美高清dvd碟片| 一区二区三区在线视频观看| 处破女av一区二区| 久久影院亚洲| 亚洲国产精品成人久久综合一区| 丝袜美腿高跟呻吟高潮一区| 欧美激情第8页| 在线播放视频一区| 亚洲国产成人av网| 欧美人与禽性xxxxx杂性| 91.成人天堂一区| 五月天亚洲精品| 99精品视频免费| 久久品道一品道久久精品| 久久99精品视频| 亚洲一区二区在线看| 中国av一区二区三区| 国产不卡在线一区| 欧洲在线/亚洲| 亚洲黄色小视频| 欧美日韩三级| 久久嫩草精品久久久久| 国产精品一品视频| 在线欧美日韩精品| 亚洲成av人片一区二区三区| 亚洲精品女人| 国产精品二三区| 国产精品啊啊啊| 久久久av毛片精品| 成人免费毛片片v| 69成人精品免费视频| 免费成人在线播放| 一本大道久久精品懂色aⅴ| 亚洲一区二区三区三| 一本一本a久久| 亚洲欧美另类久久久精品2019| 欧美视频网站| 国产精品久久久久婷婷| 国产精品国码视频| 国产精品久久久久影院老司| 欧美日一区二区在线观看| 国产人成一区二区三区影院| 91在线高清观看| 欧美激情一区二区三区不卡| 你懂的国产精品| 国产精品全国免费观看高清| 久久精品系列| 日韩精品乱码av一区二区| 久久三级福利| 男人的天堂亚洲一区| 在线亚洲免费视频| 视频一区中文字幕国产| 在线观看www91| 国内久久精品视频| 日韩手机在线导航| 成人黄色电影在线| 国产目拍亚洲精品99久久精品| 欧美人成在线| 亚洲成人av一区二区三区| 在线亚洲欧美专区二区| 国产寡妇亲子伦一区二区| 久久综合久久鬼色中文字| 欧美日韩第一区| 一区二区成人在线| 色94色欧美sute亚洲13| 国产乱人伦偷精品视频不卡| 精品国产123| 亚洲国内欧美| 日日摸夜夜添夜夜添国产精品 | 最新国产の精品合集bt伙计| 国产精品美女| 国产原创一区二区三区| 久久蜜桃av一区二区天堂| 亚洲大黄网站| 老鸭窝一区二区久久精品| 欧美sm美女调教| 亚洲欧洲日本国产| 九色|91porny| 国产欧美视频一区二区| 先锋亚洲精品| 成人污污视频在线观看| 亚洲欧美一区二区三区久本道91| 久久综合给合久久狠狠色| 成人av免费在线| 一区二区成人在线观看| 欧美一级一区二区| 亚洲精品看片| 韩国一区二区三区| 亚洲欧洲日产国码二区| 欧美影视一区二区三区| 欧美精品二区| 麻豆精品一区二区| 国产精品久久久久久久久久免费看 | 国产精品天美传媒| 在线免费观看不卡av| 牛人盗摄一区二区三区视频| 看电视剧不卡顿的网站| 国产精品久久久一区麻豆最新章节| 色8久久人人97超碰香蕉987| 欧美成人一品| 精品在线一区二区三区| 国产成人精品免费在线| 一区二区av| 成人在线一区二区三区| 五月天久久比比资源色| 亚洲国产高清在线观看视频| 欧美群妇大交群中文字幕| 日韩视频精品在线观看| 丁香婷婷综合五月| 五月天激情小说综合| 日本一区二区三区dvd视频在线| 色先锋资源久久综合| 黄色一区三区| 成人av影院在线| 激情五月播播久久久精品| 亚洲一区在线观看视频| 国产清纯白嫩初高生在线观看91 | 日韩一区二区精品在线观看| 久久久久欧美精品| 一本色道久久综合亚洲精品不| 99久久99久久免费精品蜜臀| 极品尤物av久久免费看| 亚洲午夜免费视频| 亚洲视频在线一区观看| 久久久久99精品国产片| 日韩一区二区三区在线观看| 欧美性大战xxxxx久久久| 麻豆av福利av久久av| 日韩一级在线| 亚洲国产合集| 影音先锋久久精品| 午夜精彩国产免费不卡不顿大片| 成人一区在线看| 国内偷窥港台综合视频在线播放| 三级亚洲高清视频| 午夜欧美电影在线观看| 亚洲午夜久久久久久久久久久| 亚洲视频资源在线| 亚洲欧美日韩久久| 中文字幕一区二区三区不卡在线| 国产在线播放一区三区四|