Securing our adversarial playground
In this section, we will highlight security concerns found in AI/ML development and how to address them in practice. We’ll cover how to secure the deployment of the image recognition service we developed in the previous chapter, which uses a pre-trained CIFAR-10 CNN. We will call this ImRecS from now on for brevity.
Our goal is to demonstrate the concepts rather than create a blueprint for production security.
In the previous chapter, we used a simple Python test client for API. To help us demonstrate the service better, we have written a simple web app that allows you to browse and upload your image to test the ImRecS API:
data:image/s3,"s3://crabby-images/f24a8/f24a83b951bf7cda18401ce597e86ff01c0738a6" alt="Figure 3.1 – The ImRecS web app"
Figure 3.1 – The ImRecS web app
This is what our playground looks like:
data:image/s3,"s3://crabby-images/2c4fd/2c4fd87e43faa14cb3945642ce35ef7a859d4be7" alt="Figure 3.2 – Adversarial AI playground – high-level architecture"
Figure 3.2 – Adversarial AI playground – high-level architecture
We use Docker containers to package our web app and API, both of which are hosted on a Linux host...