Claude Cowork runs Linux VM via Apple virtualization framework

gist.github.com

110 points

jumploops

2 days ago


39 comments

lysace 17 hours ago

Is there an easy way to do something similar for Claude Code? I'm growing tired of babysitting it to make sure it doesn't do anything bad.

Late adopter. Started last night. Stayed up four hours past my normal bedtime because I couldn't stop. (Ended up "building" a fancy .MOD player for DOS in Turbo C.)

Needed the Max 5x plan after two hours. (The 'Pro' plan should be renamed 'Sampler', made one-time and free with CC details.) Max 5x seems like it can sustain my current appetite.

I very quickly went from thinking it was overpriced (around 100 USD/month) to worrying that this pricing can't last. I think I get about 50 working hours per week with this plan. So, running the numbers I guess the hourly cost is about 50 cents.

  • realityfactchex 15 hours ago

    Isn't the easy way just a development VM? As in:

    Install your OS of choice in a virtual machine, e.g. even hosted on your main machine.

    Install the AI coding tool in the virtual machine.

    Set up a shared folder between host+guest OS.

    Only let the VM access files that are "safe" for it to access. Its own repo, in its own folder.

    If you want to give the AI tool and VM internet access and tool access, just limit what it can reach to things it is allowed to go haywire on. All the internet and all OS tools are ok. But don't let this AI do "real things" on "real platforms" -- limit the scope of what it "works on" to development assets.

    When deploying to staging or prod, copy/sync files out of the shared folder that the AI develops on, and run them. But check them first for subterfuge.

    So, don't give the AI access to "prod" configs/files/services/secrets, or general personal/work data, etc. Manage those in other "folders" entirely, not accessible by the development VM at all.

    Is that close?

  • linkregister 16 hours ago

    From within VSCode, you can run devcontainers, which bind mounts the project's directory into an isolated Docker container. Safe for --dangerously-skip-permissions

    https://code.visualstudio.com/docs/devcontainers/containers

    • mbreese 16 hours ago

      As a note, running devcontainers in VSCode is easy, but not required. There is also a CLI tool that uses the same specifications.

      You can install it with brew or npm.

      • pwagland 13 hours ago
        2 more

        I assume that you are talking about the [devcontainers LCI](https://github.com/devcontainers/cli) when you say "a CLI"?

        • mbreese 12 hours ago

          Yes. I probably should have included the link.

          I stated using devcontainers through VSCode and find them incredibly helpful. It’s great for me to be able to load up exact coding environments on different computers. But, I only used them through VSCode.

          When I wanted to branch out a bit (and especially using coding agents), I started using the CLI version more. I find devcontainers a great way to work with different coding projects and wanted to make sure people knew that there was a way to use them outside of VSCode.

    • bugglebeetle 15 hours ago

      Tried this the other day and the setup on this is super cumbersome and requires you to constantly rebuild your entire dev and Claude Code environment every time you use a new container, including whitelisting URLs for package managers and the like.

      • andrewmutz 15 hours ago
        2 more

        There are techniques to mitigate this. You can reuse containers instead of creating a new one each time. You can mount in directories (like ~/.claude) from your local machine so you dont have to set claude up each time.

  • greggh 16 hours ago

    Use a devcontainer. Claude Code's repo has one built specifically for it:

    https://github.com/anthropics/claude-code/tree/main/.devcont...

    • avsm 15 hours ago

      The Claude Code devcontainer works really well, especially the firewalling script! I had do a bit of GitHub Actions spelunking to figure out how to build binary images (with my own devtools preinstalled), which I wrote up here: https://anil.recoil.org/notes/ocaml-claude-dev

      With this I have a nice loop where I get Claude to analyse its own sessions via a cronjob and rewrite my devcontainer Dockerfile to have any packages that I've started using during the interactive sessions. This rebuilds via GHActions and my fresh image the next day has an updated Claude and dev environment in a sandbox.

  • jmacd 16 hours ago

    Docker desktop has a pretty nice sandbox feature that will also store your CC (and other) credentials, so you don't have to re-auth every time you create a new container.

    • avsm 15 hours ago

      Funnily enough, we shipped the Docker Desktop VM a decade ago now (experience report at https://dl.acm.org/doi/10.1145/3747525). The embedded VM in DD is much more stripped down than the one in Claude Cowork (its based on https://github.com/linuxkit/linuxkit), and its more specialised to container workloads rather than just using bubblewrap for sandboxing (system services run in their own isolated namespaces).

      Given how many products seem to be using this shipping-Linux-as-a-library-VM trick these days, it's probably a good time for an open source project to step up to supply a more reusable way of assembling this layer into a proper Mac library...

  • zackify 11 hours ago

    I have 30 lines of zsh and I just say "dev1" dev2 etc.

    And it makes a new lxd container using my base image. Connects using tmux so I can resume anytime after closing the session.

    Its like exe.dev or sprites without much effort if you want to self host.

  • nullishdomain 6 hours ago

    yolobox is the easiest I have found. Basically a batteries included image with a bit of sugar. https://github.com/finbarr/yolobox

    `yolobox run claude` launches Claude Code with --dangerously-skip-permissions mode inside of a container with a good set of default tools included.

  • cloudking 16 hours ago
    • e12e 16 hours ago

      > The sandboxed bash tool uses OS-level primitives to enforce both filesystem and network isolation.

      As I can't trust Claude Code to use a correct shell, I don't know why I would trust this feature.

    • azuanrb 12 hours ago

      Note that there are reports that it can disable sandbox, so personally I wouldn't trust this.

  • sirmoveon 15 hours ago

    Maybe not easy or for everyone but you can set a Virtualbox VM running a headless linux of your choice, install directory sharing like samba and your AI agents of choice. Then you can just have multiple SSH sessions to interact with the agents and `tail` logs.

  • Wowfunhappy 10 hours ago

    Well, one very easy way would be to use the web version of Claude Code.

  • aprilnya 15 hours ago

    Claude Code on web is okay in the meantime if you want to set it loose but not on your own machine.

  • giancarlostoro 16 hours ago

    I mean, it depends on what you're doing but I force claude to always commit code every time it finishes a todo. It never seems to stop doing that, so I run it in dangerous mode on Zed. I get to review the code after the fact anyway.

  • colechristensen 14 hours ago

    I built something to use for myself which is organized workspaces to work on many things with Claude in parallel with the ability to run things in VMs and linked web browsers all contained in one app. I built it mostly driven by trying to work on too many things at once and getting lost in a sea of windows and browser tabs.

    It is not at all ready for public consumption (a face only a mother could love, in other words it's a bugridden mess), but I've considered polishing it and releasing it to the public either as open source or for profit.

    Most of it is written with Claude and I've run into roadblocks with Claude being able to do too many things at once and am rewriting as several libraries to improve the focus for Claude agents.

  • bigyabai 11 hours ago

    Genuine advice: supplement your Claude Code plan with a GLM Coding plan: https://z.ai/subscribe

    GLM 4.7 is not a "Sonnet killer" but it will work just as well for sketching out easier projects, web design and terminal usage. After a while I cancelled my Claude Code plan because I simply didn't do anything that GLM couldn't hammer out equally as well.

Jayakumark 15 hours ago

How about the windows App ?

  • dijit 15 hours ago

    Is that even a sandbox?

    I thought it was just a wrapper around an (old) existing tool that has been infinitely rebranded. Their old "remote desktop" program and some web listing capabilities to launch it in "rootless" mode.

  • weikju 9 hours ago

    Cowork is only available on macOS for now I think.