Dela via


Så här migrerar du en Azure IoT-hubb manuellt med hjälp av en Azure Resource Manager-mall

Använd Azure Portal, Azure Resource Manager-mallar och Azure IoT Hub-tjänst-SDK:er för att migrera en IoT-hubb till en ny region, en ny nivå eller en ny konfiguration.

Stegen i den här artikeln är användbara om du vill:

För att migrera en hubb behöver du en prenumeration med administrativ åtkomst till den ursprungliga hubben. Du kan placera den nya hubben i en ny resursgrupp och region, i samma prenumeration som den ursprungliga hubben eller till och med i en ny prenumeration. Du kan bara inte använda samma namn eftersom hubbnamnet måste vara globalt unikt.

Jämför automatiska och manuella migreringssteg

Resultatet av den här artikeln liknar Hur du automatiskt migrerar en IoT-hubb med hjälp av Azure CLI, men med en annan process. Innan du börjar ska du bestämma vilken process som passar ditt scenario.

  • Den manuella processen (den här artikeln):

    • Migrerar enhetsregistret och din routnings- och slutpunktsinformation. Du måste återskapa annan konfigurationsinformation manuellt i den nya IoT-hubben.
    • Går snabbare att migrera ett stort antal enheter (till exempel mer än 100 000).
    • Använder ett Azure Storage-konto för att överföra enhetsregistret.
    • Rensar anslutningssträng för routning och filuppladdningsslutpunkter som använder nyckelbaserad autentisering från ARM-mallens utdata, och du måste lägga till dem manuellt igen.
  • Azure CLI-processen:

    • Migrerar enhetsregistret, din routnings- och slutpunktsinformation och annan konfigurationsinformation som IoT Edge-distributioner eller konfigurationer för automatisk enhetshantering.
    • Är enklare att migrera ett litet antal enheter (till exempel upp till 10 000).
    • Kräver inget Azure Storage-konto.
    • Samlar in anslutningssträng för routning och filuppladdningsslutpunkter som använder nyckelbaserad autentisering och innehåller dem i ARM-mallens utdata.

Saker att tänka på

Det finns flera saker att tänka på innan du migrerar en IoT-hubb.

  • Kontrollera att alla funktioner som är tillgängliga på den ursprungliga platsen också är tillgängliga på den nya platsen. Vissa tjänster är i förhandsversion och alla funktioner är inte tillgängliga överallt.

  • Ta inte bort de ursprungliga resurserna innan du skapar och verifierar den migrerade versionen. När du har tagit bort en hubb är den borta för alltid och det finns inget sätt att återställa den för att kontrollera inställningarna eller data för att se till att hubben replikeras korrekt.

  • Data för den ursprungliga IoT-hubben migreras inte. Dessa data omfattar enhetsmeddelanden, C2D-kommandon (moln-till-enhet) och jobbrelaterad information som scheman och historik. Mått och loggningsresultat migreras inte heller.

  • Du måste schemalägga stilleståndstid för migreringen. Det tar tid att klona enheterna till den nya hubben. Om du använder metoden Import/Export har benchmark-testning visat att det kan ta cirka två timmar att flytta 500 000 enheter och fyra timmar att flytta en miljon enheter.

  • Du kan kopiera enheter till den nya hubben utan att stänga av eller ändra enheterna.

    • Om enheterna ursprungligen etablerades med DPS uppdaterar du deras registreringar så att de pekar på den nya IoT-hubben. Konfigurera sedan om enheterna för att uppdatera anslutningsinformationen som lagras på varje enhet.

    • Annars måste du använda import-/exportmetoden för att flytta enheterna och sedan måste enheterna ändras för att använda den nya hubben. Du kan till exempel konfigurera enheten så att den använder IoT Hub-värdnamnet från de önskade egenskaperna för tvillingen. Enheten tar det IoT Hub-värdnamnet, kopplar från enheten från den gamla hubben och återansluter den till den nya.

  • Du måste uppdatera eventuella certifikat så att du kan använda dem med de nya resurserna. Dessutom har du förmodligen hubben definierad i en DNS-tabell någonstans och behöver uppdatera DNS-informationen.

  • Slutpunkter som använder systemtilldelade hanterade identiteter för autentisering kan inte migreras. Efter migreringen måste du ge den nya IoT-hubbens systemtilldelade hanterade identitet åtkomst till slutpunktsresurserna och sedan återskapa slutpunkterna.

Metod

Det här är den allmänna metod som vi rekommenderar för migrering av en IoT-hubb.

  1. Exportera hubben och dess inställningar till en Resource Manager-mall.

  2. Gör nödvändiga ändringar i mallen, till exempel uppdatera alla förekomster av namnet och platsen för den migrerade hubben. För alla resurser i mallen som används för slutpunkter för meddelanderoutning uppdaterar du nyckeln i mallen för den resursen.

  3. Importera mallen till en ny resursgrupp på den nya platsen. Det här steget skapar den nya IoT-hubben.

  4. Felsök efter behov.

  5. Lägg till allt som inte har exporterats till mallen.

    Konsumentgrupper exporteras till exempel inte till mallen. Du måste lägga till konsumentgrupperna i mallen manuellt eller använda Azure Portal när hubben har skapats.

  6. Kopiera enheterna från den ursprungliga hubben till den nya hubben. Den här processen beskrivs i avsnittet Hantera de enheter som är registrerade på IoT-hubben.

Hantera meddelanderoutning

Om din hubb använder meddelanderoutning inkluderar export av mallen för hubben routningskonfigurationen, men den inkluderar inte själva resurserna. Om du migrerar IoT-hubben till en ny region måste du välja om du vill flytta routningsresurserna till den nya platsen eller lämna dem på plats och fortsätta att använda dem som de är. Det kan uppstå en liten prestandaträff från routningsmeddelanden till slutpunktsresurser i en annan region.

Om hubben använder meddelanderoutning har du två alternativ.

  • Flytta de resurser som används för routningsslutpunkterna till den nya platsen.

    1. Skapa de nya resurserna själv antingen manuellt i Azure Portal eller med hjälp av Resource Manager-mallar.

    2. Byt namn på alla resurser när du skapar dem på den nya platsen, eftersom de kräver globalt unika namn.

    3. Uppdatera resursnamnen och resursnycklarna i den nya hubbens mall innan du skapar den nya hubben. Resurserna ska finnas när den nya hubben skapas.

  • Flytta inte de resurser som används för routningsslutpunkterna. Använd dem på plats.

    1. I steget där du redigerar mallen måste du hämta nycklarna för varje routningsresurs och placera dem i mallen innan du skapar den nya hubben.

    2. Hubben refererar fortfarande till de ursprungliga routningsresurserna och dirigerar meddelanden till dem som konfigurerade. Du får en liten prestandaträff eftersom hubben och routningsslutpunktsresurserna inte finns på samma plats.

Förbered migreringen av hubben till en annan region

Det här avsnittet innehåller specifika instruktioner för migrering av hubben.

Exportera den ursprungliga hubben till en resursmall

  1. Logga in på Azure-portalen.

  2. Navigera till den IoT-hubb som du vill flytta.

  3. Välj Exportera mall i listan med egenskaper och inställningar för hubben.

    Skärmbild som visar kommandot för att exportera mallen för IoT-hubben.

  4. Välj Ladda ned för att ladda ned mallen. Spara filen någonstans där du kan hitta den igen.

    Skärmbild som visar kommandot för att ladda ned mallen för IoT-hubben.

Visa mallen

Gå till den nedladdade mallen, som finns i en zip-fil. Extrahera zip-filen och leta reda på filen med namnet template.json.

Följande exempel är för en allmän hubb utan routningskonfiguration. Det är en S1-nivåhubb (med 1 enhet) som heter ContosoHub i regionen westus:

{
    "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
    "contentVersion": "1.0.0.0",
    "parameters": {
        "IotHubs_ContosoHub_connectionString": {
            "type": "SecureString"
        },
        "IotHubs_ContosoHub_containerName": {
            "type": "SecureString"
        },
        "IotHubs_ContosoHub_name": {
            "defaultValue": "ContosoHub",
            "type": "String"
        }
    },
    "variables": {},
    "resources": [
        {
            "type": "Microsoft.Devices/IotHubs",
            "apiVersion": "2021-07-01",
            "name": "[parameters('IotHubs_ContosoHub_name')]",
            "location": "westus",
            "sku": {
                "name": "S1",
                "tier": "Standard",
                "capacity": 1
            },
            "identity": {
                "type": "None"
            },
            "properties": {
                "ipFilterRules": [],
                "eventHubEndpoints": {
                    "events": {
                        "retentionTimeInDays": 1,
                        "partitionCount": 4
                    }
                },
                "routing": {
                    "endpoints": {
                        "serviceBusQueues": [],
                        "serviceBusTopics": [],
                        "eventHubs": [],
                        "storageContainers": []
                    },
                    "routes": [],
                    "fallbackRoute": {
                        "name": "$fallback",
                        "source": "DeviceMessages",
                        "condition": "true",
                        "endpointNames": [
                            "events"
                        ],
                        "isEnabled": true
                    }
                },
                "storageEndpoints": {
                    "$default": {
                        "sasTtlAsIso8601": "PT1H",
                        "connectionString": "[parameters('IotHubs_ContosoHub_connectionString')]",
                        "containerName": "[parameters('IotHubs_ContosoHub_containerName')]"
                    }
                },
                "messagingEndpoints": {
                    "fileNotifications": {
                        "lockDurationAsIso8601": "PT1M",
                        "ttlAsIso8601": "PT1H",
                        "maxDeliveryCount": 10
                    }
                },
                "enableFileUploadNotifications": false,
                "cloudToDevice": {
                    "maxDeliveryCount": 10,
                    "defaultTtlAsIso8601": "PT1H",
                    "feedback": {
                        "lockDurationAsIso8601": "PT1M",
                        "ttlAsIso8601": "PT1H",
                        "maxDeliveryCount": 10
                    }
                },
                "features": "None",
                "disableLocalAuth": false,
                "allowedFqdnList": []
            }
        }
    ]
}

Redigera mallen

Du måste göra några ändringar innan du kan använda mallen för att skapa den nya hubben i den nya regionen. Använd Visual Studio Code eller en textredigerare för att redigera mallen.

Redigera hubbnamnet och platsen

  1. I avsnittet parametrar tar du bort ... connectionString och ... containerName-parametrar .

    "IotHubs_ContosoHub_connectionString": {
        "type": "SecureString"
    },
    "IotHubs_ContosoHub_containerName": {
        "type": "SecureString"
    },
    
  2. I avsnittet Egenskaper tar du bort egenskapen storageEndpoints .

    "storageEndpoints": {
        "$default": {
            "sasTtlAsIso8601": "PT1H",
            "connectionString": "[parameters('IotHubs_ContosoHub_connectionString')]",
            "containerName": "[parameters('IotHubs_ContosoHub_containerName')]"
        }
    },
    
  3. Om du flyttar hubben till en ny region ändrar du platsegenskapen under resurser.

    "location": "westus",
    

Uppdatera routningsslutpunktsresurserna

När du exporterar Resource Manager-mallen för en hubb som har routning konfigurerad ser du att nycklarna för dessa resurser inte finns i den exporterade mallen. Deras placering betecknas av asterisker. Du måste fylla i dem genom att gå till resurserna i portalen och hämta nycklarna innan du importerar mallen för den nya hubben och skapar hubben.

Om du även har flyttat routningsresurserna uppdaterar du namn, ID och resursgrupp för varje slutpunkt.

  • För slutpunkter med nyckelbaserad autentisering hämtar du de nycklar som krävs för någon av routningsresurserna och placerar dem i mallen. Du kan hämta nyckeln från varje resurs i Azure Portal.
  • För slutpunkter med identitetsbaserad autentisering:
    • De som använder en användartilldelad hanterad identitet har värdet userAssignedIdentity fyllt med identitets-ID-informationen som parameter.
    • De som använder en systemtilldelad hanterad identitet kan inte migreras. Ta bort dessa slutpunkter och deras relaterade vägar från mallen och anteckna för att återskapa dem i den nya IoT-hubben.

Skapa den nya hubben genom att läsa in mallen

Skapa den nya hubben med den redigerade mallen. Om du har routningsresurser som ska flyttas bör resurserna konfigureras på den nya platsen och referenserna i mallen uppdateras så att de matchar. Om du inte flyttar routningsresurserna bör de finnas i mallen med de uppdaterade nycklarna.

  1. Logga in på Azure-portalen.

  2. Välj Skapa en resurs.

  3. I sökrutan söker du efter och väljer malldistribution (distribuera med anpassade mallar). På skärmen för malldistributionen väljer du Skapa.

  4. På sidan Anpassad distribution väljer du Skapa en egen mall i redigeraren, vilket gör att du kan ladda upp mallen från en fil.

    Skärmbild som visar kommandot för att skapa en egen mall.

  5. Välj Läs in fil.

    Skärmbild som visar kommandot för att ladda upp en mallfil.

  6. Bläddra efter den nya mallen som du redigerade och välj den och välj sedan Öppna. Mallen läses in i redigeringsfönstret. Välj Spara.

    Skärmbild som visar hur du läser in mallen.

  7. Fyll i följande fält på sidan för anpassad distribution.

    Prenumeration: Välj den prenumeration som du vill använda.

    Resursgrupp: Välj en befintlig resursgrupp eller skapa en ny.

    Region: Om du har valt en befintlig resursgrupp fylls regionen i så att du kan matcha platsen för resursgruppen. Om du har skapat en ny resursgrupp är det här platsen.

    Hubbnamn: Ge den nya hubben ett namn.

    Skärmbild som visar sidan för anpassad distribution

  8. Välj knappen Granska + skapa.

  9. Markera knappen Skapa. Portalen validerar mallen och distribuerar din nya hubb. Om du har routningskonfigurationsdata ingår de i den nya hubben, men pekar på resurserna på den tidigare platsen.

    Skärmbild som visar den slutliga sidan för anpassad distribution

Hantera de enheter som är registrerade på IoT-hubben

Nu när du har din nya hubb igång måste du kopiera alla enheter från den ursprungliga hubben till den nya.

Det finns flera sätt att kopiera enheterna. Du använde antingen Device Provisioning Service (DPS) för att etablera enheterna, eller så gjorde du inte det. Om du gjorde det är den här processen inte svår. Om du inte gjorde det kan den här processen vara komplicerad.

Om du inte använde DPS för att etablera dina enheter kan du hoppa över nästa avsnitt och börja med Använd import/export för att flytta enheterna till den nya hubben.

Använda DPS för att återskapa enheterna i den nya hubben

Information om hur du använder DPS för att flytta enheterna till den nya platsen finns i Så här återskapar du enheter. När du är klar kan du visa enheterna i Azure Portal och kontrollera att de finns på den nya platsen.

Gå till den nya hubben med hjälp av Azure Portal. Välj din hubb och välj sedan IoT-enheter. Du ser de enheter som har återskapats till den nya hubben. Du kan också visa egenskaperna för den nya hubben.

Om du har implementerat routning testar du och kontrollerar att dina meddelanden dirigeras till resurserna på rätt sätt.

Återställa ändringarna när du har använt DPS

Om du vill återställa ändringarna ska du återskapa enheterna från den nya hubben till den gamla.

Nu är du klar med att migrera din hubb och dess enheter. Du kan gå vidare till Rensa.

Använd import-export för att flytta enheterna till den nya hubben

Programmet riktar sig till .NET Core, så att du kan köra det på antingen Windows eller Linux. Du kan ladda ned exemplet, hämta dina anslutningssträng, ange flaggorna för vilka bitar du vill köra och köra det. Du kan göra detta utan att öppna koden.

Hämta exemplet

Använd IoT C# SDK:n ImportExportDevicesSample. Klona eller ladda ned lagringsplatsen för att hämta exempelkoden.

Alternativ

Om du vill köra programmet anger du tre anslutningssträng och fem alternativ. Du skickar in dessa data som kommandoradsargument eller använder miljövariabler, eller använder en kombination av de två. Vi ska skicka in alternativen som kommandoradsargument och anslutningssträng som miljövariabler. Anledningen till detta är att anslutningssträng är långa och icke-bakåtkompatibelt och sannolikt inte kommer att ändras, men du kanske vill ändra alternativen och köra programmet mer än en gång. Om du vill ändra värdet för en miljövariabel måste du stänga kommandofönstret och Visual Studio eller Visual Studio Code, beroende på vilket du använder.

Här är de fem alternativ som du anger när du kör programmet:

  • addDevices (argument 1) – ange det här alternativet till True om du vill lägga till virtuella enheter som genereras åt dig. Dessa enheter läggs till i källhubben. Ange också numToAdd (argument 2) för att ange hur många enheter du vill lägga till. Det maximala antalet enheter som du kan registrera till en hubb är en miljon. Syftet med det här alternativet är att testa. Du kan generera ett visst antal enheter och sedan kopiera dem till en annan hubb.

  • copyDevices (argument 3) – ange det här alternativet för att True kopiera enheterna från en hubb till en annan.

  • deleteSourceDevices (argument 4) – ange det här alternativet för att True ta bort alla enheter som är registrerade i källhubben. Vi rekommenderar att du väntar tills du är säker på att alla enheter har överförts innan du kör detta. När du har tagit bort enheterna kan du inte få tillbaka dem.

  • deleteDestDevices (argument 5) – ange det här alternativet för att True ta bort alla enheter som är registrerade i målhubben. Du kanske vill göra detta om du vill kopiera enheterna mer än en gång.

Det grundläggande kommandot är dotnet run, som instruerar .NET att skapa den lokala csproj-filen och sedan köra den. Du lägger till kommandoradsargumenten i slutet innan du kör det.

Kommandoraden ser ut så här:

    // Format: dotnet run add-devices num-to-add copy-devices delete-source-devices delete-destination-devices

    // Add 1000 devices, don't copy them to the other hub, or delete them. 
    // The first argument is true, numToAdd is 50, and the other arguments are false.
    dotnet run true 1000 false false false 

    // Copy the devices you just added to the other hub; don't delete anything.
    // The first argument is false, numToAdd is 0, copy-devices is true, and the delete arguments are both false
    dotnet run false 0 true false false 

Använda miljövariabler för anslutningssträng

  1. För att köra exemplet behöver du anslutningssträng till de gamla och nya IoT-hubbarna och till ett lagringskonto som du kan använda för tillfälliga arbetsfiler. Vi lagrar värdena för dessa anslutningssträng i miljövariabler.

  2. Om du vill hämta anslutningssträng värden loggar du in på Azure Portal.

  3. Placera anslutningssträng någonstans där du kan hämta dem, till exempel Anteckningar. Om du kopierar följande kan du klistra in anslutningssträng direkt där de går. Lägg inte till blanksteg runt likhetstecknet, eller så ändras variabelnamnet. Du behöver inte heller dubbla citattecken runt anslutningssträng. Om du placerar citattecken runt lagringskontot anslutningssträng misslyckas skriptet.

    Ange miljövariablerna i Windows:

    SET IOTHUB_CONN_STRING=<put connection string to original IoT hub here>
    SET DEST_IOTHUB_CONN_STRING=<put connection string to destination IoT hub here>
    SET STORAGE_ACCT_CONN_STRING=<put connection string to the storage account here>
    

    Ange miljövariablerna i Linux:

    export IOTHUB_CONN_STRING="<put connection string to original IoT hub here>"
    export DEST_IOTHUB_CONN_STRING="<put connection string to destination IoT hub here>"
    export STORAGE_ACCT_CONN_STRING="<put connection string to the storage account here>"
    
  4. För IoT Hub-anslutningssträng går du till varje hubb i portalen. Du kan söka i Resurser efter hubben. Om du känner till resursgruppen kan du gå till Resursgrupper, välja din resursgrupp och sedan välja hubben i listan över tillgångar i resursgruppen.

  5. Välj Principer för delad åtkomst från inställningarna för hubben och välj sedan iothubowner och kopiera en av anslutningssträng. Gör samma sak för målhubben. Lägg till dem i lämpliga SET-kommandon.

  6. För lagringskontot anslutningssträng letar du upp lagringskontot i Resurser eller under dess resursgrupp och öppnar det.

  7. Under avsnittet Inställningar väljer du Åtkomstnycklar och kopierar en av anslutningssträng. Placera anslutningssträng i textfilen för lämpligt SET-kommando.

Nu har du miljövariablerna i en fil med SET-kommandona och du vet vilka kommandoradsargument du har. Nu kör vi exemplet.

Kör exempelprogrammet och använd kommandoradsargument

  1. Öppna ett kommandotolksfönster. Välj Windows och skriv in command prompt för att hämta kommandotolkens fönster.

  2. Kopiera kommandona som anger miljövariablerna, en i taget, och klistra in dem i kommandotolkens fönster och välj Retur. När du är klar skriver SET du i kommandotolken för att se miljövariablerna och deras värden. När du har kopierat dessa till kommandotolkens fönster behöver du inte kopiera dem igen, såvida du inte öppnar ett nytt kommandotolksfönster.

  3. I kommandotolken ändrar du kataloger tills du är i ./ImportExportDevicesSample (där filen ImportExportDevicesSample.csproj finns). Skriv sedan följande och inkludera dina kommandoradsargument.

    // Format: dotnet run add-devices num-to-add copy-devices delete-source-devices delete-destination-devices
    dotnet run arg1 arg2 arg3 arg4 arg5
    

    Dotnet-kommandot skapar och kör programmet. Eftersom du skickar in alternativen när du kör programmet kan du ändra värdena för dem varje gång du kör programmet. Du kanske till exempel vill köra den en gång och skapa nya enheter, sedan köra den igen och kopiera enheterna till en ny hubb och så vidare. Du kan också utföra alla steg i samma körning, men vi rekommenderar att du inte tar bort några enheter förrän du är säker på att du är klar med migreringen. Här är ett exempel som skapar 1 000 enheter och sedan kopierar dem till den andra hubben.

    // Format: dotnet run add-devices num-to-add copy-devices delete-source-devices delete-destination-devices
    
    // Add 1000 devices, don't copy them to the other hub or delete them. 
    dotnet run true 1000 false false false 
    
    // Do not add any devices. Copy the ones you just created to the other hub; don't delete anything.
    dotnet run false 0 true false false 
    

    När du har kontrollerat att enheterna har kopierats kan du ta bort enheterna från källhubben så här:

    // Format: dotnet run add-devices num-to-add copy-devices delete-source-devices delete-destination-devices
    // Delete the devices from the source hub.
    dotnet run false 0 false true false 
    

Kör exempelprogrammet med Visual Studio

  1. Om du vill köra programmet i Visual Studio ändrar du den aktuella katalogen till mappen där azureiot.sln filen finns. Kör sedan det här kommandot i kommandotolken för att öppna lösningen i Visual Studio. Du måste göra detta i samma kommandofönster där du anger miljövariablerna, så att dessa variabler är kända.

    azureiot.sln
    
  2. Högerklicka på projektet ImportExportDevicesSample och välj Ange som startprojekt.

  3. Ange variablerna överst i Program.cs i mappen ImportExportDevicesSample för de fem alternativen.

    // Add randomly created devices to the source hub.
    private static bool addDevices = true;
    //If you ask to add devices, this will be the number added.
    private static int numToAdd = 0; 
    // Copy the devices from the source hub to the destination hub.
    private static bool copyDevices = false;
    // Delete all of the devices from the source hub. (It uses the IoTHubConnectionString).
    private static bool deleteSourceDevices = false;
    // Delete all of the devices from the destination hub. (Uses the DestIotHubConnectionString).
    private static bool deleteDestDevices = false;
    
  4. Välj F5 för att köra programmet. När den har körts kan du visa resultatet.

Visa resultatet

Du kan visa enheterna i Azure Portal och kontrollera att de finns på den nya platsen.

  1. Gå till den nya hubben med hjälp av Azure Portal. Välj din hubb och välj sedan IoT-enheter. Du ser de enheter som du kopierade från den gamla hubben till den nya hubben. Du kan också visa egenskaperna för den nya hubben.

  2. Kontrollera om det finns import-/exportfel genom att gå till Azure Storage-kontot i Azure Portal och leta efter containern devicefiles ImportErrors.logför . Om filen är tom (storleken är 0) uppstod inga fel. Om du försöker importera samma enhet mer än en gång avvisar den enheten andra gången och lägger till ett felmeddelande i loggfilen.

Checka in ändringarna

Nu har du kopierat hubben till den nya platsen och migrerat enheterna till den nya hubben. Nu måste du göra ändringar så att enheterna fungerar med den nya hubben.

För att genomföra ändringarna måste du utföra följande steg:

  • Uppdatera varje enhet för att ändra IoT Hub-värdnamnet så att IoT Hub-värdnamnet pekar på den nya hubben. Du bör göra detta med samma metod som du använde när du först etablerade enheten.

  • Ändra alla program som refererar till den gamla hubben så att de pekar på den nya hubben.

  • När du är klar bör den nya hubben vara igång. Den gamla hubben ska inte ha några aktiva enheter och vara i frånkopplat tillstånd.

Återställa ändringarna

Om du bestämmer dig för att återställa ändringarna följer du stegen nedan:

  • Uppdatera varje enhet för att ändra IoT Hub-värdnamnet så att det pekar IoT Hub-värdnamnet för den gamla hubben. Du bör göra detta med samma metod som du använde när du först etablerade enheten.

  • Ändra alla program som refererar till den nya hubben så att de pekar på den gamla hubben. Om du till exempel använder Azure Analytics kan du behöva konfigurera om dina Azure Stream Analytics-indata.

  • Ta bort den nya hubben.

  • Om du har routningsresurser bör konfigurationen på den gamla hubben fortfarande peka på rätt routningskonfiguration och fungera med dessa resurser när hubben har startats om.

Kontrollera resultaten

Om du vill kontrollera resultaten ändrar du din IoT-lösning så att den pekar på din hubb på den nya platsen och kör den. Med andra ord utför du samma åtgärder med den nya hubben som du utförde med föregående hubb och ser till att de fungerar korrekt.

Om du har implementerat routning testar du och kontrollerar att dina meddelanden dirigeras till resurserna på rätt sätt.

Rensa

Rensa inte förrän du är säker på att den nya hubben är igång och att enheterna fungerar korrekt. Se också till att testa routningen om du använder den funktionen. När du är klar rensar du de gamla resurserna genom att utföra följande steg:

  • Om du inte redan har gjort det tar du bort den gamla hubben. Detta tar bort alla aktiva enheter från hubben.

  • Om du har routningsresurser som du har flyttat till den nya platsen kan du ta bort de gamla routningsresurserna.

Nästa steg

Du har migrerat en IoT-hubb till en ny hubb i en ny region, komplett med enheterna. Mer information om hur du utför massåtgärder mot identitetsregistret i en IoT-hubb finns i Importera och exportera IoT Hub-enhetsidentiteter i grupp.