To facilitate the install, the following tools are required:
To publish a container to the AI for Earth API Platform, the API must be built using one of the official AI for Earth base containers and the acceptance criteria should be followed.
Tag and push your image to your container repository. The images must be versioned. Internally, we use the following naming pattern:
<ACR_name>.azurecr.io/<project_moniker>/<image_version>-<api_name>:<build_number>
- In the APIs/Projects folder, you will notice separate folders for each project. Create a new folder for your project.
- Create a new <api_name>.dockerfile and place it in your folder (pay close attention to the tech stack - Python or R; be sure to use the correct one).
- Modify the FROM clause to point to your registry and <project_moniker> (where you pushed your image in the "Push to ACR" step). The version and tag arguments are required.
The distributed image must be built from this (APIs) directory. The following illustrates how to build the species example.
docker build . -f Projects/species/species-sync.dockerfile -t registry_name.azurecr.io/species/1.0-ai4e-species-sync:1
Once complete, push the new image to your container registry:
# Log into your ACR instance.
az acr login -n <acr_name>
# Push your image to your ACR.
docker push registry_name.azurecr.io/species/1.0-ai4e-species-sync:1
You now have a distributed-capable image stored in your container registry that is ready to be hosted on the API Platform.
For all of the following steps, please reference the camera-trap example, located in the camera-trap directory.
- In the charts/ folder, create a new folder for your project.
- Copy a template chart from the Charts/templates folder and place it under your project folder.
- Modify the Chart.yaml by changing the description, name, and keywords fields. The name should be of the format <project_moniker>-<api_name>.
- Modify the autoscaler.yaml by changing both name fields. The name should be of the format <project_moniker>-<api_name>-autoscaler and <project_moniker>-<api_name>, respectfully. Modify the maxReplicas to the maximum number of instances of your service that should be run and modify the targetCPUUtilizationPercentage to indicate when a new instance should be created. The API Platform supports auto-scaling on custom Application Insights metrics.
- Modify the prod-values.yaml by changing the image.repository to <your_registry>/<project_moniker>/<major_version>-ai4e-api-<api_name>, the name to <project_moniker>-<api_name>, a port that is not taken by ANY other chart by ANY other project API, the resources, and the env variables.
- Modify the routing.yml. The VirtualService name should be of the format <project_moniker>-<api_name>. Modify the uri.prefix to indicate the incoming path to match, modify the destination.host to a name that reflects <project_moniker>-<api_name>.default.svc.cluster.local, destination.port to reflect the port that is to be used, and destination.subset to the version of the release. Change the DestinationRule to a unique name for your API, modify the host to the destination.host value from above, and esure that the name and label version match the path version of the release. To read more about Istio routing, please see the docs.
Before deploying to the cluster, edit the chart's prod-values.yaml file. This contains all configuration values to be used by your service. The Azure Function URLs can be retrieved by using the async_retrieve_cache_connector_urls helper function.
Azure Function URLs are mapped to variables according to the following table:
Chart Variable | Function Name |
---|---|
CACHE_CONNECTOR_UPSERT_URI | cache-connector-upsert |
CACHE_CONNECTOR_GET_URI | cache-connector-get |
CURRENT_PROCESSING_UPSERT_URI | CurrentProcessingUpsert |
# Deploy instance.
helm install --values ./Charts/service-name/prod-values.yaml service-name ./Charts/service-name
# Apply auto-scaling.
kubectl apply -f ./Charts/service-name/autoscaler.yaml
# Apply service routing.
kubectl apply -f ./Charts/service-name/routing.yaml
# Apply optional Application Insights custom scaling metric.
kubectl apply -f ./Charts/service-name/appinsights-metric.yaml
The create_sync_api_management_api.sh is used as an example of how to add sync APIs to your API Management instance, whereas the create_async_api_management_api.sh is used as an example of how to add async APIs. Copy the create_sync_api_management_api.sh file and use it as a template. To deploy to Azure, run the following:
bash ../APIManagement/create_sync_api_management_api.sh