Migrera från VNet inmatningscacher till Private Link-cacher
I den här artikeln beskrivs ett antal metoder för att migrera en instans av Azure Cache for Redis Virtual Network (VNet) som matas in i Azure Cache for Redis Private Link-cacheinstanser.
Azure Private Link förenklar nätverksarkitekturen och skyddar anslutningen mellan slutpunkter i Azure. Med Private Link kan du ansluta till en Azure Cache for Redis-instans från ditt virtuella nätverk via en privat slutpunkt, som tilldelas en privat IP-adress i ett undernät till det virtuella nätverket. Fördelarna med att använda Azure Private Link för Azure Cache for Redis är:
Flexibilitet på nivån – Azure Private Link stöds på alla våra nivåer. Basic, Standard, Premium, Enterprise och Enterprise Flash. Jämfört med virtuell nätverksinmatning, som endast erbjuds på premiumnivån.
Förenklad nätverkssäkerhetsgruppsregelhantering (NSG) – NSG-regler behöver inte konfigureras för att uppfylla kraven från Azure Cache for Redis.
Azure Policy Support – Se till att alla cacheminnen i din organisation skapas med Private Link och granska organisationens befintliga cacheminnen för att kontrollera att alla använder Private Link.
Migreringsalternativ
Du kan växla från VNet-inmatning till Private Link på några olika sätt. 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.
Om du använder någon kombination av geo-replikering, klustring eller ARM VNet:
Alternativ | Fördelar | Nackdelar |
---|---|---|
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. |
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 | Datamigrering krävs. | Vissa data kan gå förlorade om de skrivs till den befintliga cachen när RDB-filen har genererats. |
Migrera data programmatiskt | Fullständig kontroll över hur data flyttas. | Kräver anpassad kod. |
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:
Skapa en ny Azure Cache for Redis-instans med privata slutpunkter som har samma storlek som (eller större än) den befintliga cachen.
Ändra programkoden så att den skrivs till både den nya och den ursprungliga instansen.
Fortsätt att läsa data från den ursprungliga instansen tills den nya instansen är tillräckligt fylld med data.
Uppdatera programkoden till att endast läsa och skriva från den nya instansen.
Ta bort den ursprungliga instansen.
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:
Skapa en ny Azure Cache for Redis-instans med privata slutpunkter.
Uppdatera programmet så att det använder den nya instansen.
Ta bort den gamla Redis-instansen.
Exportera data till en RDB-fil och importera dem till Azure Cache for Redis (endast Premium-nivå)
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:
Skapa en ny Azure Cache for Redis-instans med privata slutpunkter på premiumnivån som är lika stor som (eller större än) den befintliga cachen.
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.
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.
Importera RDB-filen till den nya cachen med hjälp av dessa importinstruktioner eller PowerShell Import-cmdleten.
Uppdatera programmet så att det använder den nya cacheinstansen.
Migrera programmatiskt
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. Det här verktyget är användbart för att flytta data mellan cacheinstanser i olika Azure Cache-regioner. 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:
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.
Skapa en ny Azure Cache for Redis-instans med privata slutpunkter
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.
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 alternativ för nätverksisolering.
- Lär dig hur du konfigurerar privata slutpunkter för alla Azure Cache for Redis-nivåer.