SQL性能優化:如何定位網路性能問題

来源:http://www.cnblogs.com/kerrycode/archive/2016/04/13/5386626.html
-Advertisement-
Play Games

一同事跟我反饋他遇到了一個SQL性能問題,他說全表只有69條記錄,客戶端執行耗費了兩分多鐘,這不科學呀。要我分析一下原因並解決。我按照類似表結構,構造了一個案例,測試截圖如下所示 這個表有13800KB(也就是13M多大小),因為該表將圖片保存到資料庫(Item_Photo欄位為iamge類型),這... ...


一同事跟我反饋他遇到了一個SQL性能問題,他說全表只有69條記錄,客戶端執行耗費了兩分多鐘,這不科學呀。要我分析一下原因並解決。我按照類似表結構,構造了一個案例,測試截圖如下所示

clipboard

 

這個表有13800KB(也就是13M多大小),因為該表將圖片保存到資料庫(Item_Photo欄位為iamge類型),這個是歷史原因,暫且不噴這種的設計。看來這個SQL執行時間長的性能問題不在於IO和SQL本身執行計劃是否有問題,而是在網路數據傳時間上(伺服器與客戶端位於異地,兩地專線帶寬6M,不過很多應用、郵件、系統都依賴此專線)

sp_spaceused 'Item_Test'
 
name               rows     reserved        data        index_size      unused
-----------  -------------  ----------  -------------- ----------- -------------
Item_Test          69      13864 KB      13800 KB           16 KB        48 KB

為了驗證我的想法,我在伺服器本機測試時間為2秒,如下截圖所示

clipboard[1]

從上面我們知道在客戶端執行完該SQL語句,總共耗費了2分23秒。那麼客戶端的到底獲取了多少位元組數據,數據傳輸耗費了多長時間呢? 能否查看這些DETAIL信息呢? 答案是可以。在SSMS工具欄,勾選“Include Client Statistics”或使用快捷鍵SHIFT+ALT+S,然後執行SQL語句,就能得到如下截圖的相關信息。

clipboard[2]

 

clipboard[3]

Client Statistics(客戶端統計信息)包含三大塊:  Query Profile Statistics, Network Statistics, Time Statistics。

這些部分的內容很容易理解,無需多說,那麼我們來看看吧

 

Network Statistics(網路統計信息)
 
 
Number of server roundtrips:        伺服器往返的次數
 
TDS packets sent from client:       從客戶端發送的TDS數據包(個數)
 
TDS packets received from server:   從服務端接收的TDS數據包(個數)
 
Bytes sent from client:             從客戶端發送的位元組數
 
Bytes received from server:         從伺服器接收的位元組數
 
 
 
Time Stattistics:(時間統計信息)
 
 
Client processing time:              客戶端處理時間
 
Total execution time:                總執行時間
 
Wait time on server replies:         伺服器應答等待時間

 

從客戶端發送的位元組和從服務端接收的數據大小都很清晰、明瞭,那麼數據從伺服器端發送給客戶端所需的時間這裡沒有,其實它基本上接近客戶端處理時間(Client processing time),我們也可以將客戶端處理時間權當網路數據傳輸時間,從上面案例,我們可以看到這個時間耗費了140秒(140132 ms),可以肯定這個SQL性能慢在網路數據傳輸上,而不是慢在資料庫那一塊(Server Processing Time).

我們來看看下圖,這個是SQL SERVER的請求接收和數據輸出的一個大致流程圖,當客戶端發送請求開始,當伺服器接收客戶端發來的最後一個TDS包,資料庫引擎開始處理請求,請求完成後,將數據發送給客戶端,從圖中可以看出,客戶端接收伺服器端返回的數據也是需要一個過程的(或者說時間)

clipboard[4]

 

我們在SQL優化過程中,如果一個SQL出現性能問題時,我們應該站在一個全局的角度來分析問題,從CPU資源、網路帶寬、磁碟IO、執行計劃等多方面來分析,這樣才能有助於你分析、定位問題根源,而不要只要SQL響應很慢時,就一味條件反射式先入為主:這是資料庫問題。資料庫也不能老背這個黑鍋。

 

在資料庫等待事件中,ASYNC_NETWORK_IO可以從另外一個側面反映網路性能問題。關於ASYNC_NETWORK_IO等待類型:

This waittype indicates that the SPID is waiting for the client application to fetch the data before the SPID can send more results to the client application.

 

那麼回到如何優化這個SQL的問題上來,我們可以從下麵幾個方面來進行優化。

   1: SQL只取必須的欄位數據

        像這個案例,其實它根本不需要Item_Photo欄位數據,那麼我們可以修改SQL,只取我們需要的欄位數據,就可以避免這個問題,提高SQL性能,另外根據我的經驗,開發人員習慣性使用SELECT *,從不管那些數據是需要還是不需要的,先全部取過來再說,這種習慣性行為確實不是一個好習慣。

 

   2:避免這種腦殘設計

      圖片應該以文件形式保存在應用伺服器上,資料庫只保存其路徑信息,這種將圖片保存到資料庫的設計純屬腦殘行為。

 

 

參考資料:

https://www.simple-talk.com/sql/database-administration/how-come-the-hourglass-why-database-applications-slow-down.-/


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

-Advertisement-
Play Games
更多相關文章
  • 首先,簡單的說一下,這個底部框架的實現步驟。 1,自定義一個類,繼承LinearLayout就好了 ,因為我喜歡用LinearLayout, 當然你也可以繼承RelativeLayout。 2,重寫它兩個帶參數的構造方法。 3,進入內容的編寫,佈局文件的處理,數據的處理。 4,給底部容器添加view ...
  • 利用Intent實現有返回結果的頁面跳轉 主要用的方法: (1)Intent的構造方法:intent(當前界面對象,要跳轉的界面.class); (2)接受結果的方法onActivityResult(int requestCode, int resultCode, Intent data) (3)調 ...
  • 恢復內容開始 //需要的效果 1.設置window的根視圖控制器為一個UITableViewController #import "AppDelegate.h"#import "YCTableViewController.h"@interface AppDelegate ()@end@impleme ...
  • 當使用閉包時,類本身持有self,然後又在閉包中訪問了self或者self的屬性,就會導致噁心額迴圈引用。swift提供的解決方法是在閉包中定義捕獲列表,捕獲列表是閉包想怎麼引用捕獲來的變數。例如下麵定義了一個捕獲列表,引用self為unowned引用,這樣在賓傲中用self就不會導致迴圈引用 去掉 ...
  • 一,效果圖。 二,工程圖。 三,代碼。 RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController : UIViewController <UITextViewDelegate> @end RootViewCo ...
  • 如圖 添加如下代碼 sTableView.separatorInset = UIEdgeInsetsZero; sTableView.layoutMargins = UIEdgeInsetsZero; cell.layoutMargins = UIEdgeInsetsZero; 第二種方法如下圖 - ...
  • 為了實現在ios系統上抓包,如下步驟: 1,設備越獄 2,在cydia-軟體源-設置中改為開發者,否則有些deb搜索不到 安裝如下軟體:OpenSSH,OpenSSL,wget (下載工具) Aptitude 及 APT 0.6 Transitional (deb包工具) unzip 及 zip ( ...
  • MYSQL啟動報1067錯誤,系統日誌中是“服務 mysql 意外停止” Mysql日誌中則是:“Plugin 'FEDERATED' is disabled” 網我在網上找到解決方案:1、在MY.INI文件中的 [mysqld] 中增加一行tmpdir="D:/MySQL/data/"修改後,還是 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...