Dela via


Migrera till Azure Cache for Redis

Den här artikeln beskriver ett antal metoder för att migrera en befintlig Redis-cache som körs lokalt eller i en annan molntjänst till Azure Cache for Redis.

Migreringsscenarier

Redis med öppen källkod kan köras i många beräkningsmiljöer. Vanliga exempel:

  • Lokalt – Redis-cacheminnen som körs i privata datacenter.
  • Molnbaserade virtuella datorer – Redis cacheminnen som körs på virtuella Azure-datorer, AWS EC2 och så vidare.
  • Värdtjänster – Hanterade Redis-tjänster som AWS ElastiCache.

Om du har en sådan cache kanske du kan flytta den till Azure Cache for Redis med minimal avbrotts- eller stilleståndstid.

Om du vill flytta från en Azure-region till en annan rekommenderar vi att du ser artikeln Flytta Azure Cache for Redis-instanser till olika regioner .

Migreringsalternativ

Det finns olika sätt att växla från en cache till en annan. Beroende på var din cache är och hur ditt program interagerar med den, är en metod mer användbar än de andra. Några av de migreringsstrategier som används ofta beskrivs nedan.

Alternativ Fördelar Nackdelar
Skapa en ny cache Enklast att implementera. Behöver fylla i data till den nya cachen, vilket kanske inte fungerar med många program.
Exportera och importera data via RDB-fil Kompatibel med alla Redis-cacheminnen i allmänhet. Vissa data kan gå förlorade om de skrivs till den befintliga cachen när RDB-filen har genererats.
Dubbelskrivningsdata till två cacheminnen Ingen dataförlust eller stilleståndstid. Oavbrutna åtgärder i den befintliga cachen. Enklare testning av den nya cachen. Behöver två cacheminnen under en längre tidsperiod.
Migrera data programmatiskt Fullständig kontroll över hur data flyttas. Kräver anpassad kod.

Skapa en ny Azure Cache for Redis

Den här metoden är tekniskt sett inte en migrering. Om dataförlust inte är ett problem är det enklaste sättet att flytta till Azure Cache for Redis att skapa en cacheinstans och ansluta ditt program till den. Om du till exempel använder Redis som en cache med databasposter kan du enkelt återskapa cacheminnet från grunden.

Allmänna steg för att implementera det här alternativet är:

  1. Skapa en ny Azure Cache for Redis-instans.

  2. Du kan också prova den nya Azure Managed Redis (förhandsversion).

  3. Uppdatera programmet så att det använder den nya instansen.

  4. Ta bort den gamla Redis-instansen.

Exportera data till en RDB-fil och importera dem till Azure Cache for Redis

Redis med öppen källkod definierar en standardmekanism för att ta en ögonblicksbild av en cacheminnesdatauppsättning och spara den i en fil. Den här filen, som kallas RDB, kan läsas av en annan Redis-cache. Azure Cache for Redis premiumnivå stöder import av data till en cacheinstans via RDB-filer. Du kan använda en RDB-fil för att överföra data från en befintlig cache till Azure Cache for Redis.

Viktigt!

RDB-filformat kan ändras mellan Redis-versioner och kanske inte upprätthålla bakåtkompatibilitet. Redis-versionen av cacheminnet som du exporterar från ska vara lika med eller mindre än den version som tillhandahålls av Azure Cache for Redis.

Allmänna steg för att implementera det här alternativet är:

  1. Skapa en ny Azure Cache for Redis-instans på premiumnivån som har samma storlek som (eller större än) den befintliga cachen.

  2. Spara en ögonblicksbild av den befintliga Redis-cachen. Du kan konfigurera Redis att spara ögonblicksbilder med jämna mellanrum eller köra processen manuellt med hjälp av kommandona SAVE eller BGSAVE . RDB-filen heter "dump.rdb" som standard och kommer att finnas på den sökväg som anges i konfigurationsfilen redis.conf .

    Kommentar

    Om du migrerar data i Azure Cache for Redis kan du läsa de här anvisningarna om hur du exporterar en RDB-fil eller använder PowerShell Export-cmdleten i stället.

  3. Kopiera RDB-filen till ett Azure Storage-konto i den region där din nya cache finns. Du kan använda AzCopy för den här uppgiften.

  4. Importera RDB-filen till den nya cachen med hjälp av dessa importinstruktioner eller PowerShell Import-cmdleten.

  5. Uppdatera programmet så att det använder den nya cacheinstansen.

Skriv till två Redis-cacheminnen samtidigt under migreringsperioden

I stället för att flytta data direkt mellan cacheminnen kan du använda ditt program för att skriva data till både en befintlig cache och en ny som du konfigurerar. Programmet läser fortfarande data från den befintliga cachen från början. När den nya cachen har nödvändiga data växlar du programmet till cacheminnet och drar tillbaka den gamla. Anta till exempel att du använder Redis som ett sessionsarkiv och att programsessionerna är giltiga i sju dagar. När du har skrivit till de två cacheminnena i en vecka är du säker på att den nya cachen innehåller all icke-utgången sessionsinformation. Du kan lita på det från och med då utan att behöva bry dig om dataförlust.

Allmänna steg för att implementera det här alternativet är:

  1. Skapa en ny Azure Cache for Redis-instans på premiumnivån som har samma storlek som (eller större än) den befintliga cachen.

  2. Ändra programkoden så att den skrivs till både den nya och den ursprungliga instansen.

  3. Fortsätt att läsa data från den ursprungliga instansen tills den nya instansen är tillräckligt fylld med data.

  4. Uppdatera programkoden till att endast läsa och skriva från den nya instansen.

  5. Ta bort den ursprungliga instansen.

Migrera programmatiskt

Du kan skapa en anpassad migreringsprocess genom att programmatiskt läsa data från en befintlig cache och skriva dem till Azure Cache for Redis. Det här verktyget med öppen källkod kan användas för att kopiera data från en Azure Cache for Redis-instans till en annan. En kompilerad version är också tillgänglig. Källkoden kan också vara en användbar guide för att skriva ett eget migreringsverktyg.

Kommentar

Det här verktyget stöds inte officiellt av Microsoft.

Allmänna steg för att implementera det här alternativet är:

  1. Skapa en virtuell dator i den region där den befintliga cachen finns. Om datamängden är stor väljer du en relativt kraftfull virtuell dator för att minska kopieringstiden.

  2. Skapa en ny Azure Cache for Redis-instans.

  3. Rensa data från den nya cachen för att säkerställa att den är tom. Det här steget krävs eftersom själva kopieringsverktyget inte skriver över någon befintlig nyckel i målcachen.

    Viktigt!

    Se till att INTE rensa från källcachen.

  4. Använd ett program som verktyget med öppen källkod ovan för att automatisera kopieringen av data från källcachen till målet. Kom ihåg att kopieringsprocessen kan ta ett tag att slutföra beroende på storleken på din datauppsättning.

Nästa steg

Läs mer om Azure Cache for Redis-funktioner.