Reference
Persistence & Sleep
- Persistent filesystem backs
/home/userautomatically - Session transcripts persisted with sequence numbers for replay
- Configurable sleep with a 15-minute grace period by default
- Automatic wake when a client connects or a cron job triggers
What persists across sleep
Section titled “What persists across sleep”| Data | Storage | Persists? |
|---|---|---|
Files in /home/user | Persistent filesystem | Yes |
| Session records | SQLite (agent_os_sessions) | Yes |
| Session event history | SQLite (agent_os_session_events) | Yes |
| Preview URL tokens | SQLite (agent_os_preview_tokens) | Yes |
| Cron job definitions | Actor state | Yes |
| Running processes | VM kernel | No |
| Active shells | VM kernel | No |
| In-memory mounts | VM memory | No |
| VM kernel state | VM memory | No |
What prevents sleep
Section titled “What prevents sleep”The actor stays awake as long as any of these are active:
- Active sessions (created but not closed/destroyed)
- Running processes (spawned but not exited)
- Active shells (opened but not closed)
- Pending hooks (server-side callbacks still executing)
When all activity stops, the sleep grace period begins.
Sleep grace period
Section titled “Sleep grace period”After all activity stops, the actor waits 15 minutes before sleeping. This allows for brief pauses between interactions without restarting the VM.
Activity stops ──> 15 min grace period ──> Actor sleeps (VM shutdown, processes killed)
New client connects ──> Actor wakes ──> VM boots ──> Filesystem restoredSleep vs destroy
Section titled “Sleep vs destroy”| Sleep | Destroy | |
|---|---|---|
| Filesystem | Preserved | Deleted |
| Session records | Preserved | Deleted |
| Event history | Preserved | Deleted |
| Preview tokens | Preserved | Deleted |
| VM state | Lost | Lost |
| Processes | Killed | Killed |
VM boot and shutdown events
Section titled “VM boot and shutdown events”Subscribe to vmBooted and vmShutdown events to track VM lifecycle.
import { createClient } from "rivetkit/client";import type { registry } from "./server";
const client = createClient<typeof registry>("http://localhost:6420");const agent = client.vm.getOrCreate(["my-agent"]);
agent.on("vmBooted", () => { console.log("VM is ready");});
agent.on("vmShutdown", (data) => { console.log("VM shutdown reason:", data.reason); // reason: "sleep" | "destroy" | "error"});import { agentOs } from "rivetkit/agent-os";import { setup } from "rivetkit";import common from "@rivet-dev/agent-os-common";import pi from "@rivet-dev/agent-os-pi";
const vm = agentOs({ options: { software: [common, pi] },});
export const registry = setup({ use: { vm } });registry.start();Resuming after sleep
Section titled “Resuming after sleep”When the actor wakes up:
- The VM boots and the filesystem is restored from SQLite
- Session records and event history are available immediately
- Processes and shells from the previous session are gone
- Clients can reconnect and resume sessions using
resumeSession - Use
getSessionEventsto replay missed events
import { createClient } from "rivetkit/client";import type { registry } from "./server";
const client = createClient<typeof registry>("http://localhost:6420");const agent = client.vm.getOrCreate(["my-agent"]);
// List sessions from before sleepconst sessions = await agent.listPersistedSessions();console.log("Previous sessions:", sessions.length);
// Resume the most recent sessionif (sessions.length > 0) { const last = sessions[0]; await agent.resumeSession(last.sessionId);
// Replay events for transcript const events = await agent.getSessionEvents(last.sessionId); for (const e of events) { console.log(e.seq, e.event.method); }}import { agentOs } from "rivetkit/agent-os";import { setup } from "rivetkit";import common from "@rivet-dev/agent-os-common";import pi from "@rivet-dev/agent-os-pi";
const vm = agentOs({ options: { software: [common, pi] },});
export const registry = setup({ use: { vm } });registry.start();Persisted tables schema
Section titled “Persisted tables schema”agent_os_fs_entries
Section titled “agent_os_fs_entries”Stores the virtual filesystem.
| Column | Type | Description |
|---|---|---|
path | TEXT PRIMARY KEY | File or directory path |
is_directory | INTEGER | 1 for directory, 0 for file |
content | BLOB | File content |
mode | INTEGER | POSIX mode bits |
size | INTEGER | File size in bytes |
atime_ms | INTEGER | Access time (ms) |
mtime_ms | INTEGER | Modification time (ms) |
ctime_ms | INTEGER | Change time (ms) |
birthtime_ms | INTEGER | Birth time (ms) |
agent_os_sessions
Section titled “agent_os_sessions”Stores session metadata.
| Column | Type | Description |
|---|---|---|
session_id | TEXT PRIMARY KEY | Unique session identifier |
agent_type | TEXT | Agent type (e.g. “pi”) |
capabilities | TEXT (JSON) | Agent capabilities |
agent_info | TEXT (JSON) | Agent metadata |
created_at | INTEGER | Creation timestamp (ms) |
agent_os_session_events
Section titled “agent_os_session_events”Stores session event history.
| Column | Type | Description |
|---|---|---|
id | INTEGER PRIMARY KEY | Auto-incrementing ID |
session_id | TEXT | Session reference |
seq | INTEGER | Sequence number within session |
event | TEXT (JSON) | JSON-RPC notification |
created_at | INTEGER | Timestamp (ms) |