惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

S
Securelist
O
OpenAI News
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
T
Threat Research - Cisco Blogs
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Google Online Security Blog
Google Online Security Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
N
News and Events Feed by Topic
S
Security Affairs
SecWiki News
SecWiki News
Project Zero
Project Zero
L
Lohrmann on Cybersecurity
P
Proofpoint News Feed
P
Palo Alto Networks Blog
L
LINUX DO - 最新话题
H
Hacker News: Front Page
Recent Commits to openclaw:main
Recent Commits to openclaw:main
I
Intezer
Simon Willison's Weblog
Simon Willison's Weblog
W
WeLiveSecurity
T
The Exploit Database - CXSecurity.com
K
Kaspersky official blog
The GitHub Blog
The GitHub Blog
I
InfoQ
云风的 BLOG
云风的 BLOG
雷峰网
雷峰网
B
Blog
IT之家
IT之家
AWS News Blog
AWS News Blog
Jina AI
Jina AI
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Google DeepMind News
Google DeepMind News
Spread Privacy
Spread Privacy
N
News and Events Feed by Topic
Security Latest
Security Latest
美团技术团队
C
Check Point Blog
WordPress大学
WordPress大学
T
Tenable Blog
S
Security @ Cisco Blogs
Last Week in AI
Last Week in AI
博客园 - 聂微东
月光博客
月光博客
博客园 - 【当耐特】
S
Schneier on Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
S
Secure Thoughts
Schneier on Security
Schneier on Security
C
Cisco Blogs
Cyberwarzone
Cyberwarzone

Hacker News: Show HN

PurrrrrFocus: Pomodoro Timer App - App Store Workflow Engine — Multi-Step Orchestration for Bun RapidPhoto: Pro Photo Editor App - App Store GitHub - amitb-quantum/roboapi: The unified API layer for robotics. Connect any robot, any brand, with one SDK. Like Stripe, but for robots. GitHub - manankharwar/fusioncore: ROS 2 sensor fusion SDK: UKF, 3D native, proper GNSS, zero manual tuning. Apache 2.0. Show HN: Wayland Wlroot Hjkl Everywhere Show HN: Codex context bloat? 87% avg reduction on SWE-bench Verified traces GitHub - NoahCristino/llmcat: A simple CLI that transforms your code into clean, structured text for feeding into LLMs. GitHub - actuallyepic/background-computer-use GitHub - h4ckf0r0day/obscura: The headless browser for AI agents and web scraping GitHub - anthonybudd/Express-ts-API-Template: Production-ready minimal REST API boilerplate using Express.js, Sequelize and MySQL. GitHub - molefrog/lilmd: Agent-friendly CLI for reading large Markdown files Show HN: I built a simple site to reduce tool overload and improve focus GitHub - JonathanRosado/claude-anyteam: Native Claude Code teammates, any LLM. Codex today. Gemini, Kimi, GLM, DeepSeek next. GitHub - abi/lilo Show HN: ffmpeg-render-pro – Parallel video rendering with live dashboard GitHub - adam-s/HNswered: Notifies you when someone replies to your Hacker News posts and comments. GitHub - arian-gogani/nobulex: The accountability primitive for AI agents. Cryptographic behavioral commitments with trustless verification. GitHub - Developing-Gamer/roids: Steroids for your AI agents GitHub - nellavio/nellavio: 🚀 Next.js dashboard starter with auth, i18n, 18 pages, 60+ charts and 90+ UI components Spotify – Web Player GitHub - tillahoffmann/cctape: Claude proxy to record all interactions in a local database, allowing you to browse and search sessions, track usage, and let Claude search its own history over MCP. Show HN: Rook, a macOS notes app for developers GitHub - donchuru/mr-links: Chrome extension that shows referenced links above comments on Marginal Revolution assorted links posts GitHub - anubhavgupta/whisper-npu: Speech to text at cursor using NPU. (shortcut -> win+/) SHOW HN: I built a marketplace agency that treats profit as the actual metric GitHub - trycua/cua: Open-source infrastructure for Computer-Use Agents. Sandboxes, SDKs, and benchmarks to train and evaluate AI agents that can control full desktops (macOS, Linux, Windows). GitHub - montanaflynn/headless-terminal: Headless terminal — puppeteer for TUIs (vim/emacs/htop/nethack) with a Go CLI backed by libghostty-vt The Genesis of TurboPentest.com: Bridging the Gap in an AI-Code Explosion Era GitHub - VincenzoManto/Doxa: A YAML-driven multi-agent simulation platform for economic and social systems. It combines LLM-backed agents, market microstructure, relation graphs, and world events behind a FastAPI API and a React client. GitHub - IdreesInc/PokeMesh: Collaborative Pokémon over a decentralized network, no internet required! GitHub - tamnd/python-one: Historical Python source tarballs (1.0.1 through 2.0c1) mirrored from legacy.python.org, extracted and committed at their original release dates. GitHub - dixalex/decision-linter: Decision Linter — like ESLint for your thinking. Claude Code plugin that scores assumptions, runs consider-the-opposite, and outputs judgment memos. GitHub - pitermarx/Virgulas: An Workflowy Inspired Outliner Show HN: A standalone YouTube Music popup for OBS (no plugins required) GitHub - polotno-project/render-tag: Render HTML string into canvas using 2d native API libgoc/bench/README.md at 81798b3dd5e27d7f1e752b6cff0bdf3a95d381b7 · libgoc/libgoc Show HN: Llm.sql – Run a 640MB LLM on SQLite, with 210MB peak RSS and 7.4 tok/s GitHub - RivoLink/leaf: Terminal Markdown previewer — GUI-like experience. [China AI News] Eight Chinese chip families ran DeepSeek V4 on launch day GitHub - michaelaz774/decision-engine: A decision operating system for startup founders, powered by Claude Code. Synthesizes wisdom from 25+ legendary founders and investors into interactive AI-driven decision frameworks. Sheetflow App - Webflow Apps & Integrations Questly — The Third Rail GitHub - crufter/safer: Sleep better while AI agents have shell access. gitrails/README.md at main · maxawzsinger/gitrails Show HN: RustNmap | Hacker News GitHub - 0x0funky/agent-sprite-forge: Agent Skill for generating 2D sprite sheets, transparent PNG frames, and animated GIFs from prompts. Submissions from github.com/darshanfofadiya | Hacker News GitHub - seb3773/ntfs-repair-rfc: A legally defensible, industry-grade blueprint for building an open-source NTFS structural repair engine from scratch. TOSTask - Chrome 应用商店 GitHub - Fergana-Labs/stash: Shared memory for your team's coding agents GitHub - AdirAmsalem/easl: Instant hosting for AI agents — turn output into pages worth sharing Show HN: Pdfnative – zero-dependency TypeScript PDF engine GitHub - EricNelson12/retrocycles-hilbert GitHub - ONSARI/payclaw-skill Earful — A voice-only social network GitHub - Chrilleweb/dotenv-diff: Validate environment variable usage in your codebase llms-wordpress-plugin-benchmark/README.md at main · guilamu/llms-wordpress-plugin-benchmark GitHub - agentdmai/teamfuse: Fuse Claude Code agents into a working team. AgentDM-powered template with a cabinet-style control panel, five starter roles Thedex — AI-Native Log Intelligence Introducing Universal Deploy (+server) | Vike GitHub - thomas-vilte/mls-go: MLS Protocol (RFC 9420) implementation in Go. Secure group key exchange with forward secrecy and post-compromise security for E2EE messaging. GitHub - tamnd/python-0.9.1: Python 0.9.1 from 1991, Guido van Rossum's first public release, patched to compile on modern systems GitHub - orchidfiles/ungate: Use your Claude and ChatGPT subscriptions in Cursor instead of paying for API tokens. Show HN: Rusty Browser – AI rust service spinning up AI browsers Show HN: Seleci – Pre-built AI agents that keeps your business running GitHub - SkardiLabs/skardi: Spark for Agents — a data platform that gives AI agents full data autonomy so every dataset in your stack becomes something an agent can actually use. sss/Design.md at share-hn · ekipan/sss GitHub - TwillAI/agentbox-sdk: The open-source TypeScript SDK for running AI coding agents in sandboxes. One unified API — swap agents and infrastructure providers without changing your code. GitHub - cheprasov/ts-jsbt: JavaScript Binary Transfer (JSBT) – a binary serialization format designed for JavaScript → JavaScript communication. GitHub - AI-Colleagues/skill-mgr: Agent Skill manager. Install a skill for all supported or specified agents When Your Repo Moves, Your AI Coding History Doesn’t Buffer zoom GitHub - janaraj/tnl: Structured English contracts for AI coding agents — proposed by the agent, approved by you, saved on disk, read by every future session. Show HN: Slopify – An AI agent skill to slopify a codebase GitHub - tinyhumansai/openhuman: Your Personal AI super intelligence. Private, Simple and extremely powerful. Show HN: Reducing a 66-node dependency cycle to 13 in Scrapy GitHub - NV404/gova GitHub - latitude-dev/eval-skills: LLM eval skills for developers. Free tools to find failure patterns, build evals, and improve AI quality in production GitHub - BadC-mpany/lilith-zero: ⚸ Lilith Zero - Security Middleware for MCP tool calls written in Rust. GitHub - pumpkin-bit/Flux3n1: Music generation using the Collatz conjecture formula GitHub - Lumen-Labs/brainapi2: BrainAPI is a knowledge graph–powered AI memory layer that transforms unstructured data into structured knowledge, enabling intelligent search, recommendations, and contextual memory for AI agents and applications. An agent-native static host for AI-generated sites · VibeDrop GitHub - k38f/envsleuth: 🕵️ Detective for env vars in Python code. Finds os.getenv/os.environ usages via AST and checks them against your .env file. whodb/cli at main · clidey/whodb GitHub - Higangssh/winclipshot: Windows clipboard-to-path helper for terminal CLIs like Claude Code. Screenshot with Win+Shift+S, paste the saved path with Ctrl+V GitHub - decisionbox-io/decisionbox-platform: DecisionBox connects to your data warehouse, runs autonomous AI agents that write and execute SQL, and surfaces validated insights and actionable recommendations — without you asking a single question. GitHub - scastiel/kado: Kadō — A privacy-first habit tracker for iPhone and iPad. GitHub - franzenzenhofer/tinyscreenshot: Token-frugal screenshots for AI agents. A default capture costs ~540 tokens instead of ~2100. GitHub - russellromney/honker: SQLite extension + bindings for Postgres NOTIFY/LISTEN semantics with durable queues, streams, pub/sub, and scheduler Manex Hub App - App Store Release 0.5 · greymattergames/unbug GitHub - mljar/features_goldmine: Features Engineering Made Easy GitHub - chojs23/lazyagent: TUI for watching all your AI coding agents(claude, codex and opencode) Running Is The Hardest Endurance Sport? Not so Fast Show HN: Canopy – A2UI experiment in Go for macOS/AppKit Show HN: Share browser recordings on Cloudflare Pages from the command line GitHub - aiptimizer/TurboOCR: Fast GPU OCR server. 270 img/s on FUNSD. TensorRT FP16, PP-OCRv5, HTTP + gRPC. Show HN: We built a way for Claude Code to join meetings like a real teammate Show HN: Razorpay-universal – A framework-agnostic Razorpay SDK
GitHub - yasyf/cc-pool: Load-balancing for `claude`: CLAUDE_CONFIG_DIR=$(ccp select) claude
yasyfm · 2026-06-13 · via Hacker News: Show HN

cc-pool banner

CI Release License: PolyForm Noncommercial

Predictive, start-of-session load-balancing across multiple Claude subscriptions — for macOS.

Run several Claude Max/Pro subscriptions and you hit the same wall every week: one account pegged at its 5-hour or weekly limit while another sits idle. cc-pool launches every Claude Code session on the emptiest account, picked from live 5-hour / 7-day usage before the session starts — predictive, not reactive. No proxy in the request path, no manual switching, no waiting for a rate-limit error to learn you picked wrong.

After setup, claude is an alias for ccp run and the pooling disappears into the background. Two hard guarantees underwrite the design: plain claude on ~/.claude keeps working untouched — the pool can never log it out — and secrets stay in the macOS Keychain, never in cc-pool's database. How it works has the details.

Install

brew tap yasyf/cc-pool https://github.com/yasyf/cc-pool
brew install yasyf/cc-pool/cc-pool

macOS only. The binary installs as cc-pool with a ccp symlink; the default build is pure Go.

Quickstart

Pool two subscriptions and launch Claude on the emptiest one, in about five minutes.

1. Run ccp. On an empty pool it walks you through logging in each subscription — every account gets its own claude /login:

$ ccp
✓ Set up cc-pool on this machine.

How do you want to log in?
> Log in now, in this terminal

# claude opens its /login flow right here; finish it and ccp closes claude for you

Name for this account (optional)
> work@example.com

✓ Added work@example.com.

Add another account?
> Yes

# the second login runs the same way
✓ Added personal@example.com.

Your pool now has 2 accounts.

Launch Claude on the emptiest account:

    ccp run

Wrap `claude` to always launch on the emptiest account?
> Yes

✓ Wrapped `claude` — added an alias to ~/.zshrc.
Restart your shell or run `source ~/.zshrc` to use it now.
Run `command claude` for plain ~/.claude.

2. Check the pool. ccp status --plain prints the table once; bare ccp status (or bare ccp, now that accounts exist) opens a live TUI with per-account score breakdowns:

$ ccp status --plain
  ACCOUNT                     SCORE  5h used  7d used  LIVE RESETS
▸ work@example.com             68.1      22%      46%     0 6:00 PM
  personal@example.com         34.8      61%      70%     0 4:30 PM
▸ = next pick · score higher = emptier · 5h/7d = % used
updated 3:58 PM

3. Launch. Run claude (now wrapped). It announces its pick on stderr, then execs the real claude — cc-pool is gone from the process tree before Claude Code draws its first frame:

$ claude
Selected work@example.com · 5h 22% used · 7d 46% used

The Selected line names the account marked in step 2 — that match is your verification. From here on, every claude lands on whichever account has the most headroom.

Day-to-day use

The alias, and escaping it

The quickstart wraps claude with alias claude='ccp run'. command claude bypasses it — plain claude on ~/.claude, one keystroke away. Prefer to leave claude untouched? Decline the prompt (or pass ccp add --no-alias) and pick your own name:

Passing arguments

ccp run forwards every argument to claude verbatim — no -- separator needed. Bare ccp with flags is shorthand for the same thing:

ccp run --resume
ccp -p "summarize this repo"   # auto-converts to `ccp run -p ...`

Forcing and pinning

CCP_ACCOUNT=2 ccp run forces account 2 instead of auto-selecting. Repeated launches from the same directory stick to one account for prompt-cache continuity; those announce Reusing work@example.com (pinned) instead of Selected.

When every account is full

Selection refuses to burn a nearly-reset window: an account with an exhausted plan window is never picked while any account has headroom, and ccp select --wait blocks until one does. If the whole pool is exhausted, the launch falls back to the least-bad account and warns loudly on stderr — that session bills pay-as-you-go credits if extra usage is enabled, or rate-limits until the window resets.

Composing the launch yourself

ccp select prints the chosen config dir on stdout and nothing else. Set the plugin root too, so the session writes canonical plugin paths into the shared ~/.claude/plugins (ccp run and ccp env both do this for you):

CLAUDE_CODE_PLUGIN_CACHE_DIR="$HOME/.claude/plugins" CLAUDE_CONFIG_DIR=$(ccp select) claude

How it works

~/.claude is sacred

~/.claude is never moved and never registered as a pool account. It stays the canonical config dir, so plain claude keeps working exactly as before, and is the shared base every pooled account mirrors. The pool never touches plain claude's credential or login identity. Every account, including your main subscription, joins with its own claude /login, so its token chain is fully independent of plain claude's.

One real config dir per account

Claude Code namespaces its Keychain credential per config dir: the default ~/.claude uses the item Claude Code-credentials; a custom CLAUDE_CONFIG_DIR gets a suffixed item Claude Code-credentials-<hash>. cc-pool gives each account a real, unique dir (~/.cc-pool/accounts/acct-NN) so each gets its own Keychain item, its own independent OAuth grant (its own refresh-token chain), and runs on its own subscription — never API billing. Each account dir is seeded with a copy of your ~/.claude.json with the identity stripped (the account's own login writes its identity), so pooled sessions inherit your settings, MCP servers, and per-project tool approvals instead of running first-run onboarding.

Shared overlay

Each account dir presents all of ~/.claudeprojects/, skills/, plans/, settings.json, history.jsonl, the lot — with writes passing straight back, so every session shares the same workspace and plan-mode plans persist across pooled sessions. Two providers:

  • symlink (default, zero-dependency): symlinks each top-level entry of ~/.claude into the account dir. New top-level entries are picked up automatically at launch, by the daemon, and by ccp doctor --fix.
  • fuse (optional, live mirror): a passthrough mirror mounted via fuse-t — kext-less, mounted as you, no root — and hosted by a detached cc-pool mount-holder process, so daemon restarts and upgrades never disturb live sessions' mounts. Requires a -tags fuse build (cgo) and a one-time Network Volumes privacy grant.

A few entries stay per-account instead of shared: daemon/ and ide/ (Claude's PID-keyed supervisor and IDE lock/socket files, which would collide across concurrent sessions), backups/ (rotating backups of each account's .claude.json), the identity and credential files .claude.json and .credentials.json, .last-update-result.json (instance-local auto-update state), and remote-settings.json (claude's cached per-subscription settings).

Per-account .claude.json doesn't mean settings fork, though: its shareable top-level keys — everything except identity, per-project state, and startup counters — flow from ~/.claude.json into pooled sessions, so a setting you change in vanilla claude reaches every account. One caveat: under the default symlink overlay the flow is one-way (merged in at launch, base wins), so changing a shareable setting inside a pooled session reverts at the next launch — manage shared settings in vanilla claude, or use the fuse overlay, whose live merged view writes shareable changes back to ~/.claude.json (two-way).

Scoring

The baseline — exact when windows are far from a reset — is:

score = 0.70·(100−util_5h) + 0.25·(100−util_7d)
      − 2·active_sessions − 100·rate_limited − 20·stale_or_refresh_failed

Three terms keep the ranking honest near the edges: an imminent reset earns credit in proportion to how soon the window resets (a 90%-used window resetting in 10 minutes ranks up, not down); a low-headroom barrier stops a nearly-exhausted 7-day window from being masked by 5-hour headroom; and a burn-rate term downranks an account being actively drained. select picks argmax. Usage comes from Claude's own /api/oauth/usage endpoint.

The daemon

brew services start cc-pool (Homebrew installs) or ccp service install (source builds) runs a user LaunchAgent — a root daemon couldn't read your login Keychain. It polls usage every ~3 min with exponential backoff, refreshes idle accounts' tokens before they expire (a checked-out session owns its own refresh; the daemon adopts whatever token it rotated to on check-in), caches scores, and — with the fuse overlay — supervises the detached mount holder, which owns the mounts (so daemon restarts and upgrades never disturb them). ccp add and ccp init start it automatically; if it isn't running, ccp select auto-spawns it or samples live.

No secrets are ever stored in cc-pool's database — the macOS Keychain is the only secret store.

Commands

These two tables cover the full user-facing surface; ccp help <command> prints the same per command.

Command What it does
ccp On a terminal — empty pool: guided onboarding; populated pool: status. With flags: shorthand for ccp run
ccp add Pool a subscription via its own claude /login (auto-inits the pool, starts the daemon)
ccp run [claude args…] Select the emptiest account and exec claude, forwarding every arg
ccp status Per-account usage, score, and sessions — TUI on a terminal, plain table when piped
ccp select Print the chosen account's config dir on stdout — the composable hot path
ccp env Print shell export lines to launch an account by hand
ccp list Static account list: ids, paths, Keychain items
ccp doctor Check accounts' Keychain items and overlays; repair drift
ccp remove <id> Remove an account from the pool
ccp rename <id> <name> Rename an account; --auto derives names from account emails
ccp init Set up the pool and start the daemon (optional — ccp add does this)
ccp service install|uninstall|status Manage the daemon and mount holder (delegates to brew services on Homebrew installs)
ccp widget Install the Notification Center status widget (Homebrew cask) and show how to enable it

Flags, by command:

Command Flag Effect
add --label <name> Name for the first account
add --count <n> Add exactly N accounts, no continue prompt
add --yes, -y Add one account and log in right away
add --run-login Log in immediately instead of asking how
add --no-alias Don't add a claude shell alias
run CCP_ACCOUNT=<id> (env) Force a specific account instead of auto-selecting
select --wait Wait for an account with headroom instead of failing or using an exhausted one
select --account <id> Force a specific account id
select --no-daemon Don't use the daemon; sample usage live
select --fresh <dur> Reuse cached usage newer than this (live mode)
status --plain Print the plain table instead of the interactive TUI
status --watch, -w Refresh continuously (plain mode)
status --live Force live sampling even if the daemon is running
env --account <id> Account id (defaults to the best account)
doctor --fix Attempt to repair detected drift
remove --keep-credential Keep the account's Keychain item
rename --auto Derive labels from account emails (skips custom labels)
rename --force With --auto, overwrite custom labels too
init --no-service Don't start the daemon now; ccp add starts it
service uninstall --force Skip the live-session gate (sessions on unmounted dirs will break)
service uninstall --purge Also remove all pool accounts and state; never touches ~/.claude

Uninstall

ccp service uninstall            # stop the daemon + mount holder, unmount fuse overlays
                                 # (refuses under live sessions; --force overrides)
ccp service uninstall --purge    # ...and remove all pool accounts/dirs/state
brew uninstall cc-pool

~/.claude and its credential are never touched.

Development

Build with CGO_ENABLED=0 go build ./cmd/cc-pool; go test ./... passes with no network, Keychain, or daemon. The manual end-to-end test matrix lives in docs/VERIFICATION.md, release history in CHANGELOG.md, and conventions in AGENTS.md.

License

PolyForm-Noncommercial-1.0.0 © Yasyf Mohamedali — free for noncommercial use. See LICENSE or the license text online.