你應(yīng)該牢記MySQL服務(wù)器啟動過程的兩個目標(biāo):

專注于為中小企業(yè)提供網(wǎng)站設(shè)計、成都網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)泗水免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
你想讓服務(wù)器以某個非root用戶運行。一般地,你想限制任何運行進程的能力,除非確實需要root權(quán)限,而MySQL不需要。
你想讓服務(wù)器始終以同一個用戶運行,此時用一個用戶而其他時候以另一個不同的用戶運行服務(wù)器是很不方便的,這造成了為文件和目錄以具有不同屬主的數(shù)據(jù)目錄下被創(chuàng)建,并可能導(dǎo)致服務(wù)器不能訪問數(shù)據(jù)庫或表,這看你以哪個用戶運行。統(tǒng)一用同一個用戶運行服務(wù)器是你避免這個問題。
要一個普通的非特權(quán)用戶運行服務(wù)器,按照下列步驟:
選擇一個用于運行服務(wù)器的用戶,mysqld可以用任何用戶運行。但在概念上較清晰的是為MySQL操作創(chuàng)建一個單獨的用戶。你也可以特別為MySQL選擇一個用戶組。本文使用mysqladm和mysqlgrp分別作為用戶名和用戶組名。
如果你已在自己的賬號下安裝好了MySQL且沒有系統(tǒng)上的特殊管理權(quán)限,你將可能在你自己的用戶ID下運行服務(wù)器。在這種情況下,用你自己的登錄名和用戶組代替mysqladm和mysqlgrp。
如果你在RedHat Linux上用rpm文件安裝MySQL,該安裝將自動創(chuàng)建一個名為mysql的賬號,用該賬號代替mysqladm。
如果必要,用系統(tǒng)通常的創(chuàng)建用戶的過程創(chuàng)建服務(wù)器賬號,你需要用root做它。
如果服務(wù)器在運行,停止它。
修改數(shù)據(jù)目錄和任何子目錄和文件的屬主,這樣使得mysqladm用戶擁有它們。例如,如果數(shù)據(jù)目錄是/usr/local/var,你可以如下設(shè)置mysqladm的屬主(你需要以root運行這些命令):
#cd /usr/local/var
#chown -R mysqladm.mysqlgrp
修改數(shù)據(jù)目錄和任何子目錄和文件的權(quán)限,使得它們只能由mysqladm用戶訪問。如果數(shù)據(jù)目錄是/usr/local/var,你可以設(shè)置由mysqladm擁有的任何東西:
# cd /usr/local/var
# chmod -R go-rwx
當(dāng)你設(shè)置數(shù)據(jù)目錄及其內(nèi)容的屬主和模式時,注意符號連接。你需要順著它們并改變它們指向的文件或目錄的屬主和模式。如果連接文件的目錄位于不屬于你的地方,會有些麻煩,你可能需要root身份。
在你完成了上述過程后,你應(yīng)該確保總是在以mysqladm或root登錄時啟動服務(wù)器,在后者,確定指定--user=mysqladm選項,使服務(wù)器能將其用戶ID切換到mysqladm(同時也適用于系統(tǒng)啟動過程)。
--user選項在MySQL 3.22中引入,如果你有老版本,你可以使用su命令告訴系統(tǒng)在以root運行時在特定的用戶下運行服務(wù)器。
二、啟動服務(wù)器的方法
在我們確定了用于運行服務(wù)器的賬號后,你可以選擇如何安排啟動服務(wù)器。你可以從命令行手動或在系統(tǒng)引導(dǎo)過程中自動地運行它。對于啟動服務(wù)器由三種主要方法:
直接調(diào)用mysqld。
這可能是最不常用的方法,建議不要多使用,因此本文不詳細介紹。
調(diào)用safe_mysqld腳本。
safe_mysqld試圖確定服務(wù)器程序和數(shù)據(jù)目錄的位置。然后用反映這些值的選項調(diào)用服務(wù)器。safe_mysqld將標(biāo)準(zhǔn)出錯設(shè)備從服務(wù)器重定位到數(shù)據(jù)目錄下的一個出錯文件,使得有它的一條記錄。在啟動服務(wù)器后,safe_mysqld也監(jiān)視它并且如果它死掉則重啟它。safe_mysqld常用于BSD風(fēng)格的Unix系統(tǒng)。
如果你以root或在系統(tǒng)引導(dǎo)期間啟動sqfe_mysqld,出錯日志由root擁有,這可能在你以后試圖用一個非特權(quán)用戶調(diào)用safe_mysqld時將導(dǎo)致“permission denied”(權(quán)限拒絕)錯誤,刪除出錯日志再試一下。
調(diào)用mysql.server腳本。
這個腳本通過有意用于System V的啟動和停止系統(tǒng)上的safe_mysqld.mysql.server來啟動服務(wù)器,該系統(tǒng)包含幾個包含在機器進入或退出一個給定運行級別時被點用的腳本目錄。它可以用一個start或stop參數(shù)點用以表明你是想啟動還是想停止服務(wù)器。
safe_mysqld腳本安裝在MySQL安裝目錄的bin目錄下,或可在MySQL源代碼分發(fā)的scripts目錄下找到。mysql.server腳本安裝在MySQL安裝目錄下的share/mysqld目錄下或可以在MySQL源代碼分發(fā)的support_files目錄下找到。如果你想使用它們,你需要將它們拷貝到適當(dāng)?shù)哪夸浵隆?/p>
對BSD風(fēng)格的系統(tǒng)(FreeBSD,OpenBSD等),通常在/etc目錄下有幾個文件在引導(dǎo)時初始化服務(wù),這些文件通常有以“rc”開頭的名字,且它有可能由一個名為“rc.local”的文件(或類似的東西),特意用于啟動本地安裝的服務(wù)。在這樣的系統(tǒng)上,你可能將類似于下列的行加入rc.local文件中以啟動服務(wù)器(如果safe_mysqld的目錄在你的系統(tǒng)上不同,修改它即可):
if [ -x /usr/local/bin/safe_mysqld ]; then
/usr/local/bin/safe_mysqld
fi
對于對于System V風(fēng)格的系統(tǒng),你可以通過將mysql.server放在/etc下適當(dāng)?shù)膯幽夸浵聛戆惭b它。如果你運行Linux并從一個RPM文件安裝MySQL,這些已經(jīng)為你做好了,否則將腳本安裝在主啟動目錄下,并將指向它的連接放在適當(dāng)?shù)倪\行級別目錄下。你也可以使腳本只能由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參數(shù)調(diào)用。如果你有chkconfig命令(Linux上有),你可以由它幫助安裝mysql.server腳本而不是象上面那樣手工運行上述命令。
2.1 指定啟動選項
如果你想在服務(wù)器啟動時指定額外的啟動選項,你可有兩種方法。你可以修改你使用的啟動腳本(safe_mysqld或mysql.server)并直接在調(diào)用服務(wù)器的行上指定選項,或在一個選項文件中指定選項。建議你如果可能在一個全局選項文件中指定選項,它通常位于/etc/my.cnf(Unix)或c:\\my.cnf(Windows)。
某些種類的信息無法以服務(wù)器選項指定。對于這些你可能需要修改safe_mysqld。例如,如果你的服務(wù)器不能正確選擇本地時區(qū)而以GMT返回時間值,你可以設(shè)置TZ環(huán)境變量給它一個指示。如果你用safe_mysqld或mysql.server啟動服務(wù)器,你可以將一個時區(qū)設(shè)置加到safe_mysqld。找到啟動服務(wù)器的行并在該行前加入下列命令:
TZ=US/Central
export TZ
上面命令的語法是Solaris的,對于其他系統(tǒng)語法可能不同,請查閱相關(guān)手冊。如果你確實修改了你的啟動腳本,要記住下次你安裝MySQL時(如升級到新版本),你的修改將失去,除非你首先在別處復(fù)制了啟動腳本。在安裝了新版本后,比較新舊版本的腳本,看看你需要重建什么改變。
2.2 在啟動時檢查你的表
除了安排你的服務(wù)器在系統(tǒng)引導(dǎo)時啟動,你可能要安裝myisamchk和isamchk腳本,以在服務(wù)器啟動前檢查你的表。你可能在一個崩潰后重啟,有可能表已經(jīng)損害,在啟動前檢查它是一個發(fā)現(xiàn)問題的好方法。
三、停止服務(wù)器
要手工啟動服務(wù)器,使用mysqladmin:
%mysqladmin shutdown
要自動停止服務(wù)器,你不需做特別的事情。BSD系統(tǒng)一般通過向進程發(fā)一個TERM信號停止服務(wù),它們或者正確應(yīng)答它或被粗魯?shù)貧⑺馈ysqld在它收到這個信號時以終止作為應(yīng)答。對于用mysql.server啟動服務(wù)器的System V風(fēng)格的系統(tǒng),停止進程將用一個stop參數(shù)調(diào)用該腳本,告訴服務(wù)器終止,當(dāng)然假定你已安裝了mysql.server。
參數(shù)定義
單個參數(shù)
1 CREATE PROCEDURE HelloWorld1
2 @UserName VARCHAR(10)
3 AS
4 BEGIN
5 PRINT 'Hello' + @UserName + '!';
6 END;
7 go
1 DECLARE @RC int;
2 EXECUTE @RC = HelloWorld1 'Edward' ;
3 PRINT @RC;
4 go
HelloEdward!
IN、OUT、IN OUT
注:
SQL Server 的 OUTPUT 需要寫在變量數(shù)據(jù)類型后面。
SQL Server 沒有 IN OUT 關(guān)鍵字
OUTPUT 已經(jīng)相當(dāng)于 IN OUT 了。
1 CREATE PROCEDURE HelloWorld2
2 @UserName VARCHAR(10),
3 @OutVal VARCHAR(10) OUTPUT,
4 @InoutVal VARCHAR(10) OUTPUT
5 AS
6 BEGIN
7 PRINT 'Hello ' + @UserName + @InoutVal + '!';
8 SET @OutVal = 'A';
9 SET @InoutVal = 'B';
10 END;
11 go
1
2 DECLARE @RC int, @OutVal VARCHAR(10), @InoutVal VARCHAR(10);
3 BEGIN
4 SET @InoutVal = '~Hi~';
5 EXECUTE @RC = HelloWorld2 'Edward', @OutVal OUTPUT, @InoutVal OUTPUT;
6 PRINT @RC;
7 PRINT '@OutVal=' + @OutVal;
8 PRINT '@InoutVal=' + @InoutVal;
9 END
10 go
Hello Edward~Hi~!
@OutVal=A
@InoutVal=B
參數(shù)的默認值
1 CREATE PROCEDURE HelloWorld3
2 @UserName VARCHAR(10),
3 @Val1 VARCHAR(20) = ' Good Moning,',
4 @Val2 VARCHAR(20) = ' Nice to Meet you'
5 AS
6 BEGIN
7 PRINT 'Hello ' + @UserName + @Val1 + @Val2 + '!';
8 END;
9 go
1
2 DECLARE @RC int;
3 BEGIN
4 EXECUTE @RC = HelloWorld3 'Edward';
5 PRINT @RC;
6 EXECUTE @RC = HelloWorld3 'Edward', ' Good Night,';
7 PRINT @RC;
8 EXECUTE @RC = HelloWorld3 'Edward', ' Good Night,', ' Bye';
9 PRINT @RC;
10 END
11 go
Hello Edward Good Moning, Nice to Meet you!
Hello Edward Good Night, Nice to Meet you!
Hello Edward Good Night, Bye!
指定參數(shù)名稱調(diào)用
此部分使用 “參數(shù)默認值”那一小節(jié)的存儲過程。
用于說明當(dāng)最后2個參數(shù)是有默認的時候,如何跳過中間那個。
1 DECLARE @RC int;
2 BEGIN
3 EXECUTE @RC = HelloWorld3 'Edward';
4 PRINT @RC;
5 EXECUTE @RC = HelloWorld3 'Edward', @Val1=' Good Night,';
6 PRINT @RC;
7 EXECUTE @RC = HelloWorld3 'Edward', @Val1=' Good Night,', @Val2=' Bye';
8 PRINT @RC;
9 EXECUTE @RC = HelloWorld3 'Edward', @Val2=' HeiHei ';
10 PRINT @RC;
11 END
12 go
Hello Edward Good Moning, Nice to Meet you!
Hello Edward Good Night, Nice to Meet you!
Hello Edward Good Night, Bye!
Hello Edward Good Moning, HeiHei !
一次性插入大量數(shù)據(jù),只能使用循環(huán),
如:游標(biāo),while 循環(huán)語句
下面介紹While 循環(huán)插入數(shù)據(jù),
SQL 代碼如下:
IF OBJECT_ID('dbo.Nums') IS NOT NULL
DROP TABLE dbo.Nums;
GO
CREATE TABLE dbo.Nums(n INT NOT NULL PRIMARY KEY);
DECLARE @max AS INT, @rc AS INT;
SET @max = 5000000;
SET @rc = 1;
INSERT INTO Nums VALUES(1);
WHILE @rc * 2 = @max
BEGIN
INSERT INTO dbo.Nums SELECT n + @rc FROM dbo.Nums;
SET @rc = @rc * 2;
END
INSERT INTO dbo.Nums SELECT n + @rc FROM dbo.Nums WHERE n + @rc = @max;
--以上函數(shù)取自Inside SQL Server 2005: T-SQL Query一書。
INSERT dbo.Sample SELECT n, RAND(CAST(NEWID() AS BINARY(16))) FROM Nums
如果有日期格式使用下面的代碼:
=CONCATENATE("insert?into?employee(name,birthday,email,hobby)values('",RC[-4],"','",TEXT(RC[-3],"yyyy-mm-dd hh:mm:ss"),"','",RC[-2],"','",RC[-1],"');")
rc全稱是Release Candidate,含義是"發(fā)布候選版",它不是最終的版本,而是最終版(RTM=Release To Manufacture)之前的最后一個版本。
廣義上對測試有三個傳統(tǒng)的稱呼:alpha、beta、gamma,用來標(biāo)識測試的階段和范圍。
alpha 是指內(nèi)測,即現(xiàn)在說的CB,指開發(fā)團隊內(nèi)部測試的版本或者有限用戶體驗測試版本;beta 是指公測,即針對所有用戶公開的測試版本;然后做過一些修改,成為正式發(fā)布的候選版本時叫做gamma,現(xiàn)在叫做RC(Release Candidate)。
擴展資料
sqlserver特點
1、真正的客戶機/服務(wù)器體系結(jié)構(gòu)。
2、圖形化用戶界面,使系統(tǒng)管理和數(shù)據(jù)庫管理更加直觀、簡單。
3、豐富的編程接口工具,為用戶進行程序設(shè)計提供了更大的選擇余地。
4、SQL Server與Windows NT完全集成,利用了NT的許多功能,如發(fā)送和接受消息,管理登錄安全性等。SQL Server也可以很好地與Microsoft BackOffice產(chǎn)品集成。
5、具有很好的伸縮性,可跨越從運行Windows 95/98的小型電腦到運行Windows 2000的大型多處理器等多種平臺使用。
6、對Web技術(shù)的支持,使用戶能夠很容易地將數(shù)據(jù)庫中的數(shù)據(jù)發(fā)布到Web頁面上。
7、SQL Server提供數(shù)據(jù)倉庫功能,這個功能只在Oracle和其他更昂貴的DBMS中才有。
我們知道,可以使用SQL Server自帶的Profiler工具來跟蹤死鎖信息。但這種方式有一個很大的敝端,就是消耗很大。據(jù)國外某大神測試,profiler甚至可以占到服 務(wù)器總帶寬的35%,所以,在一個繁忙的系統(tǒng)中,使用profiler顯然不是一個好主意,下面我介紹兩種消耗比較少的方法。其中第二種的消耗最小,在最 繁忙的系統(tǒng)中也可使用。第一種最為靈活,可滿足多種應(yīng)用。
方法一:利用SQL Server代理(Alert+Job)
具體步驟如下:
1.首先使用下面的命令,將有關(guān)的跟蹤標(biāo)志啟用。
SQL code
DBCC TRACEON (3605,1204,1222,-1)
說明:
3605 將DBCC的結(jié)果輸出到錯誤日志。
1204 返回參與死鎖的鎖的資源和類型,以及受影響的當(dāng)前命令。
1222 返回參與死鎖的鎖的資源和類型,以及使用了不符合任何 XSD 架構(gòu)的 XML 格式的受影響的當(dāng)前命令(比1204更進一步,SQL 2005及以上可用)。
-1 以全局方式打開指定的跟蹤標(biāo)記。
以上跟蹤標(biāo)志作用域都是全局,即在SQL Server運行過程中,會一直發(fā)揮作用,直到SQL Server重啟。
如 果要確保SQL Server在重啟后自動開啟這些標(biāo)志,可以在SQL Server服務(wù)啟動選項中,使用 /T 啟動選項指定跟蹤標(biāo)志在啟動期
間設(shè)置為開。(位于SQL Server配置管理器-SQL Server服務(wù)-SQL Server-屬性-高級-啟動參數(shù))
在運行上面的語句后,當(dāng)SQL Server中發(fā)生死鎖時,已經(jīng)可以在錯誤日志中看到了,但還不夠直觀(和其它信息混在一起)。(SSMS
- SQL Server實例 - 管理 - SQL Server日志)
2.建表,存放死鎖記錄
SQL code
USE [Cole] --Cole是我的示例數(shù)據(jù)庫,你可以根據(jù)實際情況修改。
GO
CREATE TABLE DeadLockLog ( id int IDENTITY
(1, 1) NOT NULL, LogDate DATETIME, ProcessInfo VARCHAR(10), ErrorText VARCHAR(MAX) )
GO
3.建立JOB
新建一個JOB(假設(shè)名稱為DeadLockJob),在"步驟"中新建一步驟,隨便寫一個步驟名稱,數(shù)據(jù)庫為"Cole"(見2.建表),在"命令"欄中輸入以下語句:
SQL code
--新建臨時表 IF OBJECT_ID('tempdb.dbo.#ErrorLog') IS Not Null
DROP TABLE #ErrorLog
CREATE TABLE #ErrorLog
(Id int IDENTITY (1, 1) NOT NULL, a DATETIME, b VARCHAR(10), c VARCHAR(MAX)) --將當(dāng)前日志記錄插入臨時表
INSERT INTO #ErrorLog EXEC master.dbo.sp_readerrorlog --將死鎖信息插入用戶表
insert DeadLockLog
select a, b, c from #ErrorLog where id = (select MAX(id) from #ErrorLog
WHERE c Like '%Deadlock encountered%')
DROP TABLE #ErrorLog
4.新建警報
在"新建警報"窗體的"常規(guī)"選項卡中,進行以下設(shè)置:
名稱:可根據(jù)實際自行命名,這里我用DeadLockAlert
類型:選擇"SQL Server性能條件警報"
對象:SQLServer:Locks
計數(shù)器:Number of Deadlocks/sec
實例:_Total
計數(shù)器滿足以下條件時觸發(fā)警報:高于
值:0
設(shè)置完成后,應(yīng)該如下圖所示:
在"響應(yīng)"選項卡中,選中"執(zhí)行作業(yè)",并選擇步驟3中我們新建的作業(yè)(即DeadlockJob)
到這里為止,我們已經(jīng)完成了全部步驟,以后,你就可以隨時查詢DeadLockLog表,來顯示死鎖信息了。
方法二:利用服務(wù)器端跟蹤。
具體實現(xiàn)步驟如下:
1.編寫如下腳本,并執(zhí)行
SQL code
-- 定義參數(shù)
declare @rc int
declare @TraceID int
declare @maxfilesize bigint
set @maxfilesize = 5
-- 初始化跟蹤 exec @rc = sp_trace_create @TraceID output, 0, N'e:\DbLog\deadlockdetect', @maxfilesize, NULL
--此處的e:\dblog\deadlockdetect是文件名(可自行修改),SQL會自動在后面加上.trc的擴展名
if (@rc != 0) goto error -- 設(shè)置跟蹤事件 declare @on bit set @on = 1
--下述語句中的148指的是locks:deadlock graph事件(參見sys.trace_events),12指的是spid列(參見sys.trace_columns)
exec sp_trace_setevent @TraceID, 148, 12, @on
exec sp_trace_setevent @TraceID, 148, 11, @on
exec sp_trace_setevent @TraceID, 148, 4, @on
exec sp_trace_setevent @TraceID, 148, 14, @on
exec sp_trace_setevent @TraceID, 148, 26, @on
exec sp_trace_setevent @TraceID, 148, 64, @on
exec sp_trace_setevent @TraceID, 148, 1, @on
-- 啟動跟蹤
exec sp_trace_setstatus @TraceID, 1
-- 記錄下跟蹤ID,以備后面使用
select TraceID = @TraceID
goto finish
error:
select ErrorCode=@rc
finish:
go
運行上述語句后,每當(dāng)SQL Server中發(fā)生死鎖事件,都會自動往文件e:\DbLog\deadlockdetect.trc中插入一條記錄。
2.暫停和停止服務(wù)器端跟蹤
如果要暫停上面的服務(wù)器端跟蹤,可運行下面的語句:
SQL code
exec sp_trace_setstatus 1, 0 --第一個參數(shù)表示TraceID,即步驟1中的輸出參數(shù)。第二個參數(shù)表示將狀態(tài)改為0,即暫停
如果要停止上面的服務(wù)器端跟蹤,可運行下面的語句:
SQL code
exec sp_trace_setstatus 1, 2 --第一個參數(shù)表示TraceID,即步驟1中的輸出參數(shù)。第二個參數(shù)表示將狀態(tài)改為2,即停止
3.查看跟蹤文件內(nèi)容
對于上面生成的跟蹤文件(e:\DbLog\deadlockdetect.trc),可通過兩種方法查看:
1).執(zhí)行t-sql命令
SQL code
select * from fn_trace_gettable('e:\DbLog\deadlockdetect.trc',1)
結(jié)果中的TextData列即以XML的形式返回死鎖的詳細信息。
2).在SQL Server Profiler中打開。
依次 進入Profiler - 打開跟蹤文件 -選擇e:\DbLog\deadlockdetect.trc,就可以看到以圖形形式展現(xiàn)的死鎖信息了。
當(dāng)前標(biāo)題:關(guān)于sqlserverrc的信息
瀏覽地址:http://chinadenli.net/article16/dsgdedg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、域名注冊、響應(yīng)式網(wǎng)站、微信小程序、網(wǎng)站導(dǎo)航、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)