Udostępnij za pośrednictwem


Hello Kusto: Tworzenie pierwszej aplikacji

Dotyczy: ✅Microsoft FabricAzure Data Explorer

Z tego artykułu dowiesz się, jak wykonywać następujące działania:

  • Tworzenie pierwszej aplikacji klienckiej
  • Korzystanie z uwierzytelniania interakcyjnego
  • Uruchom podstawowe zapytanie, które wyświetla Hello Kusto!

Warunki wstępne

Skonfiguruj środowisko deweloperskie do korzystania z biblioteki klienta Kusto.

Tworzenie aplikacji

W preferowanym środowisku IDE lub edytorze tekstów utwórz projekt lub plik o nazwie hello kusto przy użyciu konwencji odpowiedniej dla preferowanego języka. Następnie dodaj następujący kod:

  1. Dodaj klasy klienta Kusto i StringBuilder.

    using Kusto.Data;
    using Kusto.Data.Net.Client;
    
  2. Zdefiniuj pustą funkcję o nazwie main i wywołaj ją.

    namespace HelloKusto {
      class HelloKusto {
        static void Main(string[] args) {
        }
      }
    }
    
  3. Utwórz obiekt konstruktora parametrów połączenia, który definiuje identyfikator URI klastra i ustawia tryb uwierzytelniania na interakcyjny. Aby uzyskać więcej informacji na temat identyfikatora URI klastra, zobacz parametry połączenia usługi Kusto.

    var clusterUri = "https://help.kusto.windows.net/";
    var kcsb = new KustoConnectionStringBuilder(clusterUri).WithAadUserPromptAuthentication();
    

    Notatka

    Do uwierzytelniania interakcyjnego potrzebne jest konto Microsoft lub tożsamość użytkownika Entra firmy Microsoft. Subskrypcja platformy Azure nie jest wymagana.

    W języku C# proces uwierzytelniania interakcyjnego może nie wyświetlać monitu do użytkownika, jeśli:

    • Użytkownik jest już uwierzytelniony na urządzeniu
    • Na urządzeniu istnieje uwierzytelnianie w interfejsie webowym Kusto Explorer lub Azure Data Explorer.
  4. Utwórz obiekt klienta, który używa obiektu konstruktora parametrów połączenia w celu nawiązania połączenia z klastrem.

    Notatka

    Zdecydowanie zalecamy buforowanie i ponowne użycie wystąpienia klienta Kusto. Częste ponowne tworzenie klientów Kusto może prowadzić do obniżenia wydajności aplikacji i zwiększenia obciążenia klastra.

    using (var kustoClient = KustoClientFactory.CreateCslQueryProvider(kcsb)) {
    }
    
  5. Zdefiniuj bazę danych i zapytanie do uruchomienia. Zapytanie wyświetla Hello Kusto! w kolumnie o nazwie Welcome.

    var database = "Samples";
    var query = "print Welcome='Hello Kusto!'";
    
  6. Uruchom zapytanie i wyświetl wynik.

    using (var response = kustoClient.ExecuteQuery(database, query, null)) {
      response.Read();
      int columnNo = response.GetOrdinal("Welcome");
      Console.WriteLine(response.GetString(columnNo));
    }
    

    Notatka

    Dane wyjściowe zapytania są zwracane w odpowiedzi jako obiekt zawierający co najmniej jedną tabelę składającą się z więcej wierszy i kolumn. Format obiektu zależy od języka biblioteki klienta.

    Kusto zapytanie zwraca tabelę z jednym wierszem i jedną kolumną.

    Odpowiedź to obiekt DataReader. Możesz odwołać się do wyniku w następujący sposób:

    • Użyj metody read() , aby odczytać pierwszy wiersz
    • Użyj metody GetString(), aby uzyskać wartość pierwszej kolumny

Pełny kod powinien wyglądać następująco:

using Kusto.Data;
using Kusto.Data.Net.Client;

namespace HelloKusto {
  class HelloKusto {
    static void Main(string[] args) {
      string clusterUri = "https://help.kusto.windows.net/";
      var kcsb = new KustoConnectionStringBuilder(clusterUri).WithAadUserPromptAuthentication();
    
      using (var kustoClient = KustoClientFactory.CreateCslQueryProvider(kcsb)) {
        string database = "Samples";
        string query = "print Welcome='Hello Kusto!'";

        using (var response = kustoClient.ExecuteQuery(database, query, null)) {
          response.Read();
          int columnNo = response.GetOrdinal("Welcome");
          Console.WriteLine(response.GetString(columnNo));
        }
      }
    }
  }
}

Uruchamianie aplikacji

W konsoli poleceń użyj następującego polecenia, aby uruchomić aplikację:

# Change directory to the folder that contains the hello world project
dotnet run .

Powinien zostać wyświetlony wynik podobny do następującego:

Hello Kusto!

Następny krok