<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: RizAli12</title>
    <description>The latest articles on DEV Community by RizAli12 (@rizali12).</description>
    <link>https://dev.to/rizali12</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1102998%2F8652766e-71bc-4f5e-a2c3-4ceb50ac7e14.png</url>
      <title>DEV Community: RizAli12</title>
      <link>https://dev.to/rizali12</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/rizali12"/>
    <language>en</language>
    <item>
      <title>Stop Duct-Taping Your Agent Sandbox. GKE Just Built It Properly.</title>
      <dc:creator>RizAli12</dc:creator>
      <pubDate>Wed, 29 Apr 2026 10:17:14 +0000</pubDate>
      <link>https://dev.to/rizali12/stop-duct-taping-your-agent-sandbox-gke-just-built-it-properly-2lm1</link>
      <guid>https://dev.to/rizali12/stop-duct-taping-your-agent-sandbox-gke-just-built-it-properly-2lm1</guid>
      <description>&lt;h2&gt;
  
  
  The Problem Every Agent Builder Knows
&lt;/h2&gt;

&lt;p&gt;Your agent just generated some Python. Now what? You need to run it. Somewhere. Safely. Without it touching your prod database, your secrets, your other pods, or anything else it wasn't supposed to touch.&lt;/p&gt;

&lt;p&gt;So you cobbled something together. Maybe a size-1 StatefulSet with gVisor. Maybe a subprocess with a timeout. Maybe a Docker container you spin up per-request and pray the cold start isn't too painful. It works — &lt;strong&gt;mostly&lt;/strong&gt;. Until it doesn't.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;The DIY agent sandbox is one of the most common pieces of technical debt in agentic AI systems right now. GKE Agent Sandbox, GA as of Cloud Next '26, is the opinionated answer to it.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  What You're Probably Doing Today
&lt;/h2&gt;

&lt;p&gt;Let's be honest about the DIY path. Here's a typical pattern:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="c1"&gt;# StatefulSet (size 1) + gVisor + manual warm pool&lt;/span&gt;
&lt;span class="na"&gt;apiVersion&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;apps/v1&lt;/span&gt;
&lt;span class="na"&gt;kind&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;StatefulSet&lt;/span&gt;
&lt;span class="na"&gt;metadata&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;agent-sandbox&lt;/span&gt;
&lt;span class="na"&gt;spec&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;replicas&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="m"&gt;1&lt;/span&gt;  &lt;span class="c1"&gt;# pray you sized this right&lt;/span&gt;
  &lt;span class="na"&gt;template&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;spec&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="na"&gt;runtimeClassName&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;gvisor&lt;/span&gt;
      &lt;span class="na"&gt;containers&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;sandbox&lt;/span&gt;
        &lt;span class="na"&gt;image&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;my-sandbox:latest&lt;/span&gt;
        &lt;span class="na"&gt;resources&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
          &lt;span class="na"&gt;limits&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="na"&gt;cpu&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;1"&lt;/span&gt;
            &lt;span class="na"&gt;memory&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;512Mi&lt;/span&gt;
&lt;span class="c1"&gt;# + manual PVC + headless Service + custom lifecycle mgmt&lt;/span&gt;
&lt;span class="c1"&gt;# + warm pool you have to manage yourself&lt;/span&gt;
&lt;span class="c1"&gt;# + no snapshot support — crash = start over&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This works at one sandbox. At ten it's fine. At a hundred it's a maintenance nightmare. You're writing glue code for provisioning, lifecycle management, networking, and warm pools — none of which is your actual product.&lt;/p&gt;




&lt;h2&gt;
  
  
  What Agent Sandbox Gives You Instead
&lt;/h2&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;DIY Approach&lt;/th&gt;
&lt;th&gt;GKE Agent Sandbox&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;StatefulSet + gVisor wired manually&lt;/td&gt;
&lt;td&gt;Managed gVisor via SandboxClaim CRD&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Cold starts of 2–3 min per sandbox&lt;/td&gt;
&lt;td&gt;Sub-second via SandboxWarmPool&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Crash = restart from zero, no state&lt;/td&gt;
&lt;td&gt;Pod Snapshots — checkpoint and resume&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Manual warm pool sizing and mgmt&lt;/td&gt;
&lt;td&gt;WarmPool declared, GKE manages it&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Custom networking + routing code&lt;/td&gt;
&lt;td&gt;Sandbox Router handles all traffic&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;No SDK — raw Kubernetes YAML&lt;/td&gt;
&lt;td&gt;Python SDK — no YAML in your hot path&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;

&lt;p&gt;&lt;strong&gt;The numbers that matter:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;300 sandboxes/sec&lt;/strong&gt; provisioned per cluster&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Sub-second&lt;/strong&gt; time to first instruction from warm pool&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;90% latency reduction&lt;/strong&gt; over cold starts&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;30% better price-performance&lt;/strong&gt; on Axion N4A vs leading competitors&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Hands-On Tutorial: Enable GKE Agent Sandbox From Scratch
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Level:&lt;/strong&gt; Intermediate (knows Kubernetes basics)&lt;br&gt;
&lt;strong&gt;Time:&lt;/strong&gt; ~15 minutes&lt;br&gt;
&lt;strong&gt;Requirements:&lt;/strong&gt; GCP project with billing enabled, gcloud CLI, kubectl, Python 3.10+&lt;/p&gt;

&lt;p&gt;You'll go from zero to a running, isolated sandbox cluster — with a warm pool ready to claim in under a second. All commands run in Cloud Shell.&lt;/p&gt;


&lt;h3&gt;
  
  
  Step 1 — Set Your Environment Variables
&lt;/h3&gt;

&lt;p&gt;Open Cloud Shell and define these once. Every command below uses them — no manual substitution needed.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nb"&gt;export &lt;/span&gt;&lt;span class="nv"&gt;PROJECT_ID&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="si"&gt;$(&lt;/span&gt;gcloud config get project&lt;span class="si"&gt;)&lt;/span&gt;
&lt;span class="nb"&gt;export &lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"agent-sandbox-cluster"&lt;/span&gt;
&lt;span class="nb"&gt;export &lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"us-central1"&lt;/span&gt;
&lt;span class="nb"&gt;export &lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_VERSION&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"1.35.2-gke.1269000"&lt;/span&gt;
&lt;span class="nb"&gt;export &lt;/span&gt;&lt;span class="nv"&gt;NODE_POOL_NAME&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"agent-sandbox-pool"&lt;/span&gt;
&lt;span class="nb"&gt;export &lt;/span&gt;&lt;span class="nv"&gt;MACHINE_TYPE&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"e2-standard-2"&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; GKE version &lt;code&gt;1.35.2-gke.1269000&lt;/code&gt; or later is required. Earlier versions don't support Agent Sandbox.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h3&gt;
  
  
  Step 2 — Create the GKE Standard Cluster
&lt;/h3&gt;

&lt;p&gt;Create the base cluster first. Agent Sandbox gets added via a dedicated node pool — you can't enable it on the default pool.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;gcloud beta container clusters create &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--cluster-version&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_VERSION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Prefer Autopilot?&lt;/strong&gt; Use this single command instead — it handles the node pool automatically, then skip straight to Step 5:&lt;/p&gt;


&lt;pre class="highlight shell"&gt;&lt;code&gt;gcloud beta container clusters create-auto &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--cluster-version&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_VERSION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--enable-agent-sandbox&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/blockquote&gt;




&lt;h3&gt;
  
  
  Step 3 — Add a gVisor-Enabled Node Pool
&lt;/h3&gt;

&lt;p&gt;Agent Sandbox requires a dedicated node pool with gVisor enabled and the &lt;code&gt;cos_containerd&lt;/code&gt; image type. This is non-negotiable — gVisor won't work on other image types.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;gcloud container node-pools create &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;NODE_POOL_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--cluster&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--machine-type&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;MACHINE_TYPE&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--image-type&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;cos_containerd &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--sandbox&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="nb"&gt;type&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;gvisor
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h3&gt;
  
  
  Step 4 — Enable the Agent Sandbox Feature
&lt;/h3&gt;

&lt;p&gt;Now flip the switch that installs the Agent Sandbox controller and registers the CRDs on your cluster.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;gcloud beta container clusters update &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--enable-agent-sandbox&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Verify it worked:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;gcloud beta container clusters describe &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--format&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"value(addonsConfig.agentSandboxConfig.enabled)"&lt;/span&gt;

&lt;span class="c"&gt;# Expected output: True&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;✅ &lt;strong&gt;If you see &lt;code&gt;True&lt;/code&gt; — you're live.&lt;/strong&gt; The Agent Sandbox controller is running and the &lt;code&gt;SandboxTemplate&lt;/code&gt;, &lt;code&gt;SandboxWarmPool&lt;/code&gt;, and &lt;code&gt;SandboxClaim&lt;/code&gt; CRDs are registered in your cluster.&lt;/p&gt;




&lt;h3&gt;
  
  
  Step 5 — Apply Your SandboxTemplate and WarmPool
&lt;/h3&gt;

&lt;p&gt;Define your runtime blueprint and tell GKE how many pre-warmed sandboxes to keep ready. Save this as &lt;code&gt;sandbox-setup.yaml&lt;/code&gt;:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;apiVersion&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;sandbox.gke.io/v1&lt;/span&gt;
&lt;span class="na"&gt;kind&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;SandboxTemplate&lt;/span&gt;
&lt;span class="na"&gt;metadata&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;python-agent-runtime&lt;/span&gt;
&lt;span class="na"&gt;spec&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;runtimeClassName&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;gvisor&lt;/span&gt;
  &lt;span class="na"&gt;containers&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;runtime&lt;/span&gt;
    &lt;span class="na"&gt;image&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;python:3.11-slim&lt;/span&gt;
    &lt;span class="na"&gt;resources&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="na"&gt;requests&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="pi"&gt;{&lt;/span&gt; &lt;span class="nv"&gt;cpu&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;500m"&lt;/span&gt;&lt;span class="pi"&gt;,&lt;/span&gt; &lt;span class="nv"&gt;memory&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;256Mi"&lt;/span&gt; &lt;span class="pi"&gt;}&lt;/span&gt;
      &lt;span class="na"&gt;limits&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;   &lt;span class="pi"&gt;{&lt;/span&gt; &lt;span class="nv"&gt;cpu&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;1"&lt;/span&gt;&lt;span class="pi"&gt;,&lt;/span&gt;    &lt;span class="nv"&gt;memory&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;512Mi"&lt;/span&gt; &lt;span class="pi"&gt;}&lt;/span&gt;
&lt;span class="nn"&gt;---&lt;/span&gt;
&lt;span class="na"&gt;apiVersion&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;sandbox.gke.io/v1&lt;/span&gt;
&lt;span class="na"&gt;kind&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;SandboxWarmPool&lt;/span&gt;
&lt;span class="na"&gt;metadata&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;python-agent-pool&lt;/span&gt;
&lt;span class="na"&gt;spec&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;template&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;python-agent-runtime&lt;/span&gt;
  &lt;span class="na"&gt;size&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="m"&gt;5&lt;/span&gt;  &lt;span class="c1"&gt;# 5 pre-warmed sandboxes — adjust to your load&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Apply it and watch the pool fill up:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;kubectl apply &lt;span class="nt"&gt;-f&lt;/span&gt; sandbox-setup.yaml

&lt;span class="c"&gt;# Watch the warm pool fill up&lt;/span&gt;
kubectl get sandboxwarmpool python-agent-pool &lt;span class="nt"&gt;-w&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h3&gt;
  
  
  Step 6 — Install the Python Client and Run Your First Sandbox
&lt;/h3&gt;

&lt;p&gt;Install the client locally and open a dev tunnel to the Sandbox Router. This is the fastest way to test without setting up Ingress.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="c"&gt;# Install the client&lt;/span&gt;
pip &lt;span class="nb"&gt;install &lt;/span&gt;agentic-sandbox-client

&lt;span class="c"&gt;# Get credentials for your cluster&lt;/span&gt;
gcloud container clusters get-credentials &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt;

&lt;span class="c"&gt;# Open dev tunnel to the Sandbox Router&lt;/span&gt;
kubectl port-forward svc/sandbox-router-svc 8080:8080
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Now in a new terminal tab, claim your first sandbox. Save this as &lt;code&gt;test_sandbox.py&lt;/code&gt;:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="kn"&gt;from&lt;/span&gt; &lt;span class="n"&gt;agent_sandbox&lt;/span&gt; &lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="n"&gt;SandboxClient&lt;/span&gt;
&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="n"&gt;asyncio&lt;/span&gt;

&lt;span class="k"&gt;async&lt;/span&gt; &lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;main&lt;/span&gt;&lt;span class="p"&gt;():&lt;/span&gt;
    &lt;span class="n"&gt;client&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nc"&gt;SandboxClient&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;dev_mode&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="bp"&gt;True&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

    &lt;span class="c1"&gt;# claim from warm pool — should be sub-second
&lt;/span&gt;    &lt;span class="n"&gt;sandbox&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="n"&gt;client&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;claim&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
        &lt;span class="n"&gt;template&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;python-agent-runtime&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
    &lt;span class="p"&gt;)&lt;/span&gt;
    &lt;span class="nf"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sa"&gt;f&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Sandbox claimed: &lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="n"&gt;sandbox&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nb"&gt;id&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

    &lt;span class="c1"&gt;# run code inside the isolated sandbox
&lt;/span&gt;    &lt;span class="n"&gt;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="n"&gt;sandbox&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;execute&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
        &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;print(&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="s"&gt;Hello from inside gVisor isolation!&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="s"&gt;)&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
    &lt;span class="p"&gt;)&lt;/span&gt;
    &lt;span class="nf"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sa"&gt;f&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Output: &lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="n"&gt;result&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;stdout&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

    &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="n"&gt;sandbox&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;release&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
    &lt;span class="nf"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Sandbox released back to pool.&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

&lt;span class="n"&gt;asyncio&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;run&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nf"&gt;main&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Run it:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;python test_sandbox.py
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;✅ &lt;strong&gt;Expected output:&lt;/strong&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Sandbox claimed: sandbox-abc123
Output: Hello from inside gVisor isolation!
Sandbox released back to pool.
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Teardown when done&lt;/strong&gt; to avoid unexpected charges:&lt;/p&gt;


&lt;pre class="highlight shell"&gt;&lt;code&gt;gcloud container clusters delete &lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;CLUSTER_NAME&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="nt"&gt;--region&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="k"&gt;${&lt;/span&gt;&lt;span class="nv"&gt;REGION&lt;/span&gt;&lt;span class="k"&gt;}&lt;/span&gt; &lt;span class="nt"&gt;--quiet&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/blockquote&gt;

&lt;p&gt;&lt;strong&gt;Total time from zero to first sandboxed execution: ~15 minutes.&lt;/strong&gt; Compare that to the days you'd spend wiring up the DIY equivalent.&lt;/p&gt;




&lt;h2&gt;
  
  
  The Core Concepts — Fast
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;1. SandboxTemplate + SandboxClaim&lt;/strong&gt;&lt;br&gt;
Template is the reusable blueprint — runtime class, resource limits, image. Claim is how your app requests one. Separation of concerns: infra team owns the template, your orchestrator just creates claims.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;2. SandboxWarmPool&lt;/strong&gt;&lt;br&gt;
Declares how many pre-warmed, pre-initialized sandboxes to keep ready. When a claim comes in, it grabs one from the pool instead of cold-starting. This is where sub-second latency comes from.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;3. Sandbox Router&lt;/strong&gt;&lt;br&gt;
A stable ClusterIP endpoint that routes traffic to the right sandbox pod. In dev mode, tunnel with &lt;code&gt;kubectl port-forward&lt;/code&gt;. In prod, your orchestrator talks to the router directly with RBAC or Workload Identity auth.&lt;/p&gt;




&lt;h2&gt;
  
  
  The Open Source Angle — Why It Matters Architecturally
&lt;/h2&gt;

&lt;p&gt;GKE Agent Sandbox is a managed wrapper around the &lt;code&gt;kubernetes-sigs/agent-sandbox&lt;/code&gt; open-source controller. This is not a detail — it's load-bearing for your architecture decisions.&lt;/p&gt;

&lt;p&gt;The &lt;code&gt;SandboxClaim&lt;/code&gt;, &lt;code&gt;SandboxTemplate&lt;/code&gt;, and &lt;code&gt;SandboxWarmPool&lt;/code&gt; CRDs are becoming a vendor-neutral standard under SIG Apps. Build your orchestrator against these primitives today, and you're not locked into GKE. Any cluster that runs the open-source controller speaks the same API.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;You're not betting on Google. You're betting on an emerging Kubernetes standard.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  Honest Critique — What's Still Missing
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Pod Snapshots is still preview.&lt;/strong&gt; The resume-from-state story is the most compelling feature for long-running agents, and it's not fully baked yet. The rest of the system is solid, but this is the piece you'll want before committing to the architecture for stateful multi-step agents.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The Python SDK is the only first-class client.&lt;/strong&gt; If your orchestrator is in Go, TypeScript, or anything else, you're talking raw Kubernetes API for now. Workable, but it pushes complexity back onto you.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Dev mode uses kubectl port-forward.&lt;/strong&gt; Fine for local testing but your dev/prod parity story needs thought. The production path with RBAC/Workload Identity is genuinely different from the tunnel-based dev path.&lt;/p&gt;




&lt;h2&gt;
  
  
  Bottom Line
&lt;/h2&gt;

&lt;p&gt;If you're running agents that execute untrusted code and you're not using something like this — &lt;strong&gt;you have a security incident waiting to happen.&lt;/strong&gt; The DIY path is not a permanent solution; it's a liability you're carrying.&lt;/p&gt;

&lt;p&gt;Agent Sandbox gives you kernel-level isolation, sub-second provisioning, and a clean Python SDK, all backed by an open standard that won't trap you. The snapshots piece isn't fully there yet — but everything else is production-ready today.&lt;/p&gt;

&lt;p&gt;The agentic AI era needed proper infrastructure. Not workarounds, not duct tape, not "good enough for now." GKE Agent Sandbox is that infrastructure — and it's available today. Your next agent deserves better than the hack you're currently running. Ship it right.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;GKE Agent Sandbox is GA as of Google Cloud Next '26, April 22, 2026. Requires GKE v1.35.2-gke.1269000+.&lt;/em&gt;&lt;br&gt;
&lt;em&gt;Open-source controller: github.com/kubernetes-sigs/agent-sandbox&lt;/em&gt;&lt;br&gt;
&lt;em&gt;Official docs: cloud.google.com/kubernetes-engine/docs/how-to/agent-sandbox&lt;/em&gt;&lt;/p&gt;

</description>
      <category>devchallenge</category>
      <category>cloudnextchallenge</category>
      <category>googlecloud</category>
    </item>
  </channel>
</rss>
