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

推荐订阅源

aimingoo的专栏
aimingoo的专栏
量子位
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
Schneier on Security
Cisco Talos Blog
Cisco Talos Blog
T
ThreatConnect
J
Java Code Geeks
博客园 - 司徒正美
A
Arctic Wolf
T
True Tiger Recordings
C
Cybersecurity and Infrastructure Security Agency CISA
Cyberwarzone
Cyberwarzone
Know Your Adversary
Know Your Adversary
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
Recorded Future
Recorded Future
P
Palo Alto Networks Blog
The Hacker News
The Hacker News
The Register - Security
The Register - Security
S
Securelist
www.infosecurity-magazine.com
www.infosecurity-magazine.com
C
CXSECURITY Database RSS Feed - CXSecurity.com
Application and Cybersecurity Blog
Application and Cybersecurity Blog
I
Intezer
P
Privacy & Cybersecurity Law Blog
Scott Helme
Scott Helme
K
Kaspersky official blog
博客园 - 聂微东
Last Week in AI
Last Week in AI
V
V2EX
小众软件
小众软件
F
Fox-IT International blog
Martin Fowler
Martin Fowler
Apple Machine Learning Research
Apple Machine Learning Research
T
Tenable Blog
F
Future of Privacy Forum
Microsoft Security Blog
Microsoft Security Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
腾讯CDC
Stack Overflow Blog
Stack Overflow Blog
C
Check Point Blog
阮一峰的网络日志
阮一峰的网络日志
GbyAI
GbyAI
T
Threatpost
I
InfoQ
P
Proofpoint News Feed
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
T
Tor Project blog
G
GRAHAM CLULEY
D
DataBreaches.Net

Recent Commits to openclaw:main

fix(doctor): skip restart prompt when gateway is healthy after recent… · openclaw/openclaw@6e8d2db fix: emit agent.send lifecycle hooks on rotation (#85875) · openclaw/openclaw@8129dba fix(crabbox): bootstrap macos shell js commands · openclaw/openclaw@7cd15d2 fix: preflight malformed openshell exec commands fix: tighten openshell exec preflight · openclaw/openclaw@822ee62 docs: clarify unshipped compat policy · openclaw/openclaw@f87aa0f fix(update): allow package-manager hardlinks in swaps · openclaw/openclaw@8061d66 docs: ban repo-hosted proof artifacts · openclaw/openclaw@17954a4 fix(discord): restore bare numeric channel sends (#86571) · openclaw/openclaw@c5b9872 fix(installer): handle alpine apk runtime floors · openclaw/openclaw@b83dfcb fix(security): audit Claude permission overrides under YOLO (#86557) · openclaw/openclaw@bd65b42 fix: speed up Discord voice wake consults · openclaw/openclaw@5ae91f0 fix(qa): harden restart inflight Windows scenario · openclaw/openclaw@3eb06e3 Recover Codex context overflow prompt errors (#85542) · openclaw/openclaw@5cfa577 docs: update changelog for #70473 · openclaw/openclaw@d967760 fix(agents): derive overflow budgets from provider errors · openclaw/openclaw@d5b0174 fix(plugins): only memoize complete metadata snapshots · openclaw/openclaw@3137622 docs: update changelog for media wake fallback (#85489) · openclaw/openclaw@a11d4e6 fix: fallback after active media wake failure (#85489) · openclaw/openclaw@1b64ccb perf(plugins): reuse derived metadata snapshots · openclaw/openclaw@159e440 docs: require maintainer-editable PR branches · openclaw/openclaw@f271f00 fix: scan OpenClaw sessions in agent transcript finder · openclaw/openclaw@4012ae4 docs: note agent transcript OpenClaw session scan · openclaw/openclaw@dd375f9 docs: require generic local fixes · openclaw/openclaw@fc93af5 fix: broaden leading voice wake fuzzing · openclaw/openclaw@a9c91ca test(agents): preserve provider hook mock exports (#86523) · openclaw/openclaw@657b246 Policy: add agent-scoped policy overlays (#85817) · openclaw/openclaw@fbb6340 fix(kilocode): normalize string stop param to array in stream wrapper… · openclaw/openclaw@abe9923 Doctor: expose shell completion health findings (#85566) · openclaw/openclaw@dc17412 fix(agents): honor effective exec policy for Claude live Bash (#86330) fix(test): stabilize e2e runtime imports fix(test): clean plugin gauntlet temp roots · openclaw/openclaw@633e4b8 perf: cache plugin package realpaths (#86517) · openclaw/openclaw@69d728a fix(qa): settle restart races with live budget · openclaw/openclaw@2cac9e5 fix(crabbox): sync full sparse lease runs · openclaw/openclaw@e97e831 fix(qa): extend config mutation Windows budget fix(qa): extend config cleanup Windows budget · openclaw/openclaw@8a93851 test(crabbox): tolerate Windows shell capture · openclaw/openclaw@50d6611 fix(sessions): stop doctor OOM on large session stores and reclaim st… · openclaw/openclaw@89aea9b fix(ollama): strip inline kimi cloud reasoning leak (#86515) fix(discord): merge media captions into one message (#86487) · openclaw/openclaw@bc10fad fix(utils): clamp fetch timeout timers (#85985) fix(ui): preserve user code block rendering (#85942) fix(memory): prevent silent vector index degradation when embedding p… docs: clarify agent transcript placeholders · openclaw/openclaw@8da8bc4 test(qa): annotate live transport RTT measurements · openclaw/openclaw@bb6f37e fix(qqbot): derive outbound watchdog from configured timeouts (#85267… · openclaw/openclaw@aa702cf fix(test): clean kitchen sink rpc temp state · openclaw/openclaw@6f695c1 fix: quiet missing daily memory reads fix: tighten empty plugin registry reuse · openclaw/openclaw@026cfb6 perf: speed up agent transcript lookup · openclaw/openclaw@e7ad116 fix: guard QMD session stem fallback (#86482) · openclaw/openclaw@2e3b59b Guard OpenAI chat payload turns (#86497) · openclaw/openclaw@489e415 fix(gateway): keep session tool mirrors under pressure · openclaw/openclaw@459e89a docs: route github creation through agent transcript test(tools): add unmocked image custom-provider auth regression (#85733) · openclaw/openclaw@f0bfb3f refactor(plugin-sdk): rename plain text tool-call compat wrapper docs(skills): defer private release locators · openclaw/openclaw@23d38e4 Replace Sharp image backend with Photon (#86437) · openclaw/openclaw@b9f975b fix(agents): release embedded-attempt session lock on every exit path… · openclaw/openclaw@32ddfc2 fix: accept OpenClaw voice wake confusions (#86507) fix(crabbox): bootstrap macos js toolchain chore: add agent transcript skill · openclaw/openclaw@d63e8d4 fix(gateway): dedupe session tool fanout · openclaw/openclaw@89a21db fix: Hook ingress token unlocks password-mode gateway auth (#86453) · openclaw/openclaw@d51f268 fix #86077: keep fallback errors candidate scoped (#86134) · openclaw/openclaw@d6b7fe8 fix(diagnostics): reclaim wedged session lanes with a stale leaked ac… · openclaw/openclaw@6f76d9f fix: derive plugin media trust from metadata (#86410) · openclaw/openclaw@e761eb8 fix(media-understanding): normalize HEIC before image descriptions (#… · openclaw/openclaw@75c7236 fix: accept leading fuzzy Discord voice wake names (#86484) · openclaw/openclaw@8fe4f34 feat: promote provider tool call stream wrapper (#86489) fix(test): dedupe kitchen sink command assertions test: derive deprecated sdk usage guard (#86403) fix(qa): extend memory fallback Windows budget fix(ui): move control ui chunking helper out of runtime source · openclaw/openclaw@968c87d fix: quiet retained lost task noise (#86475) fix(build): keep control ui chunking out of deadcode · openclaw/openclaw@dc26069 fix: rotate realtime voice sessions on max duration · openclaw/openclaw@dc2c4aa fix(test): stream bundled plugin sweep logs · openclaw/openclaw@fc3cd49 docs: add bugfix changelog credits · openclaw/openclaw@2e7e4bc fix(models): show oauth marker auth status (#86378) · openclaw/openclaw@a6df39d fix: seed cron task progress summaries (#86313) · openclaw/openclaw@92afd8b fix(update): exclude prerelease tags from stable git channel (#86260) · openclaw/openclaw@28f169b fix(doctor): warn and continue when cron job store is unreadable (#86… fix(gateway): clear runtime config snapshot before in-process restart… · openclaw/openclaw@90caa3b fix(scripts): restore sparse crabbox changed gates · openclaw/openclaw@d270879 fix(build): support Windows UI builds · openclaw/openclaw@0bb9b42 Fix local embedding worker safety (#85348) · openclaw/openclaw@7ff29a9 fix(ui): scope chat session picker to active agent (#85965) · openclaw/openclaw@70c7d6f [codex] improve iOS realtime talk mode (#86355) · openclaw/openclaw@9ca52ce fix(scripts): dedupe docker lane resources · openclaw/openclaw@5e94469 docs: add code size guidance · openclaw/openclaw@9a60fcf fix(test): avoid source gateway import in rpc walk · openclaw/openclaw@e9b8a6e docs: add bugfix changelog entries · openclaw/openclaw@f950132 Fix heartbeat response loop guard (#86324) (#86357) · openclaw/openclaw@e2c174e fix(memory-core): filter REM dreaming candidates to light-staged entr… · openclaw/openclaw@8b42771 fix(telegram): propagate forum topic names into agent context (#86299) fix(slack): keep downloaded files out of reply media (#86318) · openclaw/openclaw@2fcd481 fix(cron): accept plus durations for one-shot jobs (#86341) · openclaw/openclaw@9239f94 fix(plugins): clear metadata memo at lifecycle boundaries · openclaw/openclaw@e7c696a
fix: raise default cron concurrency · openclaw/openclaw@bc12e04
steipete · 2026-05-26 · via Recent Commits to openclaw:main
Original file line numberDiff line numberDiff line change

@@ -6,6 +6,7 @@ Docs: https://docs.openclaw.ai

66
77

### Changes

88
9+

- Cron: default `cron.maxConcurrentRuns` to 8 so scheduled automations and their isolated agent turns can make progress in parallel without explicit configuration.

910

- QA-Lab: add `qa coverage --match <query>` so focused proof selection can discover matching scenarios from existing metadata before running live or remote lanes.

1011

- Control UI: add an ephemeral Activity tab for sanitized live tool activity summaries without persisting raw telemetry. Fixes #12831. Thanks @BunsDev.

1112

- Build: include `ui:build` in the `full` and `ciArtifacts` profiles of `scripts/build-all.mjs` so `pnpm build` always rebuilds `dist/control-ui` after `tsdown` cleans `dist`, removing the second-command requirement and the missing-asset failure mode for source/runtime installs and CI artifact uploads. (#85206)

Original file line numberDiff line numberDiff line change

@@ -436,7 +436,7 @@ Model override note:

436436

cron: {

437437

enabled: true,

438438

store: "~/.openclaw/cron/jobs.json",

439-

maxConcurrentRuns: 1,

439+

maxConcurrentRuns: 8,

440440

retry: {

441441

maxAttempts: 3,

442442

backoffMs: [60000, 120000, 300000],

@@ -449,7 +449,7 @@ Model override note:

449449

}

450450

```

451451
452-

`maxConcurrentRuns` limits both scheduled cron dispatch and isolated agent-turn execution. Isolated cron agent turns use the queue's dedicated `cron-nested` execution lane internally, so raising this value lets independent cron LLM runs progress in parallel instead of only starting their outer cron wrappers. The shared non-cron `nested` lane is not widened by this setting.

452+

`maxConcurrentRuns` limits both scheduled cron dispatch and isolated agent-turn execution, and defaults to 8. Isolated cron agent turns use the queue's dedicated `cron-nested` execution lane internally, so raising this value lets independent cron LLM runs progress in parallel instead of only starting their outer cron wrappers. The shared non-cron `nested` lane is not widened by this setting.

453453
454454

The runtime state sidecar is derived from `cron.store`: a `.json` store such as `~/clawd/cron/jobs.json` uses `~/clawd/cron/jobs-state.json`, while a store path without a `.json` suffix appends `-state.json`.

455455
Original file line numberDiff line numberDiff line change

@@ -385,7 +385,7 @@ Save to `~/.openclaw/openclaw.json` and you can DM the bot from that number.

385385

cron: {

386386

enabled: true,

387387

store: "~/.openclaw/cron/cron.json",

388-

maxConcurrentRuns: 2, // cron dispatch + isolated cron agent-turn execution

388+

maxConcurrentRuns: 8, // default; cron dispatch + isolated cron agent-turn execution

389389

sessionRetention: "24h",

390390

runLog: {

391391

maxBytes: "2mb",

Original file line numberDiff line numberDiff line change

@@ -1240,7 +1240,7 @@ Current builds no longer include the TCP bridge. Nodes connect over the Gateway

12401240

{

12411241

cron: {

12421242

enabled: true,

1243-

maxConcurrentRuns: 2, // cron dispatch + isolated cron agent-turn execution

1243+

maxConcurrentRuns: 8, // default; cron dispatch + isolated cron agent-turn execution

12441244

webhook: "https://example.invalid/legacy", // deprecated fallback for stored notify:true jobs

12451245

webhookToken: "replace-with-dedicated-token", // optional bearer token for outbound webhook auth

12461246

sessionRetention: "24h", // duration string or false

Original file line numberDiff line numberDiff line change

@@ -419,7 +419,7 @@ candidate contains redacted secret placeholders such as `***`.

419419

{

420420

cron: {

421421

enabled: true,

422-

maxConcurrentRuns: 2, // cron dispatch + isolated cron agent-turn execution

422+

maxConcurrentRuns: 8, // default; cron dispatch + isolated cron agent-turn execution

423423

sessionRetention: "24h",

424424

runLog: {

425425

maxBytes: "2mb",

Original file line numberDiff line numberDiff line change

@@ -6,13 +6,15 @@ import {

66

resolveAgentMaxConcurrent,

77

resolveSubagentMaxConcurrent,

88

} from "./agent-limits.js";

9+

import { DEFAULT_CRON_MAX_CONCURRENT_RUNS, resolveCronMaxConcurrentRuns } from "./cron-limits.js";

910

import { applyAgentDefaults } from "./defaults.js";

1011

import { OpenClawSchema } from "./zod-schema.js";

1112
1213

describe("agent concurrency defaults", () => {

1314

it("resolves defaults when unset", () => {

1415

expect(resolveAgentMaxConcurrent({})).toBe(DEFAULT_AGENT_MAX_CONCURRENT);

1516

expect(resolveSubagentMaxConcurrent({})).toBe(DEFAULT_SUBAGENT_MAX_CONCURRENT);

17+

expect(resolveCronMaxConcurrentRuns()).toBe(DEFAULT_CRON_MAX_CONCURRENT_RUNS);

1618

});

1719
1820

it("clamps invalid values to at least 1", () => {

@@ -26,6 +28,7 @@ describe("agent concurrency defaults", () => {

2628

};

2729

expect(resolveAgentMaxConcurrent(cfg)).toBe(1);

2830

expect(resolveSubagentMaxConcurrent(cfg)).toBe(1);

31+

expect(resolveCronMaxConcurrentRuns({ maxConcurrentRuns: 0 })).toBe(1);

2932

});

3033
3134

it("accepts subagent spawn depth and per-agent child limits", () => {

Original file line numberDiff line numberDiff line change

@@ -0,0 +1,13 @@

1+

import type { CronConfig } from "./types.cron.js";

2+
3+

export const DEFAULT_CRON_MAX_CONCURRENT_RUNS = 8;

4+
5+

export function resolveCronMaxConcurrentRuns(

6+

cronConfig?: Pick<CronConfig, "maxConcurrentRuns">,

7+

): number {

8+

const raw = cronConfig?.maxConcurrentRuns;

9+

if (typeof raw === "number" && Number.isFinite(raw)) {

10+

return Math.max(1, Math.floor(raw));

11+

}

12+

return DEFAULT_CRON_MAX_CONCURRENT_RUNS;

13+

}

Original file line numberDiff line numberDiff line change

@@ -4,9 +4,11 @@ import {

44

DEFAULT_SUBAGENT_ARCHIVE_AFTER_MINUTES,

55

DEFAULT_SUBAGENT_MAX_CONCURRENT,

66

} from "./agent-limits.js";

7+

import { DEFAULT_CRON_MAX_CONCURRENT_RUNS } from "./cron-limits.js";

78

import {

89

applyAgentDefaults,

910

applyContextPruningDefaults,

11+

applyCronDefaults,

1012

applyMessageDefaults,

1113

} from "./defaults.js";

1214

@@ -121,6 +123,18 @@ describe("config defaults", () => {

121123

);

122124

});

123125
126+

it("fills missing cron concurrency default", () => {

127+

const next = applyCronDefaults({ messages: {} } as never);

128+
129+

expect(next.cron?.maxConcurrentRuns).toBe(DEFAULT_CRON_MAX_CONCURRENT_RUNS);

130+

});

131+
132+

it("preserves explicit cron concurrency", () => {

133+

const next = applyCronDefaults({ cron: { maxConcurrentRuns: 3 } } as never);

134+
135+

expect(next.cron?.maxConcurrentRuns).toBe(3);

136+

});

137+
124138

it("preserves explicit subagent archive default", () => {

125139

const next = applyAgentDefaults({

126140

agents: { defaults: { subagents: { archiveAfterMinutes: 0 } } },

Original file line numberDiff line numberDiff line change

@@ -7,6 +7,7 @@ import {

77

DEFAULT_SUBAGENT_ARCHIVE_AFTER_MINUTES,

88

DEFAULT_SUBAGENT_MAX_CONCURRENT,

99

} from "./agent-limits.js";

10+

import { DEFAULT_CRON_MAX_CONCURRENT_RUNS } from "./cron-limits.js";

1011

import { normalizeAgentModelMapForConfig, normalizeAgentModelRefForConfig } from "./model-input.js";

1112

import {

1213

applyProviderConfigDefaultsForConfig,

@@ -438,6 +439,20 @@ export function applyAgentDefaults(cfg: OpenClawConfig): OpenClawConfig {

438439

};

439440

}

440441
442+

export function applyCronDefaults(cfg: OpenClawConfig): OpenClawConfig {

443+

const raw = cfg.cron?.maxConcurrentRuns;

444+

if (typeof raw === "number" && Number.isFinite(raw)) {

445+

return cfg;

446+

}

447+

return {

448+

...cfg,

449+

cron: {

450+

...cfg.cron,

451+

maxConcurrentRuns: DEFAULT_CRON_MAX_CONCURRENT_RUNS,

452+

},

453+

};

454+

}

455+
441456

export function applyLoggingDefaults(cfg: OpenClawConfig): OpenClawConfig {

442457

const logging = cfg.logging;

443458

if (!logging) {

Original file line numberDiff line numberDiff line change

@@ -3,6 +3,7 @@ import {

33

applyCompactionDefaults,

44

applyContextPruningDefaults,

55

applyAgentDefaults,

6+

applyCronDefaults,

67

applyLoggingDefaults,

78

applyMessageDefaults,

89

applyModelDefaults,

@@ -63,6 +64,7 @@ export function materializeRuntimeConfig(

6364

}

6465

next = applySessionDefaults(next);

6566

next = applyAgentDefaults(next);

67+

next = applyCronDefaults(next);

6668

if (profile.includeContextPruningDefaults) {

6769

next = applyContextPruningDefaults(next, { manifestRegistry: options.manifestRegistry });

6870

}