Aracılığıyla paylaş


Azure Veri Gezgini için veritabanı sorumluları ekleme

Azure Veri Gezgini, günlük ve telemetri verileri için hızlı ve üst düzeyde ölçeklenebilir veri keşfetme hizmetidir. Bu makalede C#, Python veya Azure Resource Manager (ARM) şablonu kullanarak Azure Veri Gezgini için veritabanı sorumluları eklemeyi öğreneceksiniz.

Önkoşullar

Önkoşullar, sorumluyu eklemek için kullanılan yönteme göre değişir. Tercih ettiğiniz yöntem için ilgili sekmeyi seçin.

Aşağıdaki listede C# ile küme sorumlusu ekleme önkoşulları özetlenmiştir.

Veritabanı sorumlusu ekleme

Veritabanı sorumlusu eklemek için aşağıdaki kodu çalıştırın:

var tenantId = "xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx"; //Directory (tenant) ID
var clientId = "xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx"; //Application ID
var clientSecret = "PlaceholderClientSecret"; //Client Secret
var subscriptionId = "xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx";
var credentials = new ClientSecretCredential(tenantId, clientId, clientSecret);
var resourceManagementClient = new ArmClient(credentials, subscriptionId);
var resourceGroupName = "testrg";
//The cluster that is created as part of the Prerequisites
var clusterName = "mykustocluster";
var databaseName = "mykustodatabase";
var subscription = await resourceManagementClient.GetDefaultSubscriptionAsync();
var resourceGroup = (await subscription.GetResourceGroupAsync(resourceGroupName)).Value;
var cluster = (await resourceGroup.GetKustoClusterAsync(clusterName)).Value;
var database = (await cluster.GetKustoDatabaseAsync(databaseName)).Value;
var databasePrincipalAssignments = database.GetKustoDatabasePrincipalAssignments();
var databasePrincipalAssignmentName = "mykustodatabaseprincipalassignment";
var principalId = "xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx"; //User email, application ID, or security group name
var role = KustoDatabasePrincipalRole.Admin; //Admin, Ingestor, Monitor, User, UnrestrictedViewers, Viewer
var tenantIdForPrincipal = new Guid("xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx");
var principalType = KustoPrincipalAssignmentType.App; //User, App, or Group
var databasePrincipalAssignmentData = new KustoDatabasePrincipalAssignmentData
{
    DatabasePrincipalId = principalId, Role = role, PrincipalType = principalType, TenantId = tenantIdForPrincipal
};
await databasePrincipalAssignments.CreateOrUpdateAsync(
    WaitUntil.Completed, databasePrincipalAssignmentName, databasePrincipalAssignmentData
);
Ayar Önerilen değer Alan açıklaması
tenantId xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx Kiracı kimliğiniz. Dizin kimliği olarak da bilinir.
subscriptionId xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx Kaynak oluşturmak için kullandığınız abonelik kimliği.
clientId xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx Kiracınızdaki kaynaklara erişebilen uygulamanın istemci kimliği.
clientSecret PlaceholderClientSecret Kiracınızdaki kaynaklara erişebilen uygulamanın istemci gizli dizisi.
resourceGroupName testrg Kümenizi içeren kaynak grubunun adı.
clusterName mykustocluster Kümenizin adı.
veritabanıAdı mykustodatabase Veritabanınızın adı.
databasePrincipalAssignmentName mykustodatabaseprincipalassignment Veritabanı asıl kaynağınızın adı.
principalId xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx Kullanıcı e-postası, uygulama kimliği veya güvenlik grubu adı olabilecek asıl kimlik.
rol Yönetici 'Yönetici', 'Ingestor', 'İzleyici', 'User', 'UnrestrictedViewers', 'Viewer' olabilecek veritabanı sorumlunuzun rolü.
tenantIdForPrincipal xxxxxxxx-xxxxx-xxxx-xxxx-xxxxxxxxx Sorumlunun kiracı kimliği.
principalType Uygulama 'Kullanıcı', 'Uygulama' veya 'Grup' olabilecek sorumlunun türü