container-use

from olafgeibig/skills

my agent skills

0 stars0 forksUpdated Jan 21, 2026
npx skills add https://github.com/olafgeibig/skills --skill container-use

SKILL.md

Apple Container Usage

Guide for using Apple's container tool to run Linux containers on macOS.

TL;DR

container runs Linux containers in lightweight virtual machines (one VM per container) on macOS 26+ (Apple Silicon). It creates a native, secure, and performant alternative to Docker Desktop.

When to Use

  • You want to run Linux containers on macOS without the overhead of Docker Desktop.
  • You need strong isolation (VM per container).
  • You are developing on macOS 26+ with Apple Silicon.
  • You want to build multi-platform images (arm64/amd64).

Installation

  1. Download: Get the latest signed .pkg from GitHub Releases.
  2. Install: Double-click the .pkg and follow instructions.
  3. Start Service:
    container system start
    

Common Workflows

1. Running Containers

Basic run (similar to Docker):

# Run interactive alpine shell
container run -it --rm alpine:latest sh

# Run web server detached with port mapping
container run -d --name web -p 8080:80 nginx:latest

Key Options:

  • --cpus <count>: Limit CPUs (default: 4)
  • --memory <size>: Limit RAM (default: 1G). e.g., --memory 4g
  • --volume <host>:<container>: Mount volumes.
    container run -v ~/project:/code python:3.9
    
  • --ssh: Forward host SSH agent (great for git in containers).
    container run --ssh -it ubuntu git clone git@github.com:me/repo.git
    
  • --mac-address <addr>: Set custom MAC address.

2. Building Images

Builds run in a special builder VM.

# Build current directory
container build -t my-app:latest .

# Build for multiple architectures
container build --arch arm64 --arch amd64 -t my-app:multi .

Tip: Increase builder resources if builds are slow:

container builder start --cpus 8 --memory 16g

3. Managing State

# List running containers
container ls

# List all (including stopped)
container ls -a

# Stop/Start
container stop <name>
container start <name>

# View logs
container logs -f <name>

# Monitor stats (CPU/RAM)
container stats

4. Networking

Apple Containers use vmnet. Each network is isolated.

# Create a new isolated network
container network create backend --subnet 192.168.100.0/24

# Run container in network
container run --network backend nginx

References

  • Tutorial - Guided tour of building and running a simple web server.
  • How-to Guide - Tasks like sharing files, multi-platform builds, and networking.
  • Command Reference - Comprehensive list of CLI commands and options.

Migration from Docker

Docker CommandContainer CommandNotes
docker run ...container run ...Mostly compatible flags (-v, -p, -d, -it)
docker pscontainer ls
docker build ...container build ...
docker logs ...container logs ...
docker exec ...No direct equivalent yetUse ssh or attach if supported, or design containers to not need exec.
docker network ...container network ...

Key Differences:

  • Architecture: Docker Desktop uses one big VM. container uses one lightweight VM per container. This improves isolation but changes resource usage patterns.
  • Storage: Images and containers are stored in ~/Library/Containers/....
  • Daemon: The daemon (vminitd) runs per-container inside the VM.

Troubleshooting

System Logs: If something fails, check the system logs:

container system logs

Uninstall: To remove everything (including data):

/usr/local/bin/uninstall-container.sh -d

Repository Stats

Stars0
Forks0
LicenseApache License 2.0