<?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>Forem: RizAli12</title>
    <description>The latest articles on Forem by RizAli12 (@rizali12).</description>
    <link>https://forem.com/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>Forem: RizAli12</title>
      <link>https://forem.com/rizali12</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/rizali12"/>
    <language>en</language>
    <item>
      <title>No Settings. No Setup. No Explanation. Your Google AI and Automation Just Got Dramatically Better — And Non-Coders Deserve to Know Why.</title>
      <dc:creator>RizAli12</dc:creator>
      <pubDate>Thu, 30 Apr 2026 09:25:49 +0000</pubDate>
      <link>https://forem.com/rizali12/no-settings-no-setup-no-explanation-your-google-ai-and-automation-just-got-dramatically-better--42bc</link>
      <guid>https://forem.com/rizali12/no-settings-no-setup-no-explanation-your-google-ai-and-automation-just-got-dramatically-better--42bc</guid>
      <description>&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;If you use AI tools for your business — Gemini, AppSheet, Make, Zapier, Google Workspace — this is written for you. No Kubernetes. No terminals. No jargon. Just what actually changed and why it matters.&lt;/strong&gt;&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  The Real Problem
&lt;/h2&gt;

&lt;p&gt;You've been building AI-powered workflows. Automations in Make or Zapier. Agents in Gemini Enterprise. Assistants in AppSheet. You clicked the buttons, connected the tools — and watched it &lt;strong&gt;mostly&lt;/strong&gt; work.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Mostly.&lt;/strong&gt; That word is doing a lot of heavy lifting right now, isn't it?&lt;/p&gt;

&lt;p&gt;An agent that touches data it shouldn't. A workflow that takes three minutes to spin up. A task that crashes halfway through and starts over from zero. You didn't build those problems. But you've been absorbing the cost of them — in time, in trust, in budget.&lt;/p&gt;

&lt;p&gt;And here's what nobody told you: &lt;strong&gt;the problem was never your workflow. It was the environment your agents were running in.&lt;/strong&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;AI agents are only as reliable as the environment they run in. And until now? That environment was fragile, slow, and frankly dangerous for your business data. That just changed. Completely.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  What Just Dropped — And Why Nobody Explained It To You
&lt;/h2&gt;

&lt;p&gt;At Google Cloud Next '26, buried at announcement &lt;strong&gt;#122 out of 260&lt;/strong&gt; — which is honestly criminal — Google launched something called &lt;strong&gt;GKE Agent Sandbox&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Now, that name sounds like something only a DevOps engineer cares about at 2am. But stay with us — because this is the announcement that will actually change how your AI tools perform every single day.&lt;/p&gt;

&lt;p&gt;Think of it this way: every AI agent you use lives somewhere. It runs on infrastructure — servers, containers, systems — that decide how fast it starts, how safely it operates, and whether it can touch things it shouldn't. Until now, that infrastructure was fragile and slow. &lt;strong&gt;Google just rebuilt it from the ground up.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;And the best part? Every no-code platform built on Google Cloud — Gemini Enterprise, AppSheet, Vertex AI Agent Builder — quietly inherits every single upgrade. &lt;strong&gt;You don't install anything. You don't configure anything. It just arrives.&lt;/strong&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  The Numbers — In Plain English
&lt;/h2&gt;

&lt;p&gt;Here's what changed under the hood, translated for humans:&lt;/p&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;What Google improved&lt;/th&gt;
&lt;th&gt;What it means for you&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;300 sandboxes per second per cluster&lt;/td&gt;
&lt;td&gt;Your agent is ready before you finish clicking&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Sub-second startup — down from minutes&lt;/td&gt;
&lt;td&gt;No more staring at a loading screen&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;30% better price-performance&lt;/td&gt;
&lt;td&gt;Your platform costs less to run — savings get passed down&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Kernel-level isolation&lt;/td&gt;
&lt;td&gt;Your agent literally cannot touch what it shouldn't&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;




&lt;h2&gt;
  
  
  What This Actually Means For Your Work
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Your agents can't break other things — ever.&lt;/strong&gt;&lt;br&gt;
Every agent now runs sealed inside its own isolated container. It cannot reach your other data, apps, or systems. It does its job — and it's gone. Think of it like a disposable glove. It never leaks. It never oversteps.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Instant. Not "almost instant."&lt;/strong&gt;&lt;br&gt;
Pre-warmed pools mean your agent is already running before you finish clicking the button. Those 2–3 minute cold starts that made you question whether the automation even worked? Gone. Under one second, every time.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;It picks up exactly where it stopped.&lt;/strong&gt;&lt;br&gt;
A new feature called Pod Snapshots means agents can pause mid-task and resume from the exact same point — like saving a video game. No restarts. No lost progress. No "it crashed and now I have to start over."&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Works all night. Without you.&lt;/strong&gt;&lt;br&gt;
Long-running agents can now operate in secure background environments for hours. Set your automation before you sleep. Come back to completed work at 9am. That's not a sales promise — that's the technical specification.&lt;/p&gt;




&lt;h2&gt;
  
  
  Before vs. After — No Jargon
&lt;/h2&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Before&lt;/th&gt;
&lt;th&gt;After&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;Agents ran in shared, risky environments&lt;/td&gt;
&lt;td&gt;Every agent sealed in its own isolated space&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;2–3 minute spin-up every single time&lt;/td&gt;
&lt;td&gt;Sub-second readiness — pre-warmed and waiting&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Crash mid-task? Start completely over&lt;/td&gt;
&lt;td&gt;Snapshots save state — resume, don't restart&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Rogue agents could touch what they shouldn't&lt;/td&gt;
&lt;td&gt;Isolation means agents literally can't escape&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Idle agents quietly burning your budget&lt;/td&gt;
&lt;td&gt;Idle sandboxes auto-suspended — costs drop&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;




&lt;h2&gt;
  
  
  The Critique Nobody's Saying Out Loud
&lt;/h2&gt;

&lt;p&gt;Here's what genuinely frustrates me about this announcement: &lt;strong&gt;Google barely talked about it.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;The keynote was dominated by Gemini Enterprise Agent Platform — the shiny new interface for building agents. Fair enough, it looks impressive. But the platform is a product. GKE Agent Sandbox is &lt;strong&gt;infrastructure&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;And here's the thing about infrastructure: products come and go. Infrastructure compounds. Six months from now, when your AI tools feel faster and more reliable and you can't quite put your finger on why — &lt;strong&gt;this is why.&lt;/strong&gt; You'll never see a changelog entry crediting it. It'll just quietly work better.&lt;/p&gt;

&lt;p&gt;That's how good infrastructure behaves. Invisibly. Relentlessly.&lt;/p&gt;

&lt;p&gt;One more thing worth knowing: GKE Agent Sandbox is &lt;strong&gt;open source&lt;/strong&gt;. This is not a Google lock-in play. Every cloud platform can adopt this standard. You're not betting on Google — you're betting on an emerging industry standard that will outlast any single company's product roadmap.&lt;/p&gt;




&lt;h2&gt;
  
  
  Real Scenarios Where This Changes Things
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;The solopreneur running overnight automations&lt;/strong&gt;&lt;br&gt;
You've set up a Gemini agent to process customer inquiries while you sleep. Before: it occasionally crashed, touched the wrong spreadsheet, or took 4 minutes to spin up per batch. After: sealed, instant, and resumable if anything interrupts it. You wake up to clean results.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The marketing manager running AI content pipelines&lt;/strong&gt;&lt;br&gt;
Your team uses AppSheet agents to draft, review, and queue social content. Before: someone always had to babysit it. After: it runs in the background, isolated, fast, and picks up exactly where it left off if anything pauses it. Your team focuses on strategy, not supervision.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The small business owner with a customer-facing AI agent&lt;/strong&gt;&lt;br&gt;
Your booking or ordering agent is the first thing customers interact with. Before: slow spin-ups meant frustrated customers. After: sub-second readiness means your agent is always there, always fast, always safe. It never touches data it shouldn't.&lt;/p&gt;




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

&lt;p&gt;You don't need to understand a single line of infrastructure code to benefit from this. You just need to understand one thing:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The AI agents you're already using just got safer, faster, and more capable — automatically, in the background, at a scale that was physically impossible six months ago.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;This is the upgrade your AI tools have been waiting for, whether you knew to ask for it or not. Google buried it at announcement #122. The developers noticed. Now you should too.&lt;/p&gt;

&lt;p&gt;And once your agents start performing at this level — you won't be able to imagine going back.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;Announced at Google Cloud Next '26, Las Vegas — April 22, 2026. GKE Agent Sandbox is now generally available as a managed GKE add-on. Open-source controller available at github.com/kubernetes-sigs/agent-sandbox&lt;/em&gt;&lt;/p&gt;

</description>
      <category>googlecloud</category>
      <category>ai</category>
      <category>productivity</category>
      <category>automation</category>
    </item>
    <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://forem.com/rizali12/stop-duct-taping-your-agent-sandbox-gke-just-built-it-properly-2lm1</link>
      <guid>https://forem.com/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>
