Vývoj modulu IoT Edge v C# pro přesun souborů pomocí Azure Stack Edge Pro FPGA
Důležité
Zařízení Azure Stack Edge Pro FPGA dosáhla konce životnosti v únoru 2024.
Tento článek vás provede procesem vytvoření modulu IoT Edge pro nasazení pomocí zařízení Azure Stack Edge Pro FPGA. Azure Stack Edge Pro FPGA je řešení úložiště, které umožňuje zpracovávat data a odesílat je přes síť do Azure.
Pomocí modulů Azure IoT Edge se službou Azure Stack Edge Pro FPGA můžete transformovat data při jejich přesunu do Azure. Modul použitý v tomto článku implementuje logiku pro kopírování souboru z místní sdílené složky do cloudové sdílené složky na zařízení Azure Stack Edge Pro FPGA.
V tomto článku získáte informace o těchto tématech:
- Vytvořte registr kontejneru pro ukládání a správu modulů (imagí Dockeru).
- Vytvořte modul IoT Edge pro nasazení na zařízení Azure Stack Edge Pro FPGA.
Informace o modulu IoT Edge
Vaše zařízení Azure Stack Edge Pro FPGA může nasazovat a spouštět moduly IoT Edge. Moduly Edge jsou v podstatě kontejnery Dockeru, které provádějí konkrétní úlohu, jako je příjem zprávy ze zařízení, transformace zprávy nebo odeslání zprávy do IoT Hubu. V tomto článku vytvoříte modul, který kopíruje soubory z místní sdílené složky do cloudové sdílené složky na zařízení Azure Stack Edge Pro FPGA.
- Soubory se zapisují do místní sdílené složky na zařízení Azure Stack Edge Pro FPGA.
- Generátor událostí souboru vytvoří událost souboru pro každý soubor zapsaný do místní sdílené složky. Události souboru se generují také při úpravě souboru. Události souborů se pak odesílají do ioT Edge Hubu (v modulu runtime IoT Edge).
- Vlastní modul IoT Edge zpracovává událost souboru a vytvoří objekt události souboru, který obsahuje také relativní cestu k souboru. Modul vygeneruje absolutní cestu pomocí relativní cesty k souboru a zkopíruje soubor z místní sdílené složky do cloudové sdílené složky. Modul pak odstraní soubor z místní sdílené složky.
Jakmile je soubor v cloudové sdílené složce, automaticky se nahraje do vašeho účtu Azure Storage.
Požadavky
Dříve začnete, ujistěte se, že máte:
Zařízení Azure Stack Edge Pro FPGA, které je spuštěné.
- Zařízení má také přidružený prostředek IoT Hubu.
- Zařízení má nakonfigurovanou výpočetní roli Edge. Další informace najdete v tématu Konfigurace výpočetních prostředků pro azure Stack Edge Pro FPGA.
Následující vývojové materiály:
- Visual Studio Code.
- Rozšíření jazyka C# pro Visual Studio Code (využívající OmniSharp).
- Rozšíření Azure IoT Edge pro Visual Studio Code.
- .NET Core 2.1 SDK.
- Docker CE. Možná budete muset vytvořit účet ke stažení a instalaci softwaru.
Vytvoření registru kontejneru
Registr kontejnerů Azure je privátním registrem Dockeru v Azure, kde můžete ukládat a spravovat privátní image kontejnerů Dockeru. Dvě oblíbené služby registru Dockeru dostupné v cloudu jsou Azure Container Registry a Docker Hub. Tento článek používá službu Container Registry.
V prohlížeči zarovnáte na web Azure Portal.
Vyberte Vytvořit kontejner kontejnerů > prostředků>. Klikněte na Vytvořit.
Poskytnout:
Jedinečný název registru v Azure, který obsahuje 5 až 50 alfanumerických znaků.
Zvolte Předplatné.
Vytvořte novou nebo zvolte existující skupinu prostředků.
Vyberte Umístění. Doporučujeme, aby toto umístění bylo stejné jako přidružené k prostředku Azure Stack Edge.
Přepněte přepínač Uživatel s rolí správce na Povolit.
Nastavte skladovou položku na Basic.
Vyberte Vytvořit.
Po vytvoření registru kontejneru do něj přejděte a vyberte Přístupové klíče.
Zkopírujte hodnoty pro Přihlašovací server, Uživatelské jméno a Heslo. Tyto hodnoty použijete později k publikování image Dockeru do registru a k přidání přihlašovacích údajů registru do modulu runtime Azure IoT Edge.
Vytvoření projektu modulu IoT Edge
Následující kroky vytvoří projekt modulu IoT Edge založený na sadě .NET Core 2.1 SDK. Projekt používá Visual Studio Code a rozšíření Azure IoT Edge.
Vytvoření nového řešení
Vytvořte šablonu řešení v jazyce C#, kterou můžete přizpůsobit pomocí vlastního kódu.
V editoru Visual Studio Code výběrem palety příkazů Zobrazit > otevřete paletu příkazů VS Code.
Na paletě příkazů zadejte a spusťte příkaz Azure: Sign in (Azure: Přihlásit se) a postupujte podle pokynů pro přihlášení k účtu Azure. Pokud už přihlášení jste, můžete tento krok přeskočit.
Na paletě příkazů zadejte a spusťte příkaz Azure IoT Edge: New IoT Edge solution (Azure IoT Edge: Nové řešení IoT Edge). Na paletě příkazů zadejte následující informace k vytvoření řešení:
Vyberte složku, ve které chcete vytvořit řešení.
Zadejte název pro vaše řešení nebo přijměte výchozí název EdgeSolution.
Jako šablonu modulu zvolte C# Module.
Nahraďte výchozí název modulu názvem, který chcete přiřadit, v tomto případě fileCopyModule.
Jako úložiště image pro první modul zadejte registr kontejneru, který jste vytvořili v předchozí části. Nahraďte localhost:5000 hodnotou pro přihlašovací server, kterou jste zkopírovali.
Konečný řetězec vypadá takto
<Login server name>/<Module name>
. V tomto příkladu je řetězec:mycontreg2.azurecr.io/filecopymodule
.
Přejděte do složky Otevřít soubor>.
Přejděte do složky EdgeSolution, kterou jste vytvořili dříve. Okno VS Code načte pracovní prostor řešení IoT Edge s pěti komponentami nejvyšší úrovně. Nebudete upravovat složku .vscode , soubor .gitignore , soubor .env a deployment.template.json v tomto článku.
Jedinou komponentou, kterou upravíte, je složka modulů. Tato složka obsahuje kód jazyka C# pro modul a soubory Dockeru pro sestavení modulu jako image kontejneru.
Aktualizace modulu pomocí vlastního kódu
V průzkumníku VS Code otevřete moduly > FileCopyModule > Program.cs.
V horní části oboru názvů FileCopyModule přidejte následující příkazy using pro typy, které se používají později. Microsoft.Azure.Devices.Client.Transport.Mqtt je protokol pro odesílání zpráv do ioT Edge Hubu.
namespace FileCopyModule { using Microsoft.Azure.Devices.Client.Transport.Mqtt; using Newtonsoft.Json;
Přidejte do třídy Program proměnnou InputFolderPath a OutputFolderPath .
class Program { static int counter; private const string InputFolderPath = "/home/input"; private const string OutputFolderPath = "/home/output";
Ihned po předchozím kroku přidejte třídu FileEvent pro definování textu zprávy.
/// <summary> /// The FileEvent class defines the body of incoming messages. /// </summary> private class FileEvent { public string ChangeType { get; set; } public string ShareRelativeFilePath { get; set; } public string ShareName { get; set; } }
V metodě Init kódem vytvoříte a nakonfigurujete objekt ModuleClient. Tento objekt umožňuje modulu připojit se k místnímu modulu runtime Azure IoT Edge pomocí protokolu MQTT pro odesílání a příjem zpráv. Modul runtime IoT Edge poskytne modulu připojovací řetězec používaný metodou Init. Kód zaregistruje zpětné volání FileCopy pro příjem zpráv z centra IoT Edge prostřednictvím koncového bodu input1 . Nahraďte inicializační metodu následujícím kódem.
/// <summary> /// Initializes the ModuleClient and sets up the callback to receive /// messages containing file event information /// </summary> static async Task Init() { MqttTransportSettings mqttSetting = new MqttTransportSettings(TransportType.Mqtt_Tcp_Only); ITransportSettings[] settings = { mqttSetting }; // Open a connection to the IoT Edge runtime ModuleClient ioTHubModuleClient = await ModuleClient.CreateFromEnvironmentAsync(settings); await ioTHubModuleClient.OpenAsync(); Console.WriteLine("IoT Hub module client initialized."); // Register callback to be called when a message is received by the module await ioTHubModuleClient.SetInputMessageHandlerAsync("input1", FileCopy, ioTHubModuleClient); }
Odeberte kód metody PipeMessage a na jeho místě vložte kód pro FileCopy.
/// <summary> /// This method is called whenever the module is sent a message from the IoT Edge Hub. /// This method deserializes the file event, extracts the corresponding relative file path, and creates the absolute input file path using the relative file path and the InputFolderPath. /// This method also forms the absolute output file path using the relative file path and the OutputFolderPath. It then copies the input file to output file and deletes the input file after the copy is complete. /// </summary> static async Task<MessageResponse> FileCopy(Message message, object userContext) { int counterValue = Interlocked.Increment(ref counter); try { byte[] messageBytes = message.GetBytes(); string messageString = Encoding.UTF8.GetString(messageBytes); Console.WriteLine($"Received message: {counterValue}, Body: [{messageString}]"); if (!string.IsNullOrEmpty(messageString)) { var fileEvent = JsonConvert.DeserializeObject<FileEvent>(messageString); string relativeFileName = fileEvent.ShareRelativeFilePath.Replace("\\", "/"); string inputFilePath = InputFolderPath + relativeFileName; string outputFilePath = OutputFolderPath + relativeFileName; if (File.Exists(inputFilePath)) { Console.WriteLine($"Moving input file: {inputFilePath} to output file: {outputFilePath}"); var outputDir = Path.GetDirectoryName(outputFilePath); if (!Directory.Exists(outputDir)) { Directory.CreateDirectory(outputDir); } File.Copy(inputFilePath, outputFilePath, true); Console.WriteLine($"Copied input file: {inputFilePath} to output file: {outputFilePath}"); File.Delete(inputFilePath); Console.WriteLine($"Deleted input file: {inputFilePath}"); } else { Console.WriteLine($"Skipping this event as input file doesn't exist: {inputFilePath}"); } } } catch (Exception ex) { Console.WriteLine("Caught exception: {0}", ex.Message); Console.WriteLine(ex.StackTrace); } Console.WriteLine($"Processed event."); return MessageResponse.Completed; }
Soubor uložte.
Můžete si také stáhnout existující ukázku kódu pro tento projekt. Pak můžete ověřit soubor, který jste uložili do souboru program.cs v této ukázce.
Vytvoření řešení IoT Edge
V předchozí části jste vytvořili řešení IoT Edge a do FileCopyModule jste přidali kód pro kopírování souborů z místní sdílené složky do cloudové sdílené složky. Teď je potřeba sestavit toto řešení jako image kontejneru a odeslat ho do registru kontejneru.
V nástroji VSCode přejděte do terminálu > New Terminal a otevřete nový integrovaný terminál editoru Visual Studio Code.
Přihlaste se k Dockeru zadáním následujícího příkazu v integrovaném terminálu.
docker login <ACR login server> -u <ACR username>
Použijte přihlašovací server a uživatelské jméno, které jste zkopírovali z registru kontejneru.
Po zobrazení výzvy k zadání hesla zadejte heslo. Hodnoty přihlašovacího serveru, uživatelského jména a hesla můžete načíst také z přístupových klíčů v registru kontejneru na webu Azure Portal.
Po zadání přihlašovacích údajů můžete image modulu odeslat do registru kontejneru Azure. V Průzkumníku VS Code klikněte pravým tlačítkem na soubor module.json a vyberte Sestavit a odeslat řešení IoT Edge.
Když visual Studio Code řeknete, aby sestavil řešení, spustí v integrovaném terminálu dva příkazy: docker build a docker push. Tyto dva příkazy sestaví kód, provedou kontejnerizaci vaší knihovny CSharpModule.dll a odešlou ji do registru kontejneru, který jste zadali při inicializaci řešení.
Zobrazí se výzva k výběru platformy modulu. Vyberte amd64 odpovídající Linuxu.
Důležité
Podporují se jenom moduly Linuxu.
Může se zobrazit následující upozornění, které můžete ignorovat:
Program.cs(77;44): upozornění CS1998: Tato asynchronní metoda nemá operátory await a spustí se synchronně. Zvažte použití operátoru await k čekání neblokujících volání rozhraní API nebo operátor await Task.Run(...) k provedení práce vázané na procesor na vlákně na pozadí.
Úplnou adresu image kontejneru se značkou můžete vidět v integrovaném terminálu VS Code. Adresa obrázku je sestavena z informací, které jsou v souboru module.json ve formátu
<repository>:<version>-<platform>
. Pro tento článek by měl vypadat jakomycontreg2.azurecr.io/filecopymodule:0.0.1-amd64
.
Další kroky
Pokud chcete tento modul nasadit a spustit v Azure Stack Edge Pro FPGA, přečtěte si postup v tématu Přidání modulu.