- VS Code
- Docker
- Postman
- GitHub Account
- fork the example respository. Link to GitHub documentation for forking a repo: https://docs.github.com/en/get-started/quickstart/fork-a-repo
- check out your own fork of the example repository
- Open the folder in VS Code. You can either do this via File -> Open Folder.. or via command line by cd-ing into the folder and then using
code .
(Linux/Mac: if commandcode
is not found, open VS Code, open the Command Palette and ExecuteShell Command: install 'code' command in PATH
) - make sure Docker is running
- Use the Command Palette and execute
Remote-Containers: Open Folder in Container
. This should start a new Docker container in the background and open a new VS Code window with the project folder mounted. It will also ask to install a few recommended extensions. Depending on your hardware VS Code should finish loading shortly. Check the VS Code status bar at the very bottom to see if all activites were finished. - now you should have a complete dev environment running inside the docker container.
Microsoft introduced the requirement to agree to their "Responsible AI" terms of service. Doing so requires the following steps:
- Open portal.azure.com
- Navigate into your subscription
- In the left menu, click "Access control (IAM)"
- Navigate to the "Role assignments" tab
- Click "+ Add" in the top menu and click "Add role assignment"
- In the "Roles" tabs, select "Cognitive Services Contributor"
- In the members tab click "+ Select members", and select your user in the newly openend menu on the right of the screen and click the "Select" button
- Click the "Review + assign" button on the botton
- Click the "Review + assign" button on the botton again
- Now click the "Microsoft Azure" text in the topmost bar to navigate to the "Home" screen
- Click "Create a resource"
- Enter "Cognitive Services" in the search bar and press Enter
- Click the blue "Create" button
- Make sure your Student Subscription is selected if you already have several subscriptions
- Click "Create new" below the "Resource group" dropdown. The list should be empty if you have not created any Azure resources so far
- enter a name for your resource group (which name is not important since we will delte it right after creating the Cognitive Service account)
- In the "Region" dropdown, select "West Europe"
- Enter a name for the resource (again it does not matter which one since we will delete it again)
- Unter Pricing Tier, select "Standard S0"
- Check the box to acknowledge the Responsible AI terms
- Click "Review + create"
- If validation is succesful, click "Create"
- Wait until creation is done
- Now click the "Microsoft Azure" text in the topmost bar to navigate to the "Home" screen again
- Click on "Resourcxe groups" under "Navigate"
- Select the resource group that was just created (see step 16)
- Click "Delete resource group" in the menu bar
- Make sure that the resource group only contains the custom vision service that we just created
- Confirm by writing the name of the resource group into the text field and click the "Delete" button.
- Open Terminal in the repo root folder
- execute
cd ./infrastructure
- execute
az login --use-device-code
and log in to your Azure Free Trial account You should see a similar output:
Retrieving tenants and subscriptions for the selection...
[Tenant and subscription selection]
No Subscription name Subscription ID Tenant
----- ------------------- ------------------------------------ --------
[1] * Azure for Students fb0e8e47-e203-45b3-a725-3a365ce122ba FH OOe
The default is marked with an *; the default tenant is 'FH OOe' and subscription is 'Azure for Students' (fb0e8e47-e203-45b3-a725-3a365ce122ba).
Select a subscription and tenant (Type a number or Enter for no changes): 1
Tenant: FH OOe
Subscription: Azure for Students (fb0e8e47-e203-45b3-a725-3a365ce122ba)
- execute
az account set --subscription < Subscription ID from above output>
- execute
az deployment sub create --template-file main.bicep --location EastUs
-
The deployment will ask for the following values:
- 'deploymentName': free choosable name for the deployment (e.g.
clc3-example
) - 'rgName': name of the resource group which should be created for the deployment(e.g.
rg-clc3-example-<lastname>
)
!!Important!!: use your last name as a prefix on the resource group name to avoid name colisions with other students
- 'location': region where the infrastructure should be created (e.g.
eastus
)
- 'deploymentName': free choosable name for the deployment (e.g.
-
- In case the deployment fails because it could not create the role-assignments, trigger the deployment a second time using the exact same values as before. This error is caused by Azure AD having a delay in the creation of new identities, while the template assumes that they are created immediately.
If the above deployment worked without errors you can deploy the function code as a next step.
-
Open the Azure portal (portal.azure.com) and navigate to the resource group created in the previous step.
-
Find the resource of type
Function App
in the list, click on the name and open the menu entryDeployment Center
in the left-hand menu. -
If there is already a GitHub connection, press "Disconnect" under Source
-
Set up a new connection to Github
- Organization: should be same as your GitHub user
- Repository: the forked repository from the infrastrcture setup
- Branch: master
- Build provider: GitHub Actions
- Runtime stack: Java
- Version: 11
-
Click
Save
. This will automatically add a new GitHub Actions workflow to your repository and trigger a build that should deploy your function. Chekc the status in theActions
tab in your GitHub repository. -
Validate that the deployment worked. Find the resource of type
Function App
in the list, click on the name and open the menu entryFunctions
in the left-hand menu. You should see one entry with nameblobStorageUpload
, TriggerHTTP
and StatusEnabled
At this point, your function should be ready to upload an image to the blob storage. What's missing now is the configuration of the Logic App that get's triggered after a new file is added to the blob container and sends it to the Computer Vision service for analysis.
Before continuing, find the following information in the Azure Cognitive Service instance that was created during the infrastructure deployment.
- Click on your computer vision service in the resource group you created.
- Click on
Keys and Endpoints
in the left-hand menu. - Copy the value in
Key 1
andEndpoint
to a text file. You will need it in the next steps.
-
Find the Logic App in your resource group named
fh-clc3-logicapp
and open it. -
Click the
Edit
button in the top menu -
Edit the steps marked with an orange exclamation mark. Those steps require a connection configuration to communicate the the underlying Azure Services (Storage Account and Congitive Service).
- Edit the Trigger setep by clicking on it. You will see a list wiht one entry named "fh-clc3-example-connection" and a red error message "Invalid Connection"
- Select the invalid connection
- Under
Authentication Type
selectLogic App Managed Identity
and use name "fh-clc3-example-connection" - The connection should look like this:
- Select the next step in the workflow. You will again see the connection tab, but now there should be a second connection with does not have an exclamation mark next to it. Select this entry.
- Select the next step in the worklfow. This is the connection to the Azure Computer Vision Service.
- Click the
Add new
button - Enter the following values:
- Connection name:
Computer Vision Connection
- Authentication Type:
Api Key
(already selected by default) - Account key: insert Key from the prerequisites step
- Site URL: insert Endpoint URL from the prerequisites step
- Connection name:
- Click
Create
- For the cosmosDB connection, you need to create a new connection as well. Choose a name and select the "Managed Identity" authentication type. The connection should look like this:
- Perform the same as in step 5 using the last step in the workflow.
- Click
Save
in the top menu bar of the Logic App. Do not forget this, otherwise you have to re-do all steps
Get the URL of your function by
- navigation to the Function App in the Azure portal
- click
Functions
in the left hand menu - click on the name
blobStorageUpload
function - click
Get Function Url
and copy the complete URL displayed
To test your apllication, use the following curl command, either from the Terminal or use Postman:
curl --location --request POST '<Your Function URL>' \
--header 'Content-Type: application/octet-stream' \
--header 'Cache-Control: no-cache' \
--data-binary '@<Path to image file'
- If you need to re-deploy the Bicep template, you need to purge the Cognitive Services manually. This can be done by navigating to the Cognitive Service in the Azure Portal (https://portal.azure.com/#view/Microsoft_Azure_ProjectOxford/CognitiveServicesHub/~/ComputerVision), select "Computer Vision" in the left-hand menu, then select "Manage deleted resources" in the top menu and then select and Purge all entries in the list on the right. Repeat this for the "Custom Vision" entry in the left-hand menu.
- If the GitHub action failes after starting with message "The template is not valid. .github/workflows/master_fh-clc3-.yml (Line: 27, Col: 15): Unexpected value 'java-version: 11", you need to manually edit the file
.github/workflows/master_fh-clc3-<random>.yml
and replace the linewith: |+
withwith:
(remove the|+
) and then re-trigger the action by pushing a new commit to your repository.
A more advanced version of this example uses the Custom Vision service in Azure to train a custom model. As an example we want to distinguish soda bottles and let the model classify if it is either one of the following option:
- Coca Cola
- Fanta
- Sprite
-
First thing we need is to deploy the Custom Vision infrastructure. This was already done via the provided infrastructure template. It created a new training and prediction account inside the resource group. To access the Custom Vision portal, open URL https://www.customvision.ai and log in with the same Microsoft user that you use for the Azure portal.
-
Next thing to do is to create a new project. The free tier allows to create 2 projects. Click on the "New Projects" button and enter the following:
- Name: Soda identifier
- Description: Vision model to detect Cola, Fanta and Sprite bottles in images
- Resource: select "fhclc3excustvis*" (* is a random string generated during resource creation)
- Project Type: Classifciation
- Classification Types: Multiclass (single tag per image)
- Domains: Retail
-
Click "Create Project".
-
Now you are ready to upload the images.Go back to the Custom Vision portal (https://www.customvision.ai) and click "Add imgages". Perform the following steps:
- navigate to the folder where you downloaded the training data set
- open folder "fanta"
- select all images and click "Open" to load them
- a new window in the Custom Vision portal opens where you can add the tags
- add tag "fanta" in the "My Tags" field and press enter
- Click the "Upload x files" button (x depends on the number of images you selected)
- repeat those steps for folder "coca_cola" and "sprite" and use tag values "coca cola" and "sprite"
-
If you uploaded and tagged all images, click the "train" button in the top right. You can choose between "Quick Training" and "Advanced Training". For better qualits, choose
Advanced Training
and set the maximum time to 1 hour (ATTENTION: every additional hour will cost $10!). Then clickTrain
, get a snack and wait until it is finished. -
When the training finisehd sucessfully you should see the results in the "Performance" tab. You should also see a
Publish
button on top. Click it to publish your model and choose a name. -
Now we need the URL for our Azure function. Click
Prediction URL
and choose the second one where it says "If you have an image file". Remove the first part of the url https://yourname.cognitiveservices.azure.com/ including the slash! What is left should look like this:customvision/v3.0/Prediction/63d58ba7-0a1c-4361-9bfb-2b29f749f7d1/classify/iterations/Version%201/image
-
Store the URL path that is left in the Function App Configuration, using the name
CUSTOM_VISION_PREDICTION_PATH