分享方式:


使用 Reporting Services 中的 ExecutionLog 和 ExecutionLog3 檢視

Reporting Services 報表伺服器執行記錄包含有關在伺服器上執行,或多個伺服器上執行之報表的資訊。 這些伺服器位於原生模式向外延展部署或 SharePoint 伺服器陣列中。 您可以使用報表執行記錄來找出:

  • 要求報表的次數。
  • 最常使用哪些輸出格式。
  • 每個處理階段所花費的處理時間 (以毫秒為單位)。

此記錄會包含執行報表之資料集查詢所花費時間長度的資訊,以及處理資料所花費的時間。 如果您是報表伺服器系統管理員,您可以檢閱記錄資訊並識別長時間執行的工作。 您也可以向報表作者建議作者或許可以加以改善的資料集或處理報表的區域。

設定為 SharePoint 模式的報表伺服器也可以利用 SharePoint 統一登入服務 (ULS) 記錄。 如需詳細資訊,請參閱開啟 SharePoint 追蹤記錄檔的 Reporting Services 事件 (ULS)

檢視記錄資訊

報表伺服器會將有關報表執行的資料記錄到內部資料庫資料表中。 您可以從 SQL Server 檢視取得此資料表的資訊。

報表執行記錄會儲存在預設名為 ReportServer的報表伺服器資料庫中。 SQL 檢視會提供執行記錄資訊。 "2" 和 "3" 檢視是在較新版本中新增,而且包含新欄位或是名稱比舊版更易記的欄位。 舊版檢視仍然保留在產品中,因此相依於這些檢視的自訂應用程式不受影響。 如果您沒有舊版檢視 (例如 ExecutionLog) 的相依性,您應當使用最新檢視 ExecutionLog3

SharePoint 模式報表伺服器的組態設定

您可以從 Reporting Services 服務應用程式的 [系統設定] 開啟或關閉報表執行記錄。

根據預設,記錄項目會保留 60 天。 超過此天數的項目會在每天上午 2:00 移除。 在到期的安裝上,不論何時都只能取得 60 天的資訊。

您無法針對資料列數目或記錄的項目類型設定限制。

啟用 SharePoint 伺服器的執行記錄

  1. 從 [SharePoint 管理中心] 的 [應用程式管理] 群組中,選取 [管理服務應用程式]。

  2. 選中您想要設定之 Reporting Services 服務應用程式的名稱。

  3. 選取系統設定

  4. 選取 [記錄] 區段中的 [啟用執行記錄]。

  5. 選取 [確定]。

啟用 SharePoint 伺服器的詳細資訊記錄

您必須依照先前步驟的說明啟用記錄,然後完成下列步驟:

  1. 在 Reporting Services 服務應用程式的 [系統設定] 頁面中,尋找 [使用者定義] 區段。

  2. 將 [ExecutionLogLevel] 變更為 [verbose]。 這個欄位是文字輸入欄位,而且兩個可能的值為 [verbose] 和 [normal]。

原生模式報表伺服器的組態設定

您可以從 SQL Server Management Studio 的 [伺服器屬性] 頁面開啟或關閉報表執行記錄。 EnableExecutionLogging 是進階内容。

根據預設,記錄項目會保留 60 天。 超過此天數的項目會在每天上午 2:00 移除。 在到期的安裝上,不論何時都只能取得 60 天的資訊。

您無法針對資料列數目或記錄的項目類型設定限制。

啟用原生模式伺服器的執行記錄

  1. 使用系統管理權限來啟動 SQL Server Management Studio。 例如,以滑鼠右鍵按一下 Management Studio 圖示,然後選取 [以系統管理員身分執行]。

  2. 連接到所需的報表伺服器。

  3. 以滑鼠右鍵按一下伺服器名稱,然後選取 [內容] 。 如果 [屬性] 選項已停用,請確認您已使用系統管理權限來啟動 SQL Server Management Studio。

  4. 選取 [記錄] 頁面。

  5. 選取 [啟用報表執行記錄]。

啟用原生模式伺服器的詳細資訊記錄

您必須依照先前步驟的說明啟用記錄,然後完成下列步驟:

  1. 在 [伺服器屬性] 對話方塊中,選取 [進階] 頁面。

  2. 在 [使用者定義] 區段中,將 [ExecutionLogLevel] 變更為 [verbose]。 這個欄位是文字輸入欄位,而且兩個可能的值為 [verbose] 和 [normal]。

    [伺服器內容] 對話框的螢幕擷取畫面,其中醒目提示 ExecutionLogLevel 欄位設定為詳細資訊。

記錄欄位 (ExecutionLog3)

這個檢視會在 XML 架構的 AdditionalInfo 資料行內加入其他效能診斷節點。 AdditionalInfo 資料行包含的 XML 結構是由 1 至多個資訊欄位所組成。 下面是可從 ExecutionLog3 檢視中擷取資料列的範例 Transact SQL 陳述式。 此範例會假設報表伺服器資料庫名為 ReportServer:

Use ReportServer  
select * from ExecutionLog3 order by TimeStart DESC  

下表描述在報表執行記錄中擷取的資料。

資料行 描述
InstanceName 處理要求的報表伺服器執行個體名稱。 如果您的環境具有多個報表伺服器,您可以分析 InstanceName 散發以監視並判斷網路負載平衡器是否依照預期方式在報表伺服器之間散發要求。
ItemPath 儲存報表或報表項目的路徑。
UserName 使用者識別碼。
ExecutionID 與要求相關聯的內部識別碼。 相同使用者工作階段上的要求會共用相同的執行 ID。
RequestType 可能的值如下:

互動式

訂用帳戶



分析依 RequestType=Subscription 所篩選並且依 TimeStart 所排序的記錄資料可能會顯現訂閱使用量龐大的週期,而且您可能會想要將某些報表訂閱修改成不同的時間。
[格式] 轉譯格式。
參數 報表執行所使用的參數值。
ItemAction 可能的值:

Render

Sort

BookMarkNavigation

DocumentNavigation

GetDocumentMap

Findstring

Execute

RenderEdit.
TimeStart 指出報表處理持續期間的開始與結束時間。
TimeEnd
TimeDataRetrieval 擷取資料所花費的毫秒數。
TimeProcessing 處理報表所花費的毫秒數。
TimeRendering 轉譯報表所花費的毫秒數。
來源 報表執行的來源。 可能的值:

即時

Cache:表示快取的執行作業,例如資料集查詢不會以即時方式執行。

快照式

記錄

臨機操作:指出動態產生的報表模型型鑽研報表。 它也可以參考使用報表伺服器處理和轉譯之用戶端上預覽的報表產生器報表。

Session:表示已建立工作階段內的後續要求。 例如,初始要求是檢視頁面 1,而後續要求則是匯出到 Excel (包含目前的工作階段狀態)。

報告定義自訂延伸項目 (RDCE):表示報告定義自訂。 RDCE 自訂延伸模組可以動態地自訂報表定義,然後在執行報表時將定義傳遞至處理引擎。
狀態 狀態 (不是 rsSuccess 就是錯誤碼;如果發生多個錯誤,就只會記錄第一個錯誤)。
ByteCount 轉譯報表的大小 (以位元組為單位)。
RowCount 從查詢傳回的資料列數目。
AdditionalInfo XML 屬性包,其中包含有關執行的其他資訊。 每個資料列的內容可能都不同。

AdditionalInfo 欄位

AdditionalInfo 欄位是一種 XML 屬性包或結構,其中包含有關執行的其他資訊。 記錄中每個資料列的內容可能都不同。

以下是標準和詳細資訊記錄中,AddtionalInfo 欄位內容的範例:

AddtionalInfo 的標準記錄範例

<AdditionalInfo>  
  <ProcessingEngine>2</ProcessingEngine>  
  <ScalabilityTime>  
    <Pagination>0</Pagination>  
    <Processing>0</Processing>  
  </ScalabilityTime>  
  <EstimatedMemoryUsageKB>  
    <Pagination>0</Pagination>  
    <Processing>6</Processing>  
  </EstimatedMemoryUsageKB>  
  <DataExtension>  
    <SQL>1</SQL>  
  </DataExtension>  
  <Connections>  
    <Connection>  
      <ConnectionOpenTime>147</ConnectionOpenTime>  
      <DataSets>  
        <DataSet>  
          <Name>DataSet1</Name>  
          <RowsRead>16</RowsRead>  
          <TotalTimeDataRetrieval>642</TotalTimeDataRetrieval>  
          <ExecuteReaderTime>63</ExecuteReaderTime>  
        </DataSet>  
        <DataSet>  
          <Name>DataSet2</Name>  
          <RowsRead>3</RowsRead>  
          <TotalTimeDataRetrieval>157</TotalTimeDataRetrieval>  
          <ExecuteReaderTime>60</ExecuteReaderTime>  
        </DataSet>  
      </DataSets>  
    </Connection>  
  </Connections>  
</AdditionalInfo>

AdditionalInfo 的詳細資訊記錄範例

<AdditionalInfo>  
  <ProcessingEngine>2</ProcessingEngine>  
  <ScalabilityTime>  
    <Pagination>0</Pagination>  
    <Processing>0</Processing>  
  </ScalabilityTime>  
  <EstimatedMemoryUsageKB>  
    <Pagination>0</Pagination>  
    <Processing>6</Processing>  
  </EstimatedMemoryUsageKB>  
  <DataExtension>  
    <SQL>1</SQL>  
  </DataExtension>  
  <Connections>  
    <Connection>  
      <ConnectionOpenTime>127</ConnectionOpenTime>  
      <DataSource>  
        <Name>DataSource1</Name>  
        <DataExtension>SQL</DataExtension>  
      </DataSource>  
      <DataSets>  
        <DataSet>  
          <Name>DataSet1</Name>  
          <RowsRead>16</RowsRead>  
          <TotalTimeDataRetrieval>655</TotalTimeDataRetrieval>  
          <QueryPrepareAndExecutionTime>94</QueryPrepareAndExecutionTime>  
          <ExecuteReaderTime>33</ExecuteReaderTime>  
          <DataReaderMappingTime>30</DataReaderMappingTime>  
          <DisposeDataReaderTime>1</DisposeDataReaderTime>  
        </DataSet>  
        <DataSet>  
          <Name>DataSet2</Name>  
          <RowsRead>3</RowsRead>  
          <TotalTimeDataRetrieval>16</TotalTimeDataRetrieval>  
          <QueryPrepareAndExecutionTime>2</QueryPrepareAndExecutionTime>  
          <ExecuteReaderTime>1</ExecuteReaderTime>  
          <DataReaderMappingTime>0</DataReaderMappingTime>  
          <DisposeDataReaderTime>0</DisposeDataReaderTime>  
        </DataSet>  
      </DataSets>  
    </Connection>  
  </Connections>  
</AdditionalInfo>

以下範例是您可以在 AdditionalInfo 欄位中看見的一些值:

  • ProcessingEngine

    如果大部分報表仍然顯示 1 值,可以調查重新設計報表的方式,使報表都利用較新且更有效率的視需要處理引擎。

    1=SQL Server 2005, 2=The new On-demand Processing Engine
    
    <ProcessingEngine>2</ProcessingEngine>
    
  • ScalabilityTime

    在處理引擎中執行延展相關作業所花費的毫秒數。 0 值表示沒有針對延展作業花費任何額外時間,而且 0 也表示要求沒有承受記憶體不足的壓力。

    <ScalabilityTime>  
        <Processing>0</Processing>  
    </ScalabilityTime>  
    
  • EstimatedMemoryUsageKB

    在特定要求期間,每個元件所耗用之記憶體尖峰數量的估計值 (以 KB 為單位)。

    <EstimatedMemoryUsageKB>  
        <Processing>38</Processing>  
    </EstimatedMemoryUsageKB>  
    
  • DataExtension

    用於報表之資料延伸模組或資料來源的類型。 其數字為特定資料來源的出現次數。

    <DataExtension>  
       <DAX>2</DAX>  
    </DataExtension>  
    
  • ExternalImages

    值會以毫秒來表示。 此資料可用來診斷效能問題。 從外部 Web 伺服器擷取影像所需的時間可能會讓整體報表執行變慢。

    <ExternalImages>  
        <Count>3</Count>  
        <ByteCount>9268</ByteCount>  
        <ResourceFetchTime>9</ResourceFetchTime>  
    </ExternalImages>  
    
  • 連線

    多層結構

    <Connections>  
        <Connection>  
          <ConnectionOpenTime>127</ConnectionOpenTime>  
          <DataSource>  
            <Name>DataSource1</Name>  
            <DataExtension>SQL</DataExtension>  
          </DataSource>  
          <DataSets>  
            <DataSet>  
              <Name>DataSet1</Name>  
              <RowsRead>16</RowsRead>  
              <TotalTimeDataRetrieval>655</TotalTimeDataRetrieval>  
              <QueryPrepareAndExecutionTime>94</QueryPrepareAndExecutionTime>  
              <ExecuteReaderTime>33</ExecuteReaderTime>  
              <DataReaderMappingTime>30</DataReaderMappingTime>  
              <DisposeDataReaderTime>1</DisposeDataReaderTime>  
            </DataSet>  
            <DataSet>  
              <Name>DataSet2</Name>  
              <RowsRead>3</RowsRead>  
              <TotalTimeDataRetrieval>16</TotalTimeDataRetrieval>  
              <QueryPrepareAndExecutionTime>2</QueryPrepareAndExecutionTime>  
              <ExecuteReaderTime>1</ExecuteReaderTime>  
              <DataReaderMappingTime>0</DataReaderMappingTime>  
              <DisposeDataReaderTime>0</DisposeDataReaderTime>  
            </DataSet>  
          </DataSets>  
        </Connection>  
    </Connections>  
    
    

記錄欄位 (ExecutionLog2)

這個檢視加入了一些新欄位並且重新命名了一些其他欄位。 下面的範例是可從 ExecutionLog2 檢視中擷取資料列的 Transact SQL 陳述式。 此範例會假設報表伺服器資料庫名為 ReportServer

Use ReportServer  
select * from ExecutionLog2 order by TimeStart DESC  

下表描述在報表執行記錄中擷取的資料。

資料行 描述
InstanceName 處理要求的報表伺服器執行個體名稱。
ReportPath 報表的路徑結構。 儲存在根資料夾中名為 test 的報表包含 /test 的 ReportPath。

儲存在資料夾 Samples 中名為 test 的報表,可能包含 /Samples/test/ 的 ReportPath。
UserName 使用者識別碼。
ExecutionID
RequestType 要求類型為 usersystem
[格式] 轉譯格式。
參數 報表執行所使用的參數值。
ReportAction 可能的值:RenderSortBookMarkNavigationDocumentNavigationGetDocumentMapFindstring
TimeStart 指出報表處理持續期間的開始時間。
TimeEnd 指出報表處理持續期間的結束時間。
TimeDataRetrieval 擷取資料所花費的毫秒數。
TimeProcessing 處理報表所花費的毫秒數。
TimeRendering 轉譯報表所花費的毫秒數。
來源 報表執行的來源。 選項為 1=Live2=Cache3=Snapshot4=History
狀態 狀態為 rsSuccess 或錯誤碼。 如果發生多個錯誤,只會記錄第一個錯誤。
ByteCount 轉譯報表的大小 (以位元組為單位)。
RowCount 從查詢傳回的資料列數目。
AdditionalInfo XML 屬性包,其中包含有關執行的其他資訊。

記錄欄位 (ExecutionLog)

下面的範例是可從 ExecutionLog 檢視中擷取資料列的 Transact SQL 陳述式。 此範例會假設報表伺服器資料庫名為 ReportServer

Use ReportServer  
select * from ExecutionLog order by TimeStart DESC

下表描述在報表執行記錄中擷取的資料。

資料行 描述
InstanceName 處理要求的報表伺服器執行個體名稱。
ReportID 報表識別碼。
UserName 使用者識別碼。
RequestType 可能的值:

True= 訂閱要求

False= 互動式要求
[格式] 轉譯格式。
參數 報表執行所使用的參數值。
TimeStart 指出報表處理持續期間的開始與結束時間。
TimeEnd
TimeDataRetrieval 擷取資料、處理報表和轉譯報表所花費的毫秒數。
TimeProcessing
TimeRendering
來源 報表執行的來源。 可能的值:(1= 即時、2= 快取、3= 快照集、4= 歷程記錄、5= 特定、6= 工作階段、7= RDCE)。
狀態 可能的值為 rsSuccessrsProcessingAborted 或錯誤碼。 如果發生多個錯誤,只會記錄第一個錯誤。
ByteCount 轉譯報表的大小 (以位元組為單位)。
RowCount 從查詢傳回的資料列數目。