Dela via


Integrera Azure Cache for Redis med Service Connector

Den här sidan visar autentiseringsmetoder och klienter som stöds och visar exempelkod som du kan använda för att ansluta Azure Cache for Redis till andra molntjänster med hjälp av Service Connector. Du kanske fortfarande kan ansluta till Azure Cache for Redis på andra programmeringsspråk utan att använda Service Connector. På den här sidan visas även standardnamn och värden för miljövariabler (eller Spring Boot-konfiguration) som du får när du skapar tjänstanslutningen.

Beräkningstjänster som stöds

Service Connector kan användas för att ansluta följande beräkningstjänster till Azure Cache for Redis:

  • Azure App Service
  • Azure Container Apps
  • Azure Functions
  • Azure Kubernetes Service (AKS)
  • Azure Spring Apps

Autentiseringstyper och klienttyper som stöds

Tabellen nedan visar vilka kombinationer av autentiseringsmetoder och klienter som stöds för att ansluta beräkningstjänsten till Azure Cache for Redis med hjälp av Service Connector. Ett "Ja" anger att kombinationen stöds, medan ett "Nej" anger att den inte stöds.

Klienttyp Systemtilldelad hanterad identitet Användartilldelad hanterad identitet Hemlighet/anslutningssträng Tjänstens huvudnamn
.NET Ja Ja Ja Ja
Go Nej Nej Ja Nej
Java Ja Ja Ja Ja
Java – Spring Boot Nej Nej Ja Nej
Node.js Ja Ja Ja Ja
Python Ja Ja Ja Ja
None Ja Ja Ja Ja

Den här tabellen anger att den enda autentiseringsmetod som stöds för alla klienttyper i tabellen är metoden Hemlighet/anslutningssträng. Andra autentiseringsmetoder stöds inte för någon av klienttyperna för att ansluta till Azure Cache for Redis med hjälp av Service Connector.

Standardnamn för miljövariabler eller programegenskaper och exempelkod

Använd miljövariabelnamnen och programegenskaperna nedan för att ansluta beräkningstjänster till Redis Server. För varje exempel nedan ersätter du platshållartexterna <redis-server-name>och <redis-key> med ditt eget Redis-servernamn och -nyckel. Mer information om namngivningskonventioner finns i artikeln interna serviceanslutningsprogram .

Systemtilldelad hanterad identitet

Standardnamn för miljövariabel beskrivning Exempelvärde
AZURE_REDIS_HOST Redis-slutpunkt <RedisName>.redis.cache.windows.net

Exempelkod

Se stegen och koden nedan för att ansluta till Redis med hjälp av en systemtilldelad hanterad identitet.

  1. Installera beroenden.

    dotnet add package Microsoft.Azure.StackExchangeRedis --version 3.2.0
    
  2. Lägg till autentiseringslogik med miljövariabler som anges av Service Connector. Mer information finns i Microsoft.Azure.StackExchangeRedis-tillägget.

    using StackExchange.Redis;
    var cacheHostName = Environment.GetEnvironmentVariable("AZURE_REDIS_HOST");
    var configurationOptions = ConfigurationOptions.Parse($"{cacheHostName}:6380");
    
    // Uncomment the following lines corresponding to the authentication type you want to use.
    // For system-assigned identity.
    // await configurationOptions.ConfigureForAzureWithTokenCredentialAsync(new DefaultAzureCredential());
    
    // For user-assigned identity.
    // var managedIdentityClientId = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTID");
    // await configurationOptions.ConfigureForAzureWithUserAssignedManagedIdentityAsync(managedIdentityClientId);
    
    // Service principal secret
    // var clientId = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTID");
    // var tenantId = Environment.GetEnvironmentVariable("AZURE_REDIS_TENANTID");
    // var secret = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTSECRET");
    // await configurationOptions.ConfigureForAzureWithServicePrincipalAsync(clientId, tenantId, secret);
    
    
    var connectionMultiplexer = await ConnectionMultiplexer.ConnectAsync(configurationOptions);
    

Användartilldelad hanterad identitet

Standardnamn för miljövariabel beskrivning Exempelvärde
AZURE_REDIS_HOST Redis-slutpunkt <RedisName>.redis.cache.windows.net
AZURE_REDIS_CLIENTID klient-ID för hanterad identitet <client-ID>

Exempelkod

Se stegen och koden nedan för att ansluta till Redis med hjälp av en användartilldelad hanterad identitet.

  1. Installera beroenden.

    dotnet add package Microsoft.Azure.StackExchangeRedis --version 3.2.0
    
  2. Lägg till autentiseringslogik med miljövariabler som anges av Service Connector. Mer information finns i Microsoft.Azure.StackExchangeRedis-tillägget.

    using StackExchange.Redis;
    var cacheHostName = Environment.GetEnvironmentVariable("AZURE_REDIS_HOST");
    var configurationOptions = ConfigurationOptions.Parse($"{cacheHostName}:6380");
    
    // Uncomment the following lines corresponding to the authentication type you want to use.
    // For system-assigned identity.
    // await configurationOptions.ConfigureForAzureWithTokenCredentialAsync(new DefaultAzureCredential());
    
    // For user-assigned identity.
    // var managedIdentityClientId = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTID");
    // await configurationOptions.ConfigureForAzureWithUserAssignedManagedIdentityAsync(managedIdentityClientId);
    
    // Service principal secret
    // var clientId = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTID");
    // var tenantId = Environment.GetEnvironmentVariable("AZURE_REDIS_TENANTID");
    // var secret = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTSECRET");
    // await configurationOptions.ConfigureForAzureWithServicePrincipalAsync(clientId, tenantId, secret);
    
    
    var connectionMultiplexer = await ConnectionMultiplexer.ConnectAsync(configurationOptions);
    

Anslutningssträng

Varning

Microsoft rekommenderar att du använder det säkraste tillgängliga autentiseringsflödet. Det autentiseringsflöde som beskrivs i den här proceduren kräver mycket stort förtroende för programmet och medför risker som inte finns i andra flöden. Du bör bara använda det här flödet när andra säkrare flöden, till exempel hanterade identiteter, inte är livskraftiga.

Standardnamn för miljövariabel beskrivning Exempelvärde
AZURE_REDIS_CONNECTIONSTRING StackExchange. Redis anslutningssträng <redis-server-name>.redis.cache.windows.net:6380,password=<redis-key>,ssl=True,defaultDatabase=0

Exempelkod

Se stegen och koden nedan för att ansluta till Azure Cache for Redis med hjälp av en anslutningssträng.

  1. Installera beroenden.

    dotnet add package StackExchange.Redis --version 2.6.122
    
  2. Hämta anslutningssträng från miljövariabeln som lagts till av Service Connector.

    using StackExchange.Redis;
    var connectionString = Environment.GetEnvironmentVariable("AZURE_REDIS_CONNECTIONSTRING");
    var _redisConnection = await RedisConnection.InitializeAsync(connectionString: connectionString);
    

Tjänstens huvudnamn

Standardnamn för miljövariabel beskrivning Exempelvärde
AZURE_REDIS_HOST Redis-slutpunkt <RedisName>.redis.cache.windows.net
AZURE_REDIS_CLIENTID klient-ID för tjänstens huvudnamn <client-ID>
AZURE_REDIS_CLIENTSECRET hemlighet för tjänstens huvudnamn <client-secret>
AZURE_REDIS_TENANTID klientorganisations-ID för tjänstens huvudnamn <tenant-id>

Exempelkod

Se stegen och koden nedan för att ansluta till Redis med hjälp av tjänstens huvudnamn.

  1. Installera beroenden.

    dotnet add package Microsoft.Azure.StackExchangeRedis --version 3.2.0
    
  2. Lägg till autentiseringslogik med miljövariabler som anges av Service Connector. Mer information finns i Microsoft.Azure.StackExchangeRedis-tillägget.

    using StackExchange.Redis;
    var cacheHostName = Environment.GetEnvironmentVariable("AZURE_REDIS_HOST");
    var configurationOptions = ConfigurationOptions.Parse($"{cacheHostName}:6380");
    
    // Uncomment the following lines corresponding to the authentication type you want to use.
    // For system-assigned identity.
    // await configurationOptions.ConfigureForAzureWithTokenCredentialAsync(new DefaultAzureCredential());
    
    // For user-assigned identity.
    // var managedIdentityClientId = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTID");
    // await configurationOptions.ConfigureForAzureWithUserAssignedManagedIdentityAsync(managedIdentityClientId);
    
    // Service principal secret
    // var clientId = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTID");
    // var tenantId = Environment.GetEnvironmentVariable("AZURE_REDIS_TENANTID");
    // var secret = Environment.GetEnvironmentVariable("AZURE_REDIS_CLIENTSECRET");
    // await configurationOptions.ConfigureForAzureWithServicePrincipalAsync(clientId, tenantId, secret);
    
    
    var connectionMultiplexer = await ConnectionMultiplexer.ConnectAsync(configurationOptions);
    

Nästa steg

Följ självstudierna nedan om du vill veta mer om Service Connector.