Dela via


Automatisera rotationen av en hemlighet för resurser som använder en uppsättning autentiseringsuppgifter

Det bästa sättet att autentisera till Azure-tjänster är att använda en hanterad identitet, men det finns vissa scenarier där det inte är ett alternativ. I dessa fall används åtkomstnycklar eller hemligheter. Du bör regelbundet rotera åtkomstnycklar eller hemligheter.

Den här självstudien visar hur du automatiserar den periodiska rotationen av hemligheter för databaser och tjänster som använder en uppsättning autentiseringsuppgifter. Mer specifikt roterar den här självstudien SQL Server-lösenord som lagras i Azure Key Vault med hjälp av en funktion som utlöses av Azure Event Grid-meddelande:

Diagram över rotationslösning

  1. Trettio dagar före förfallodatumet för en hemlighet publicerar Key Vault händelsen "near expiry" till Event Grid.
  2. Event Grid kontrollerar händelseprenumerationerna och använder HTTP POST för att anropa funktionsappens slutpunkt som prenumererar på händelsen.
  3. Funktionsappen tar emot den hemliga informationen, genererar ett nytt slumpmässigt lösenord och skapar en ny version för hemligheten med det nya lösenordet i Key Vault.
  4. Funktionsappen uppdaterar SQL Server med det nya lösenordet.

Kommentar

Det kan finnas en fördröjning mellan steg 3 och 4. Under den tiden kommer hemligheten i Key Vault inte att kunna autentisera till SQL Server. Om något av stegen misslyckas försöker Event Grid igen i två timmar.

Förutsättningar

Om du inte har ett befintligt Key Vault och SQL Server kan du använda den här distributionslänken:

Bild som visar en knapp med etiketten

  1. Välj Skapa ny under Resursgrupp. Ge gruppen ett namn, vi använder akvrotation i den här självstudien.
  2. Under SQL-administratörsinloggning skriver du inloggningsnamnet för SQL-administratören.
  3. Välj Granska + skapa.
  4. Välj Skapa

Skapa en resursgrupp

Nu har du ett Key Vault och en SQL Server-instans. Du kan kontrollera den här konfigurationen i Azure CLI genom att köra följande kommando:

az resource list -o table -g akvrotation

Resultatet ser ut ungefär så här:

Name                     ResourceGroup         Location    Type                               Status
-----------------------  --------------------  ----------  ---------------------------------  --------
akvrotation-kv           akvrotation      eastus      Microsoft.KeyVault/vaults
akvrotation-sql          akvrotation      eastus      Microsoft.Sql/servers
akvrotation-sql/master   akvrotation      eastus      Microsoft.Sql/servers/databases
akvrotation-sql2         akvrotation      eastus      Microsoft.Sql/servers
akvrotation-sql2/master  akvrotation      eastus      Microsoft.Sql/servers/databases

Skapa och distribuera sql server-funktionen för lösenordsrotation

Viktigt!

Den här mallen kräver att nyckelvalvet, SQL-servern och Azure-funktionen finns i samma resursgrupp.

Skapa sedan en funktionsapp med en systemhanterad identitet, utöver de andra nödvändiga komponenterna, och distribuera SQL Server-funktioner för lösenordsrotation

Funktionsappen kräver följande komponenter:

  • En Azure App Service-plan
  • En funktionsapp med SQL-lösenordsroteringsfunktioner med händelseutlösare och http-utlösare
  • Ett lagringskonto som krävs för funktionsappens utlösarhantering
  • En åtkomstprincip för funktionsappsidentitet för åtkomst till hemligheter i Key Vault
  • En Event Grid-händelseprenumeration för SecretNearExpiry-händelse
  1. Välj distributionslänken för Azure-mallen:

    Bild som visar en knapp med etiketten

  2. I listan Resursgrupp väljer du akvrotation.

  3. I SQL Server-namnet skriver du SQL Server-namnet med lösenord för att rotera

  4. I Key Vault-namnet skriver du namnet på nyckelvalvet

  5. I funktionsappens namn skriver du funktionsappens namn

  6. I det hemliga namnet skriver du det hemliga namn där lösenordet ska lagras

  7. I webbadressen till lagringsplatsen skriver du funktionskoden GitHub-plats (https://github.com/Azure-Samples/KeyVault-Rotation-SQLPassword-Csharp.git)

  8. Välj Granska + skapa.

  9. Välj Skapa.

Välj Granska+skapa

När du har slutfört föregående steg har du ett lagringskonto, en servergrupp och en funktionsapp. Du kan kontrollera den här konfigurationen i Azure CLI genom att köra följande kommando:

az resource list -o table -g akvrotation

Resultatet ser ut ungefär så här:

Name                     ResourceGroup         Location    Type                               Status
-----------------------  --------------------  ----------  ---------------------------------  --------
akvrotation-kv           akvrotation       eastus      Microsoft.KeyVault/vaults
akvrotation-sql          akvrotation       eastus      Microsoft.Sql/servers
akvrotation-sql/master   akvrotation       eastus      Microsoft.Sql/servers/databases
cfogyydrufs5wazfunctions akvrotation       eastus      Microsoft.Storage/storageAccounts
akvrotation-fnapp        akvrotation       eastus      Microsoft.Web/serverFarms
akvrotation-fnapp        akvrotation       eastus      Microsoft.Web/sites
akvrotation-fnapp        akvrotation       eastus      Microsoft.insights/components

Information om hur du skapar en funktionsapp och använder hanterad identitet för att komma åt Key Vault finns i Skapa en funktionsapp från Azure-portalen, Använda hanterad identitet för App Service och Azure Functions och Tilldela en key vault-åtkomstprincip med hjälp av Azure-portalen.

Rotationsfunktion

Distribuerad i föregående steg-funktion använder en händelse för att utlösa rotationen av en hemlighet genom att uppdatera Key Vault och SQL-databasen.

Händelse för funktionsutlösare

Den här funktionen läser händelsedata och kör rotationslogik:

public static class SimpleRotationEventHandler
{
   [FunctionName("AKVSQLRotation")]
   public static void Run([EventGridTrigger]EventGridEvent eventGridEvent, ILogger log)
   {
      log.LogInformation("C# Event trigger function processed a request.");
      var secretName = eventGridEvent.Subject;
      var secretVersion = Regex.Match(eventGridEvent.Data.ToString(), "Version\":\"([a-z0-9]*)").Groups[1].ToString();
      var keyVaultName = Regex.Match(eventGridEvent.Topic, ".vaults.(.*)").Groups[1].ToString();
      log.LogInformation($"Key Vault Name: {keyVaultName}");
      log.LogInformation($"Secret Name: {secretName}");
      log.LogInformation($"Secret Version: {secretVersion}");

      SecretRotator.RotateSecret(log, secretName, keyVaultName);
   }
}

Hemlig rotationslogik

Den här rotationsmetoden läser databasinformation från hemligheten, skapar en ny version av hemligheten och uppdaterar databasen med den nya hemligheten:

    public class SecretRotator
    {
		private const string CredentialIdTag = "CredentialId";
		private const string ProviderAddressTag = "ProviderAddress";
		private const string ValidityPeriodDaysTag = "ValidityPeriodDays";

		public static void RotateSecret(ILogger log, string secretName, string keyVaultName)
        {
            //Retrieve Current Secret
            var kvUri = "https://" + keyVaultName + ".vault.azure.net";
            var client = new SecretClient(new Uri(kvUri), new DefaultAzureCredential());
            KeyVaultSecret secret = client.GetSecret(secretName);
            log.LogInformation("Secret Info Retrieved");

            //Retrieve Secret Info
            var credentialId = secret.Properties.Tags.ContainsKey(CredentialIdTag) ? secret.Properties.Tags[CredentialIdTag] : "";
            var providerAddress = secret.Properties.Tags.ContainsKey(ProviderAddressTag) ? secret.Properties.Tags[ProviderAddressTag] : "";
            var validityPeriodDays = secret.Properties.Tags.ContainsKey(ValidityPeriodDaysTag) ? secret.Properties.Tags[ValidityPeriodDaysTag] : "";
            log.LogInformation($"Provider Address: {providerAddress}");
            log.LogInformation($"Credential Id: {credentialId}");

            //Check Service Provider connection
            CheckServiceConnection(secret);
            log.LogInformation("Service  Connection Validated");
            
            //Create new password
            var randomPassword = CreateRandomPassword();
            log.LogInformation("New Password Generated");

            //Add secret version with new password to Key Vault
            CreateNewSecretVersion(client, secret, randomPassword);
            log.LogInformation("New Secret Version Generated");

            //Update Service Provider with new password
            UpdateServicePassword(secret, randomPassword);
            log.LogInformation("Password Changed");
            log.LogInformation($"Secret Rotated Successfully");
        }
}

Du hittar den fullständiga koden på GitHub.

Lägg till hemligheten i Key Vault

Ange din åtkomstprincip för att bevilja användare behörighet att hantera hemligheter :

az keyvault set-policy --upn <email-address-of-user> --name akvrotation-kv --secret-permissions set delete get list

Skapa en ny hemlighet med taggar som innehåller SQL Server-resurs-ID, SQL Server-inloggningsnamnet och giltighetsperioden för hemligheten i dagar. Ange namnet på hemligheten, det första lösenordet från SQL-databasen (i vårt exempel "Simple123") och inkludera ett förfallodatum som har angetts för morgondagen.

$tomorrowDate = (get-date).AddDays(+1).ToString("yyy-MM-ddThh:mm:ssZ")
az keyvault secret set --name sqlPassword --vault-name akvrotation-kv --value "Simple123" --tags "CredentialId=sqlAdmin" "ProviderAddress=<sql-database-resource-id>" "ValidityPeriodDays=90" --expires $tomorrowDate

Om du skapar en hemlighet med ett kort utgångsdatum publiceras en SecretNearExpiry händelse inom 15 minuter, vilket i sin tur utlöser funktionen för att rotera hemligheten.

Testa och verifiera

Om du vill kontrollera att hemligheten har roterats går du till Key Vault-hemligheter>:

Skärmbild som visar hur du får åtkomst till Key Vault-hemligheter > .

Öppna sqlPassword-hemligheten och visa de ursprungliga och roterade versionerna:

Gå till Hemligheter

Skapa en webbapp

Om du vill verifiera SQL-autentiseringsuppgifterna skapar du en webbapp. Den här webbappen hämtar hemligheten från Key Vault, extraherar SQL-databasinformation och autentiseringsuppgifter från hemligheten och testar anslutningen till SQL Server.

Webbappen kräver följande komponenter:

  • En webbapp med systemhanterad identitet
  • En åtkomstprincip för åtkomst till hemligheter i Key Vault via webbappens hanterade identitet
  1. Välj distributionslänken för Azure-mallen:

    Bild som visar en knapp med etiketten

  2. Välj resursgruppen akvrotation.

  3. I SQL Server-namnet skriver du SQL Server-namnet med lösenord för att rotera

  4. I Key Vault-namnet skriver du namnet på nyckelvalvet

  5. I det hemliga namnet skriver du det hemliga namn där lösenordet lagras

  6. I webbadressen till lagringsplatsen skriver du webbappkoden GitHub-plats (https://github.com/Azure-Samples/KeyVault-Rotation-SQLPassword-Csharp-WebApp.git)

  7. Välj Granska + skapa.

  8. Välj Skapa.

Öppna webbappen

Gå till den distribuerade program-URL:en:

'https://akvrotation-app.azurewebsites.net/'

När programmet öppnas i webbläsaren visas värdet Genererad hemlighet och värdet Database Connectedtrue.

Läs mer