SQL SERVER中的OLEDB等待事件

来源:http://www.cnblogs.com/kerrycode/archive/2016/01/30/5172218.html
-Advertisement-
Play Games

OLEDB等待事件介紹 OLEDB等待類型是SQL SERVER 資料庫中最常見的幾種等待類型之一。它意味著某個會話(SPID)通過SQL Server Native Client OLEDB Provider發生了調用請求並等待資料庫返回所需的數據。它出現在遠程系統(remote system )...


OLEDB等待事件介紹

OLEDB等待類型是SQL SERVER 資料庫中最常見的幾種等待類型之一。它意味著某個會話(SPID)通過SQL Server Native Client OLEDB Provider發生了調用請求並等待資料庫返回所需的數據。它出現在遠程系統(remote system )或網路連接速度不夠快,因此調用伺服器必須等待要返回結果的情況下。OLEDB等待事件一般是由那些活動造成呢?它一般由下麵一些事件引起:

  1. 遠程過程調用(Remote procedure calls)
  2. 鏈接伺服器查詢(Linked server queries)
  3. BULK INSERT commands
  4. Full-search queries 或外部數據源處理,例如Excel
  5. 客戶端的Profiler跟蹤(Client-side Profiler traces)
  6. DMV, log reader and DBCC CHECKDB

看到DBCC CHECKDB會引起OLEDB等待事件,你是否覺得很奇怪,其實剛開始的時候我也覺得很奇怪,我們的DPA(Database Performance Analyzer)監控工具發現SQL 2012、SQL 2014資料庫的DBCC CHECKDB引起的OLEDB等待事件占據了等待類型柱狀圖很大的比例。這個引起了我的好奇心,後面查證後發現DBCC CHECKDB它使用 OLEDB 行集在查詢處理器和存儲引擎的子系統之間交換信息。

下麵演示一下DBCC CHECKDB出現OLEDB等待事件的例子:

--SESSION 1
DBCC SQLPERF('sys.dm_os_wait_stats', CLEAR);
GO
 
DBCC CHECKDB('AdventureWorks2014');
 
--SESSION 2
SELECT * FROM
sys.dm_os_wait_stats
WHERE wait_type='OLEDB'

clipboard

 

     在DBCC CHECKDB還在執行時,你在會話2中,會看到OLEDB等待類型的waiting_tasks_count、wait_time_ms會一直增加。關於DBCC CHECKDB產生的OLEDB等待事件,我從DPA裡面觀察,發現SQL Server 2012、SQL Server 2014明顯要比SQL Server 2005、 SQL Server 2008要多,暫時不清楚具體原因,在SQL SERVER 2012/2014中DBCC CHECKDB出現了幾個Bug,具體可以參考官方文檔SQL Server 2014 Service Pack 1 release information 。我們可以看到官方已經Fix掉了三個關於DBCC CHECKDB的Bug。但是我更新了這些補丁,依然發現DBCC CHECKDB引起的OLEDB等待事件較多。

   另外關於DMV會引起OLEDB等待事件,是因為DMV內部使用了OLEDB,因此一些監測工具頻繁調用DMV也會導致出現較多OLEDB等待事件。

 

OLEDB等待事件解決

 

1:從應用層面考慮,只返回必要的欄位和數據。減少網路傳輸內容和時間。從而減少OLEDB等待事件。例如分頁控制項的按頁獲取數據。

2:如果使用Linked Server獲取的數據是靜態數據,可以考慮將這些靜態數據複製到本地資料庫,減少沒有必要的鏈接伺服器查詢。如果數據是動態變化,也可以考慮使用使用複製(發佈訂閱)將數據同步到本地資料庫。

3:從業務角度出發審查你的數據分佈,鏈接伺服器查詢是否絕對有必要?那些是可以減少、那些不必要的?另外 ,可以從架構層面考慮解決,例如將那些數據集中起來。

4:如果有些數據源是Excel文件,可以先將其通過FTP或文件共用上傳到本機,然後處理數據。

5: 優化鏈接伺服器查詢的SQL,檢查其是否缺少索引、統計信息是否過時;是否可以將某些業務邏輯放置到遠程伺服器上去處理(存儲過程),然後只返回需要的數據。例如下麵這種需求。

        SELECT * FROM

        linked_server.dbo.table_a  inner join ..

        linked_server.dbo.table_b  inner join ..

        linked_server.dbo.table_c  inner join ..

        .......................

6:找系統管理員或網路管理員瞭解專線帶寬等情況。有時候網路帶寬資源不足時也是引起OLEDB等待事件增多的原因。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • jQuery實現的監聽回車按鍵代碼實例:回車鍵是最為常用的按鍵之一,所以點擊回車來執行一段代碼是比較常見的操作,下麵就通過實例代碼介紹一下如何實現此功能。代碼如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="a
  • js如何使用指定字元分割字元串:在實際應用中,可能需要將字元進行分割,然後進行相關操作,下麵就給出這樣一個代碼實例供大家參考。代碼如下: var str="a-n-t-z-o-n-e"; var theArray=str.split("-"); console.log(theArray); 以上代碼
  • <link>和@import url()引入外部css文件的區別:標題中的兩種方式都可以引入外部css文件,關於它們的基本用法這裡就不多介紹了,具體可以參閱相關閱讀。相關閱讀:(1).<link>標簽可以參閱HTML的<link>標簽一章節。(2).@import url()可以參閱css的@imp
  • 點擊增加或者減少商品數量並且自動計算總價格:本章節介紹一下如何實現點擊按鈕來添加或者刪除商品的數量,並且能夠自動計算商品的總價格。代碼實例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" con
  • javascript計算字元串的長度區分中英文:計算字元串的長度是常有的操作,代碼如下: var str="I love 螞蟻部落"; console.log(str.length); 使用length計算字元串的長度,得出的結果是字元串中字元的個數,而在實際應用中可能需要計算字元串所占有的位元組長度
  • 使用<link>標簽引入css文件簡單代碼實例:本章節介紹一下如何利用<link>標簽引入外部css文件。雖然這個非常的簡單,但是很多初學者比較容易忘記它的基本使用格式。下麵就演示一下如何使用此標簽引入外部樣式表:代碼如下: <link rel="stylesheet" type="text/css
  • 獲取table表格指定列的所有單元格的內容:本章節介紹一下如何獲取表格指定列的所有單元格的內容,這可能在一些應用或者說擴展應用中會需要。代碼實例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author"
  • 在SQL SERVER 2005/2008中,如果將有序的記錄插入臨時表,則從臨時表查詢出來的記錄是有序的(不依賴ORDER BY也是有序狀態),但是從SQL SERVER 2012開始,即使插入的記錄集有序,查詢出來的結果變成無序了。需要依賴ORDER BY來或得到一個有序結果。例如下麵例子: S...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...