SSRS 2008 ReportServerTempDB增長異常分析

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

這兩天收到一SQL 2008 R2資料庫伺服器的磁碟空間告警,在檢查過程中發現ReportServerTempDB已經暴增到60多GB,其中數據文件接近60G,日誌文件9G大小左右。如下截圖所示 我們知道ReportServerTempDB是SSRS使用的臨時資料庫。這個資料庫負責存儲中間處理結果,... ...


    這兩天收到一SQL 2008 R2資料庫伺服器的磁碟空間告警,在檢查過程中發現ReportServerTempDB已經暴增到60多GB,其中數據文件接近60G,日誌文件9G大小左右。如下截圖所示

clipboard

我們知道ReportServerTempDB是SSRS使用的臨時資料庫。這個資料庫負責存儲中間處理結果,例如報表伺服器生成的會話和執行數據、緩存報表以及工作表。正常情況下,Report Server能夠周期性地清除ReportServerTempDB中的到期的和孤立的數據。後臺進程定期清理時間間隔由參數CleanupCycleMinutes控制,這個參數位於

<Installation Drive>\<Program Files or Program Files(x86)>\Microsoft SQL Server\<SSRS Instance>\Reporting Services\ReportServer 下的rsreportserver.config配置文件中。 例如C:\Program Files\Microsoft SQL Server\MSRS10_50.MSSQLSERVER\Reporting Services\ReportServer\rsreportserver.config ,它指定多少分鐘後從報表伺服器資料庫刪除舊會話和過期快照。有效值的範圍為 0 到最大整數之間。預設值為 10。如果將值設置為 0,將禁止資料庫清除進程。如下所示,此參數值為10分鐘

clipboard[1]

也就是說,如果正常清理ReportServerTempDB的話,ReportServerTempDB應該不會有這麼大。檢查資料庫ReportServerTempDB,發現最大的表是SessionData,有50多G大小。

CREATE TABLE #tablespaceinfo
    (
      nameinfo VARCHAR(500) ,
      rowsinfo BIGINT ,
      reserved VARCHAR(20) ,
      datainfo VARCHAR(20) ,
      index_size VARCHAR(20) ,
      unused VARCHAR(20)
    )  
 
DECLARE @tablename VARCHAR(255);  
 
DECLARE Info_cursor CURSOR
FOR
    SELECT  '[' + [name] + ']'
    FROM    sys.tables
    WHERE   type = 'U'
 
OPEN Info_cursor  
FETCH NEXT FROM Info_cursor INTO @tablename  
 
WHILE @@FETCH_STATUS = 0
    BEGIN 
        INSERT  INTO #tablespaceinfo
                EXEC sp_spaceused @tablename  
        FETCH NEXT FROM Info_cursor  
    INTO @tablename  
    END 
 
CLOSE Info_cursor  
DEALLOCATE Info_cursor  
 
--創建臨時表
CREATE TABLE [#tmptb]
    (
      TableName VARCHAR(50) ,
      DataInfo BIGINT ,
      RowsInfo BIGINT ,
      Spaceperrow  AS ( CASE RowsInfo
                         WHEN 0 THEN 0
                         ELSE CAST(DataInfo AS decimal(18,2))/CAST(RowsInfo AS decimal(18,2))
                       END ) PERSISTED
    )
 
--插入數據到臨時表
INSERT  INTO [#tmptb]
        ( [TableName] ,
          [DataInfo] ,
          [RowsInfo]
        )
        SELECT  [nameinfo] ,
                CAST(REPLACE([datainfo], 'KB', '') AS BIGINT) AS 'datainfo' ,
                [rowsinfo]
        FROM    #tablespaceinfo
        ORDER BY CAST(REPLACE(reserved, 'KB', '') AS INT) DESC  
 
 
--彙總記錄
SELECT  [tbspinfo].* ,
        [tmptb].[Spaceperrow] AS '每行記錄大概占用空間(KB)'
FROM    [#tablespaceinfo] AS tbspinfo ,
        [#tmptb] AS tmptb
WHERE   [tbspinfo].[nameinfo] = [tmptb].[TableName]
ORDER BY CAST(REPLACE([tbspinfo].[reserved], 'KB', '') AS INT) DESC  
 
DROP TABLE [#tablespaceinfo]
DROP TABLE [#tmptb]

clipboard[2]

檢查C:\Program Files\Microsoft SQL Server\MSRS10_50.MSSQLSERVER\Reporting Services\LogFiles 下的日誌文件,搜索“Call to CleanBatch”,會看到clean session都是0,部分如下所示

library!WindowsService_0!df8!04/20/2016-12:38:44:: i INFO: Call to CleanBatch()

library!WindowsService_0!df8!04/20/2016-12:38:45:: i INFO: Cleaned 0 batch records, 0 policies, 0 sessions, 0 cache entries, 49 snapshots, 289 chunks, 0 running jobs, 0 persisted streams, 244 segments, 244 segment mappings, 0 edit sessions.

library!WindowsService_0!df8!04/20/2016-12:38:45:: i INFO: Call to CleanBatch() ends

不清楚為什麼出現這種情況,在網上也能看到很多關於reportservertempdb 不能清理歷史數據或快照的帖子,如下所示,

http://www.sqlservercentral.com/Forums/Topic1183933-1550-1.aspx

ReportServerTempDB not cleaning itself up in SSRS 2008

ReportserverTempDB Grows unexpected

可以判斷SSRS清理歷史數據或快照的後臺進程出現異常或存在bug(The ReportServerTempDB sessiondata table is not being purged according to the 10 minute default setting),但是具體情況,沒有相關文檔或資料佐證。所以僅僅從上面日誌,我們還不能分析出具體原因。我倒是很想知道這個資料庫ReportServerTempDB是什麼時候出現暴增的,幸虧我在這台伺服器部署了一個作業監控資料庫文件增長情況,如下所示

可以看出這個資料庫在2016-1-1號,只有22G大小(已經運行了一兩年了),此後的幾個月,幾乎每個月增長了10G左右。

clipboard[3]

clipboard[4]

查看表SessionData的記錄,發現居然還有2015年就已經過期的會話數據,更加深信這個是SSRS的一些bug造成的。

USE ReportServerTempDB;
 
GO
 
SELECT MIN(Expiration) FROM SessionData WITH(NOLOCK)

clipboard[5]


那麼如何處理這個案例呢,我們可以在業務非常少的時間段,按照下麵步驟進行操作

1: 首先停止SSRS服務

2: 刪除SessionDate表的數據

USE ReportServerTempDB;
GO
 
TRUNCATE TABLE dbo.SessionData;

3: 然後啟動SSRS服務

4: 收縮ReportServerTempDB資料庫

    如果磁碟空間足夠的情況下,就不要收縮ReportServerTempDB資料庫了。如果磁碟空間實在緊張,那麼收縮也是必須的。clipboard[6]

 

 

如果還存在dbo.SessionData不斷增長的情況,最好創建做一個作業,每天定期清理那些過期的會話信息。另外還有一個問題,很多人會有疑惑:ReportServerTempDB資料庫裡面的表能否清理? 答案是可以,具體參考官方文檔https://technet.microsoft.com/en-us/library/ms156016.aspx

If you back up the temporary database and subsequently restore it, you should delete the contents. Generally, it is safe to delete the contents of the temporary database at any time. However, you must restart the Report Server Windows service after you delete the contents.


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

-Advertisement-
Play Games
更多相關文章
  • HashMap和SparseArray可以實現相似的功能。 但SparseArray是Android定義的,在鍵是整數時,他比HashMap的性能更高,因為HashMap使用的是Integer對象, 而SparseArray使用的是int型,因此使用HashMap會創建很多的Integer對象,而使 ...
  • 逐幀顯示一張圖片,連起來成為動畫 在res/drawable/目錄下,創建一個xxx.xml的文件 添加<animation-list>節點,設置是否迴圈android:oneshot:”false” 添加條目<item>節點,設置資源android:drawable=”@drawable/xxx” ...
  • 完成情況:瞭解as界面,以及基礎功能 制定個人模塊基本計劃 截圖及鏈接:運行helloworld:http://jingyan.baidu.com/album/90895e0fce970264ec6b0bf2.html?picindex=5 as入門知識介紹:http://blog.csdn.net ...
  • 說什麼都是蒼白的,直接上圖~ 在某些情況下,我們需要獲取用戶周邊的位置,來讓用戶選取。例如微信的朋友圈,在發一條朋友圈時可以選擇地點,就是使用這樣的功能。 基於以上的情況(其實也就是為了模仿微信),有了這個簡單的demo。 #-1 說明 其中使用了高德地圖的開發包,用了定位和搜索兩個模塊。demo中 ...
  • 今天主要學了幾個android控制項和使用兩個適配器 ListView DatePicker和TimePicker GridView 適配器:SimpleAdapter和ArrayAdapter 都是常見的控制項 學到現在就越來越發現,其實基本功打扎實了,學起這些很簡單,就是屬性和事件。 關於這些控制項有 ...
  • 【轉載】 Axc註:版本為AFNetWorking 2.6 3.0需要修改大部分對象 一:聲明本 人以前一直是使用ASI網路請求類庫的。最近才開始瞭解使用AFNetworing這個類庫。網上也肯定會有更好的介紹AFN的博客文章,希望大家辯證閱 讀,取之精華,去其糟粕。本人的認識可能有錯誤或者不全的地 ...
  • select distinct s.database_name, s.first_lsn,s.last_lsn,s.database_backup_lsn,s.backup_finish_date,s.type,f.physical_drive from msdb..backupset s join ...
  • 其實這個不是一個什麼新的話題。但是之前在多次項目中,總是遇到大家針對Oracle資料庫的訪問時,會有各種各樣的問題,最基本的就是要在客戶端安裝各種client,版本不一樣的話還有各種問題。 靜下心來看看,其實也沒有那麼難。我這裡總結一下,如何在.NET應用程式中,簡單優雅地使用Oracle資料庫。 ... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...