狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQLServer如何監(jiān)控阻塞會(huì)話

freeflydom
2024年5月28日 10:28 本文熱度 1026

一、查詢阻塞和被阻塞的會(huì)話

SELECT 

    r.session_id AS [Blocked Session ID],

    r.blocking_session_id AS [Blocking Session ID],

    r.wait_type,

    r.wait_time,

    r.wait_resource,

    s1.program_name AS [Blocked Program Name],

    s1.login_name AS [Blocked Login],

    s2.program_name AS [Blocking Program Name],

    s2.login_name AS [Blocking Login],

    r.text AS [SQL Text]

FROM sys.dm_exec_requests AS r

LEFT JOIN sys.dm_exec_sessions AS s1 ON r.session_id = s1.session_id

LEFT JOIN sys.dm_exec_sessions AS s2 ON r.blocking_session_id = s2.session_id

CROSS APPLY sys.dm_exec_sql_text(r.sql_handle) AS r

WHERE r.blocking_session_id <> 0

二、找出阻塞的具體SQL

SELECT 

    r.session_id,

    r.blocking_session_id,

    t.text AS [SQL Text],

    r.wait_type,

    r.wait_time,

    r.wait_resource

FROM sys.dm_exec_requests AS r

CROSS APPLY sys.dm_exec_sql_text(r.sql_handle) AS t

WHERE r.blocking_session_id <> 0;

三、編寫C#程序,每隔10秒監(jiān)控SQL Server數(shù)據(jù)庫(kù)中的阻塞會(huì)話,定位出阻塞的根源會(huì)話并終止它們,同時(shí)記錄日志。

using System;

using System.Data.SqlClient;

using System.IO;

using System.Timers;


class Program

{

    private static Timer timer;

    private static string connectionString = "your_connection_string_here";


    static void Main(string[] args)

    {

        timer = new Timer(10000); // 每10秒執(zhí)行一次

        timer.Elapsed += CheckForBlockingSessions;

        timer.AutoReset = true;

        timer.Enabled = true;


        Console.WriteLine("Press [Enter] to exit the program.");

        Console.ReadLine();

    }


    private static void CheckForBlockingSessions(object source, ElapsedEventArgs e)

    {

        try

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                connection.Open();


                string query = @"

                SELECT 

                    r.session_id AS BlockedSessionID,

                    r.blocking_session_id AS BlockingSessionID,

                    r.text AS SqlText

                FROM sys.dm_exec_requests AS r

                CROSS APPLY sys.dm_exec_sql_text(r.sql_handle) AS r

                WHERE r.blocking_session_id <> 0;";


                using (SqlCommand command = new SqlCommand(query, connection))

                {

                    using (SqlDataReader reader = command.ExecuteReader())

                    {

                        while (reader.Read())

                        {

                            int blockedSessionId = reader.GetInt32(0);

                            int blockingSessionId = reader.GetInt32(1);

                            string sqlText = reader.GetString(2);


                            LogBlockingSession(blockedSessionId, blockingSessionId, sqlText);

                            KillSession(blockingSessionId);

                        }

                    }

                }

            }

        }

        catch (Exception ex)

        {

            LogError(ex.Message);

        }

    }


    private static void KillSession(int sessionId)

    {

        try

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                connection.Open();

                string killQuery = $"KILL {sessionId};";

                using (SqlCommand killCommand = new SqlCommand(killQuery, connection))

                {

                    killCommand.ExecuteNonQuery();

                    LogKillSession(sessionId);

                }

            }

        }

        catch (Exception ex)

        {

            LogError($"Failed to kill session {sessionId}: {ex.Message}");

        }

    }


    private static void LogBlockingSession(int blockedSessionId, int blockingSessionId, string sqlText)

    {

        string logMessage = $"[{DateTime.Now}] Blocked Session ID: {blockedSessionId}, Blocking Session ID: {blockingSessionId}, SQL Text: {sqlText}";

        File.AppendAllText("blocking_sessions.log", logMessage + Environment.NewLine);

        Console.WriteLine(logMessage);

    }


    private static void LogKillSession(int sessionId)

    {

        string logMessage = $"[{DateTime.Now}] Killed Session ID: {sessionId}";

        File.AppendAllText("killed_sessions.log", logMessage + Environment.NewLine);

        Console.WriteLine(logMessage);

    }


    private static void LogError(string message)

    {

        string logMessage = $"[{DateTime.Now}] Error: {message}";

        File.AppendAllText("errors.log", logMessage + Environment.NewLine);

        Console.WriteLine(logMessage);

    }

}

說(shuō)明

  1. 連接字符串:替換 your_connection_string_here 為實(shí)際的數(shù)據(jù)庫(kù)連接字符串。

  2. 定時(shí)器:使用 System.Timers.Timer 類設(shè)置每10秒執(zhí)行一次檢查。

  3. 檢查阻塞會(huì)話:在 CheckForBlockingSessions 方法中,查詢阻塞會(huì)話和根源會(huì)話的信息。

  4. 終止會(huì)話:在 KillSession 方法中,執(zhí)行 KILL 命令來(lái)終止阻塞會(huì)話。

  5. 日志記錄:日志記錄包括阻塞會(huì)話的詳細(xì)信息和終止會(huì)話的操作,以及錯(cuò)誤信息。

注意事項(xiàng)

  • 運(yùn)行此程序需要確保有足夠的權(quán)限來(lái)訪問(wèn)數(shù)據(jù)庫(kù)和執(zhí)行 KILL 命令。

  • 請(qǐng)仔細(xì)測(cè)試程序以確保其符合預(yù)期行為,尤其是在生產(chǎn)環(huán)境中。

  • 日志文件的路徑和權(quán)限需要根據(jù)實(shí)際情況進(jìn)行配置。


轉(zhuǎn)自https://www.cnblogs.com/tianqing/p/18217020 作者:Eric Zhou


該文章在 2024/5/28 10:28:58 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved