Blog Post

Apps on Azure Blog
3 MIN READ

New: Secure Sandboxes at Scale with Azure Container Apps Dynamic Sessions

AnthonyChu's avatar
AnthonyChu
Icon for Microsoft rankMicrosoft
May 16, 2024

We're excited to announce the public preview of Azure Container Apps dynamic sessions. Azure Container Apps is a serverless platform that enables you to run containerized workloads without managing the underlying infrastructure. Dynamic sessions adds the ability to execute untrusted code in secure, sandboxed environments at scale.

 

When you build applications that run code or commands from untrusted sources, you must ensure that the code runs in its own isolated environment. Dynamic sessions provide secure, ephemeral sandboxes called "sessions" for running potentially malicious code. Each session runs in its own Hyper-V virtualization boundary — ensuring complete isolation from other sessions and resources.

 

Dynamic sessions are ideal for running untrusted code in hostile multi-tenant scenarios such as:

  • Running code generated by a large language model (LLM).
  • Running code or commands submitted by cloud application users.
  • Running cloud-based development environments, terminals, and more.

 

To build a secure and efficient compute environment for these scenarios, you need to possess strong security expertise and invest in building and maintaining a secure infrastructure at high scale. Azure Container Apps dynamic sessions abstracts away the complexity of managing secure sandboxes, allowing you to focus on building your application.

 

Tested and proven

 

With dynamic sessions, you now have access to the same battle-tested and highly scalable technology that Microsoft relies on to power unique features and experiences. Every day, millions of sessions are used to securely run untrusted code.

 

Instant code execution

 

Azure Container Apps automatically manages pools of resources to ensure there's always a session that's ready to use. It takes just milliseconds to access a session and execute code. Each session maintains state and can be reused for multiple code executions in a single security context. Sessions are ephemeral and are automatically cleaned up after a configurable idle timeout.

 

Built-in code interpreter

 

Out of the box, dynamic sessions comes with a built-in Python code interpreter that's preinstalled with many popular libraries. You can execute Python code by calling a simple REST API. The code interpreter also supports uploading and downloading files, allowing you to bring your own Python modules or import data or files to process.

 

Sessions using the built-in code interpreter are billed on a consumption basis at US$0.03 per session-hour.

 

LangChain, LlamaIndex, and Semantic Kernel integrations

 

Recently, AI agents have seen a surge in popularity. A limitation of these agents is that the LLMs they rely on are unable to perform certain tasks involving math and other computations. When given access to dynamic sessions’ code interpreter, an LLM can write Python code to solve complex problems and an agent executes it to produce accurate responses.

 

However, LLM-generated code occasionally produces unpredictable results, and the code may be harmful when given malicious input. So, it's important to provide each AI agent conversation with its own isolated code interpreter.

 

 

You can integrate the code interpreter in dynamic sessions with popular AI agent frameworks in a few lines of code. To learn more, see the tutorial for each framework:

 

More integrations are on the way. If you have suggestions, please let us know or contribute an integration to that project directly.

 

Custom container sessions

 

Do you want to build your own custom code interpreter or have an entirely different scenario to run in dynamic sessions? You can bring your own custom container. We'll have more to share next week at Microsoft Build.

 

Update May 21: Custom containers are now available. See the official announcement: Public preview: Dynamic sessions in Azure Container Apps for more information.

 

Get started with dynamic sessions

 

Use Azure Container Apps dynamic sessions today. Learn more in our documentation.

 

Join us at PyCon US 2024

 

If you're at PyCon US 2024, come to our session on May 16 or visit our booth to learn more about dynamic sessions.

 

More at Microsoft Build 2024

 

We'll have more next week at Microsoft Build, including custom container sessions and Azure portal experiences. Join us in our session BRK131: Serverless architectures: Effortless Intelligent Apps at extreme scale

 

Updated Jun 07, 2024
Version 3.0
No CommentsBe the first to comment