共用方式為


在 Azure 資料總管叢集上設定串流擷取

當您在擷取和查詢之間需要低延遲時,串流擷取對於載入數據很有用。 請考慮在下列案例中使用串流擷取:

  • 需要少於一秒的延遲。
  • 若要優化許多數據表的作業處理,其中每個數據表的數據串流相對較小(每秒記錄數筆),但整體數據擷取量很高(每秒數千筆記錄)。

如果每個數據表中的數據串流很高(每小時超過 4 GB),請考慮使用 佇列擷取

若要深入瞭解不同的擷取方法,請參閱 數據擷取概觀

如需以舊版 SDK 為基礎的程式代碼範例,請參閱 封存一文

選擇適當的串流擷取類型

支援兩種串流擷取類型:

擷取類型 描述
資料連線 事件中樞、IoT 中樞 和事件方格數據連線可以使用串流擷取,前提是叢集層級已啟用。 根據目標數據表上設定的串流擷取原則,決定使用串流擷取。
如需管理數據連線的資訊,請參閱事件中樞IoT 中樞事件方格。
自定義擷取 自定義擷取需要您撰寫使用其中一個 Azure 數據 總管客戶端連結庫的應用程式。
使用本主題中的資訊來設定自定義擷取。 您也可以找到 C?view=azure-data-explorer&preserve-view=true# 串流擷取範例應用程式 很有説明。

使用下表可協助您選擇適合您環境的擷取類型:

準則 資料連線 自定義擷取
擷取起始與可供查詢的數據之間的數據延遲 較長的延遲時間 較短的延遲
開發額外負荷 快速且容易設定,不需要開發額外負荷 建立應用程式擷取數據、處理錯誤並確保數據一致性的高開發額外負荷

注意

您可以使用 C# Azure 入口網站 或以程式設計方式,管理在叢集上啟用和停用串流擷取的程式。 如果您使用 C# 進行 自訂應用程式,您可能會發現使用程式設計方法更方便。

必要條件

效能和作業考慮

可能會影響串流擷取的主要參與者包括:

  • VM 和叢集大小:隨著 VM 和叢集大小增加,串流擷取效能和容量調整。 並行擷取要求的數目限制為每個核心6個。 例如,對於16個核心SKU,例如 D14 和 L16,最大支援的負載是96個並行擷取要求。 對於兩個核心 SKU,例如 D11,最大支援的負載是 12 個並行擷取要求。
  • 數據大小限制:串流擷取要求的數據大小限製為4 MB。 這包括在擷取期間針對更新原則建立的任何數據。
  • 架構更新:串流擷取服務最多可能需要五分鐘的時間,例如建立和修改數據表和擷取對應等架構更新。 如需詳細資訊,請參閱 串流擷取和架構變更
  • SSD 容量:在叢集上啟用串流擷取,即使數據未透過串流擷取,也會使用叢集機器的本機 SSD 磁碟部分來串流擷取數據,並減少可供經常性快取使用的記憶體。

在您的叢集上啟用串流擷取

您必須先在叢集上啟用功能,並定義 串流擷取原則,才能使用串流擷取。 您可以在建立叢集時啟用此功能,或將其新增至現有的叢集

警告

啟用串流擷取之前, 請先檢閱限制

在建立新的叢集時啟用串流擷取

您可以使用 Azure 入口網站 或在 C# 中以程式設計方式建立新的叢集時,啟用串流擷取。

使用建立 Azure 數據總管叢集和資料庫中的步驟建立叢集時,請在 [組態] 索引標籤中,選取 [串流擷取>開啟]。

在 Azure 數據總管中建立叢集時啟用串流擷取。

在現有叢集上啟用串流擷取

如果您有現有的叢集,您可以使用 Azure 入口網站 或在 C# 中以程式設計方式啟用串流擷取。

  1. 在 Azure 入口網站 中,移至您的 Azure 數據總管叢集。

  2. 在 [設定] 中,選取 [組態]。

  3. 在 [ 組態 ] 窗格中,選取 [開啟 ] 以啟用 串流擷取

  4. 選取儲存

    在 Azure 數據總管中開啟串流擷取。

建立目標數據表並定義原則

建立數據表以接收串流擷取數據,並使用 C# Azure 入口網站 或以程式設計方式定義其相關原則。

  1. 在 Azure 入口網站中瀏覽至您的叢集。

  2. 選取查詢

    在 Azure 數據總管入口網站中選取查詢,以啟用串流擷取。

  3. 若要建立將透過串流擷取接收數據的數據表,請將下列命令 複製到 [查詢] 窗格中 ,然後選取 [ 執行]。

    .create table TestTable (TimeStamp: datetime, Name: string, Metric: int, Source:string)
    

    建立數據表以串流擷取至 Azure 數據總管。

  4. 將下列其中一個命令複製到 [ 查詢] 窗格中 ,然後選取 [ 執行]。 這會定義 您所建立數據表或包含數據表的資料庫上的串流擷取 原則。

    提示

    在資料庫層級定義的原則會套用至資料庫中所有現有和未來的數據表。 當您在資料庫層級啟用原則時,不需要為每個數據表啟用它。

    • 若要在您所建立的數據表上定義原則,請使用:

      .alter table TestTable policy streamingingestion enable
      
    • 若要在包含您所建立數據表的資料庫上定義原則,請使用:

      .alter database StreamingTestDb policy streamingingestion enable
      

    在 Azure 數據總管中定義串流擷取原則。

建立串流擷取應用程式以將數據內嵌至叢集

使用慣用的語言,建立應用程式以將數據內嵌至叢集。

using System.IO;
using System.Threading.Tasks;
using Kusto.Data; // Requires Package Microsoft.Azure.Kusto.Data
using Kusto.Data.Common;
using Kusto.Ingest; // Requires Package Microsoft.Azure.Kusto.Ingest
namespace StreamingIngestion;
class Program
{
    static async Task Main(string[] args)
    {
        var clusterPath = "https://<clusterName>.<region>.kusto.windows.net";
        var appId = "<appId>";
        var appKey = "<appKey>";
        var appTenant = "<appTenant>";
        // Create Kusto connection string with App Authentication
        var connectionStringBuilder = new KustoConnectionStringBuilder(clusterPath)
            .WithAadApplicationKeyAuthentication(
                applicationClientId: appId,
                applicationKey: appKey,
                authority: appTenant
            );
        // Create a disposable client that will execute the ingestion
        using var client = KustoIngestFactory.CreateStreamingIngestClient(connectionStringBuilder);
        // Ingest from a compressed file
        var fileStream = File.Open("MyFile.gz", FileMode.Open);
        // Initialize client properties
        var ingestionProperties = new KustoIngestionProperties(databaseName: "<databaseName>", tableName: "<tableName>");
        // Create source options
        var sourceOptions = new StreamSourceOptions { CompressionType = DataSourceCompressionType.gzip, };
        // Ingest from stream
        await client.IngestFromStreamAsync(fileStream, ingestionProperties, sourceOptions);
    }
}

停用叢集上的串流擷取

警告

停用串流擷取可能需要數小時的時間。

在 Azure 數據總管叢集上停用串流擷取之前,請先從所有相關數據表和資料庫卸 載串流擷取原則 。 拿掉串流擷取原則會觸發 Azure 數據總管叢集內的數據重新排列。 串流擷取數據會從初始記憶體移至數據行存放區中的永久記憶體(範圍或分區)。 此程式可能需要幾秒鐘到幾個小時的時間,視初始記憶體中的數據量而定。

卸除串流擷取原則

您可以使用 Azure 入口網站 或以程序設計方式在 C# 中卸載串流擷取原則。

  1. 在 Azure 入口網站 中,移至您的 Azure 數據總管叢集,然後選取 [查詢]。

  2. 若要從數據表卸除串流擷取原則,請將下列命令 複製到 [查詢] 窗格中 ,然後選取 [ 執行]。

    .delete table TestTable policy streamingingestion
    

    刪除 Azure 數據總管中的串流擷取原則。

  3. 在 [設定] 中,選取 [組態]。

  4. 在 [ 組態 ] 窗格中,選取 [ 關閉 ] 以停用 串流擷取

  5. 選取儲存

    關閉 Azure 數據總管中的串流擷取。

限制

  • 數據對應 必須 預先建立 ,才能用於串流擷取。 個別串流擷取要求無法容納內嵌數據對應。
  • 無法在串流擷取數據上設定範圍標籤
  • 更新原則。 更新原則只能參考來源資料表中新內嵌的資料,而不是資料庫中的任何其他資料或資料表。
  • 當具有交易式原則的更新原則失敗時,重試會回復為批次擷取。
  • 如果在做為追蹤者資料庫領導者的叢集上啟用串流擷取,則必須在下列叢集上啟用串流擷取,才能追蹤串流擷取數據。 同樣適用於叢集數據是否透過 Data Share 共用。