Document the operational routine + ship automation templates
Until opencode session-stopping hooks land upstream, mempalace-session
is the entire mechanism that gets opencode conversations into the
palace — skip it and session history stays trapped in a local SQLite
DB, invisible to semantic search. Previous docs covered setup well
but were thin on when and how often to run it.
- ARCHITECTURE.md §5: replace the one-line 'When to re-mine' note with
a full Operational Routine section — triggers, cadence, relationship
to the session lifecycle, automation pointers, verification.
- SKILL.md: add an Operational Routine section aimed at agents —
when to suggest invoking the tool, cadence guidance, how to
distinguish this producer-side tool from the consumer-side
mempalace skill's in-session habits.
- README.md: add 'Keeping it fresh' subsection pointing at contrib/
and the full docs.
contrib/ ships three ready-to-use templates:
- systemd/mempalace-session.{service,timer} — user units with weekly
Mon 03:00 schedule, Persistent=true catch-up, RandomizedDelaySec for
fleet-wide jitter, ConditionPathExists guard for opencode-less boxes,
Nice+IOSchedulingClass=idle so it never fights interactive work.
- cron/mempalace-session.cron — sample crontab entry with log
redirection and clear USER-substitution instructions.
- README.md with install/verify/uninstall recipes for both, a chooser
table (systemd vs cron), container/devbox caveats, and tuning notes
(daily vs weekly vs monthly trade-offs).
The user's LATER-list item 'wrap mempalace-session in cron/systemd
timer for true auto-save coverage' is now actionable: a single
systemctl --user enable --now command stands it up.
This commit is contained in:
+85
-1
@@ -188,7 +188,91 @@ Both wrappers dedup via `mempalace mine`'s built-in key:
|
||||
### When to re-mine
|
||||
|
||||
- `mempalace-docs`: after significant doc changes in a project.
|
||||
- `mempalace-session`: opportunistically. Every few days catches new opencode sessions. Or wire to cron / systemd timer for true auto-save coverage (not yet done).
|
||||
- `mempalace-session`: see the full **Operational Routine** below.
|
||||
|
||||
### Operational Routine (the `mempalace-session` workflow)
|
||||
|
||||
Until opencode grows session hooks and `hooks_cli.py` grows an opencode harness (see §6), **`mempalace-session` is the entire mechanism that gets opencode conversations into the palace.** Skip it and your session history exists only inside `~/.local/share/opencode/opencode.db` — a local SQLite file that's invisible to `mempalace_search`, vulnerable to volume wipes, and lost if the devbox is replaced.
|
||||
|
||||
That makes the routine worth codifying:
|
||||
|
||||
#### Triggers (when to run)
|
||||
|
||||
| Trigger | What to run | Why |
|
||||
|---|---|---|
|
||||
| **Substantive session you want preserved past `/exit`** | `mempalace-session --session <id>` | Targeted save before destructive action; see `~/.local/share/opencode/opencode.db` `session` table for the ID. |
|
||||
| **Before a container recreate** | `mempalace-session` | The opencode DB lives in a named volume (`devbox-data`) so it normally survives, but a full mine right before is cheap insurance. |
|
||||
| **Fresh machine, first provisioning** | `mempalace-session --dry-run` then `mempalace-session` | Backfills the whole corpus. Expect ~20 min / 60 sessions. |
|
||||
| **Periodic sweep** | `mempalace-session` | Weekly catches anything you didn't explicitly save. Dedup is free, so running more often only costs the ~5 min repair. |
|
||||
| **After upstream mempalace upgrade** | `mempalace-session` + `mempalace repair` | If the miner changed normalization or chunking, re-mine ensures the palace reflects current logic. Rare. |
|
||||
|
||||
#### Cadence (how often)
|
||||
|
||||
**Default: weekly.** Dedup is free on unchanged sessions, and `wing_conversations` growth is roughly linear in user activity. Weekly is frequent enough that searches almost always include recent context, and infrequent enough that the cost is negligible.
|
||||
|
||||
**Daily** is fine but wasteful — you'll pay the post-mine `repair` cost seven times more often than you need. If you want daily runs, add `--no-repair` and schedule a separate weekly repair.
|
||||
|
||||
**Monthly** is too infrequent. You'll search for "that thing we discussed last Tuesday" and miss it.
|
||||
|
||||
#### Relationship to the session lifecycle
|
||||
|
||||
`mempalace-session` is **offline, inter-session maintenance** — it runs between agent sessions, not during them. It does not replace the in-session habits from the consumer-side `mempalace` skill:
|
||||
|
||||
| Habit | When | Who |
|
||||
|---|---|---|
|
||||
| Wake-up search (load recent diary) | Agent session start | Agent, during session |
|
||||
| Wind-down diary write | Agent session end | Agent, during session |
|
||||
| `mempalace-session` mine | Between sessions (manual or scheduled) | Operator or automation |
|
||||
|
||||
The first two are live; the third is batched. They're complementary, not alternatives. A machine doing only wake-up/wind-down keeps a diary but loses the actual conversation turns. A machine doing only `mempalace-session` captures the raw turns but not the curated summaries. Do both.
|
||||
|
||||
#### Automation
|
||||
|
||||
Pick one:
|
||||
|
||||
1. **systemd user timer** (recommended on modern Linux). Survives reboots, optional `Persistent=true` catch-up, logs to `journalctl`, background I/O priority. Templates in [`contrib/systemd/`](contrib/systemd/).
|
||||
2. **cron** (simpler, works anywhere). Templates in [`contrib/cron/`](contrib/cron/).
|
||||
3. **Manual** — run `mempalace-session` opportunistically. Fine on machines where you're in and out frequently; less fine on long-running devboxes.
|
||||
|
||||
Install recipes, verification commands, and uninstall steps for all three are in [`contrib/README.md`](contrib/README.md).
|
||||
|
||||
Quick-start (systemd user timer):
|
||||
|
||||
```bash
|
||||
mkdir -p ~/.config/systemd/user
|
||||
cp contrib/systemd/*.{service,timer} ~/.config/systemd/user/
|
||||
systemctl --user daemon-reload
|
||||
systemctl --user enable --now mempalace-session.timer
|
||||
# Optional on headless boxes: keep timer running when logged out
|
||||
sudo loginctl enable-linger "$USER"
|
||||
systemctl --user list-timers mempalace-session.timer
|
||||
```
|
||||
|
||||
Quick-start (cron):
|
||||
|
||||
```bash
|
||||
sed "s|USER|$USER|g" contrib/cron/mempalace-session.cron \
|
||||
| (crontab -l 2>/dev/null; cat) | crontab -
|
||||
mkdir -p ~/.cache/mempalace-session
|
||||
```
|
||||
|
||||
#### Verification
|
||||
|
||||
After any run (manual or scheduled), confirm the palace grew:
|
||||
|
||||
```bash
|
||||
mempalace-session --dry-run # should list sessions
|
||||
# Or from inside a live MCP client:
|
||||
# mempalace_status — wing_conversations count
|
||||
# mempalace_reconnect — refresh index after mine
|
||||
```
|
||||
|
||||
A healthy run produces one of:
|
||||
- **First run on fresh corpus**: several hundred to several thousand new drawers.
|
||||
- **Incremental run**: zero to a few dozen new drawers (whatever grew since last run).
|
||||
- **Rerun with no new activity**: zero new drawers, only the repair step runs.
|
||||
|
||||
A run that files far more drawers than expected may indicate a staging-dir wipe (forcing a full re-mine) — check `~/.cache/mempalace-session/<wing>/` modification times.
|
||||
|
||||
### Cost profile (reference)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user