CI/CD voor Stream Analytics op IoT Edge implementeren met behulp van API's

U kunt continue integratie en implementatie inschakelen voor Azure Stream Analytics-taken met behulp van REST API's. Dit artikel bevat voorbeelden van welke API's u moet gebruiken en hoe u deze kunt gebruiken. REST API's worden niet ondersteund in Azure Cloud Shell.

API's aanroepen vanuit verschillende omgevingen

REST API's kunnen worden aangeroepen vanuit zowel Linux als Windows. De volgende opdrachten demonstreren de juiste syntaxis voor de API-aanroep. Specifiek API-gebruik wordt beschreven in latere secties van dit artikel.

Linux

Voor Linux kunt u de opdrachten of Wget gebruikenCurl:

curl -u { <username:password> }  -H "Content-Type: application/json" -X { <method> } -d "{ <request body> }" { <url> }   
wget -q -O- --{ <method> } -data="<request body>" --header=Content-Type:application/json --auth-no-challenge --http-user="<Admin>" --http-password="<password>" <url>

Windows

Voor Windows gebruikt u PowerShell:

$user = "<username>" 
$pass = "<password>" 
$encodedCreds = [Convert]::ToBase64String([Text.Encoding]::ASCII.GetBytes(("{0}:{1}" -f $user,$pass))) 
$basicAuthValue = "Basic $encodedCreds" 
$headers = New-Object "System.Collections.Generic.Dictionary[[String],[String]]" 
$headers.Add("Content-Type", 'application/json') 
$headers.Add("Authorization", $basicAuthValue) 
$content = "<request body>" 
$response = Invoke-RestMethod <url> -Method <method> -Body $content -Headers $Headers 
echo $response 

Een ASA-taak maken op IoT Edge

Als u een Stream Analytics-taak wilt maken, roept u de PUT-methode aan met behulp van de Stream Analytics-API.

Methode Aanvraag-URL
PUT https://management.azure.com/subscriptions/{subscription-id}/resourcegroups/{resource-group-name}/providers/Microsoft.StreamAnalytics/streamingjobs/{job-name}?api-version=2017-04-01-preview

Voorbeeld van een opdracht met behulp van curl:

curl -u { <username:password> } -H "Content-Type: application/json" -X { <method> } -d "{ <request body> }" https://management.azure.com/subscriptions/{subscription-id}/resourcegroups/{resource-group-name}/providers/Microsoft.StreamAnalytics/streamingjobs/{jobname}?api-version=2017-04-01-preview  

Voorbeeld van aanvraagbody in JSON:

{ 
  "location": "West US", 
  "tags": { "key": "value", "ms-suppressjobstatusmetrics": "true" }, 
  "sku": {  
      "name": "Standard" 
    }, 
  "properties": { 
    "sku": {  
      "name": "standard" 
    }, 
       "eventsLateArrivalMaxDelayInSeconds": 1, 
       "jobType": "edge", 
    "inputs": [ 
      { 
        "name": "{inputname}", 
        "properties": { 
         "type": "stream", 
          "serialization": { 
            "type": "JSON", 
            "properties": { 
              "fieldDelimiter": ",", 
              "encoding": "UTF8" 
            } 
          }, 
          "datasource": { 
            "type": "GatewayMessageBus", 
            "properties": { 
            } 
          } 
        } 
      } 
    ], 
    "transformation": { 
      "name": "{queryName}", 
      "properties": { 
        "query": "{query}" 
      } 
    }, 
    "package": { 
      "storageAccount" : { 
        "accountName": "{blobstorageaccountname}", 
        "accountKey": "{blobstorageaccountkey}" 
      }, 
      "container": "{blobcontaine}]" 
    }, 
    "outputs": [ 
      { 
        "name": "{outputname}", 
        "properties": { 
          "serialization": { 
            "type": "JSON", 
            "properties": { 
              "fieldDelimiter": ",", 
              "encoding": "UTF8" 
            } 
          }, 
          "datasource": { 
            "type": "GatewayMessageBus", 
            "properties": { 
            } 
          } 
        } 
      } 
    ] 
  } 
} 

Zie de API-documentatie voor meer informatie.

IoT Edge-pakket publiceren

Als u een Stream Analytics-taak op IoT Edge wilt publiceren, roept u de POST-methode aan met behulp van de IoT Edge Package Publish-API.

Methode Aanvraag-URL
POST https://management.azure.com/subscriptions/{subscriptionid}/resourceGroups/{resourcegroupname}/providers/Microsoft.StreamAnalytics/streamingjobs/{jobname}/publishedgepackage?api-version=2017-04-01-preview

De vorige aanroep van de api voor het publiceren van IoT Edge-pakketten activeert een asynchrone bewerking en retourneert de status 202. De header van het locatieantwoord bevat de URI die wordt gebruikt om de status van die asynchrone bewerking op te halen. Een aanroep van de URI in de locatieheader retourneert de status 202 om aan te geven dat de asynchrone bewerking nog steeds wordt uitgevoerd. Wanneer de bewerking is voltooid, retourneert de aanroep van de URI in de locatieheader de status 200.

Voorbeeld van een IoT Edge pakket publicatieaanroep met behulp van curl:

curl -d -X POST https://management.azure.com/subscriptions/{subscriptionid}/resourceGroups/{resourcegroupname}/providers/Microsoft.StreamAnalytics/streamingjobs/{jobname}/publishedgepackage?api-version=2017-04-01-preview

Nadat u de POST-aanroep hebt uitgevoerd, moet u een antwoord met een lege hoofdtekst verwachten. Zoek de URI in de locatieheader van het antwoord en noteer deze voor verder gebruik.

Voorbeeld van de URI van de locatieheader van het antwoord:

https://management.azure.com/subscriptions/{subscriptionid}/resourcegroups/{resourcegroupname}/providers/Microsoft.StreamAnalytics/StreamingJobs/{resourcename}/OperationResults/{guidAssignedToTheAsynchronousOperation}?api-version=2017-04-01-preview

Wacht een paar seconden tot een paar minuten voordat u de API aanroept waarvan u de URI hebt gevonden in de locatieheader van het antwoord op de IoT Edge Pakket publiceren-API en herhaal de cyclus van wachten en opnieuw proberen totdat u een 200-antwoord krijgt.

Voorbeeld van het maken van EEN API-aanroep met de geretourneerde URL met curl:

curl -d –X GET https://management.azure.com/subscriptions/{subscriptionid}/resourcegroups/{resourcegroupname}/providers/Microsoft.StreamAnalytics/StreamingJobs/{resourcename}/OperationResults/{guidAssignedToTheAsynchronousOperation}?api-version=2017-04-01-preview

Het antwoord bevat de informatie die u moet toevoegen aan het IoT Edge-implementatiescript. In de onderstaande voorbeelden ziet u welke informatie u moet verzamelen en waar u deze kunt toevoegen aan het implementatiemanifest.

Voorbeeld van antwoordtekst na publicatie:

{ 
  edgePackageUrl : null 
  error : null 
  manifest : "{"supportedPlatforms":[{"os":"linux","arch":"amd64","features":[]},{"os":"linux","arch":"arm","features":[]},{"os":"windows","arch":"amd64","features":[]}],"schemaVersion":"2","name":"{jobname}","version":"1.0.0.0","type":"docker","settings":{"image":"{imageurl}","createOptions":null},"endpoints":{"inputs":["\],"outputs":["{outputnames}"]},"twin":{"contentType":"assignments","content":{"properties.desired":{"ASAJobInfo":"{asajobsasurl}","ASAJobResourceId":"{asajobresourceid}","ASAJobEtag":"{etag}","PublishTimeStamp":"{publishtimestamp}"}}}}" 
  status : "Succeeded" 
} 

Voorbeeld van implementatiemanifest:

{ 
  "modulesContent": { 
    "$edgeAgent": { 
      "properties.desired": { 
        "schemaVersion": "1.0", 
        "runtime": { 
          "type": "docker", 
          "settings": { 
            "minDockerVersion": "v1.25", 
            "loggingOptions": "", 
            "registryCredentials": {} 
          } 
        }, 
        "systemModules": { 
          "edgeAgent": { 
            "type": "docker", 
            "settings": { 
              "image": "mcr.microsoft.com/azureiotedge-agent:1.0", 
              "createOptions": "{}" 
            } 
          }, 
          "edgeHub": { 
            "type": "docker", 
            "status": "running", 
            "restartPolicy": "always", 
            "settings": { 
              "image": "mcr.microsoft.com/azureiotedge-hub:1.0", 
              "createOptions": "{}" 
            } 
          } 
        }, 
        "modules": { 
          "<asajobname>": { 
            "version": "1.0", 
            "type": "docker", 
            "status": "running", 
            "restartPolicy": "always", 
            "settings": { 
              "image": "<settings.image>", 
              "createOptions": "<settings.createOptions>" 
            } 
            "version": "<version>", 
             "env": { 
              "PlanId": { 
               "value": "stream-analytics-on-iot-edge" 
          } 
        } 
      } 
    }, 
    "$edgeHub": { 
      "properties.desired": { 
        "schemaVersion": "1.0", 
        "routes": { 
            "route": "FROM /* INTO $upstream" 
        }, 
        "storeAndForwardConfiguration": { 
          "timeToLiveSecs": 7200 
        } 
      } 
    }, 
    "<asajobname>": { 
      "properties.desired": {<twin.content.properties.desired>} 
    } 
  } 
} 

Nadat u het implementatiemanifest hebt geconfigureerd, raadpleegt u Azure IoT Edge-modules implementeren met Azure CLI voor implementatie.

Volgende stappen