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

推荐订阅源

F
Full Disclosure
Recorded Future
Recorded Future
T
Tenable Blog
S
Securelist
C
CERT Recently Published Vulnerability Notes
T
Threatpost
S
Schneier on Security
A
Arctic Wolf
The Hacker News
The Hacker News
C
CXSECURITY Database RSS Feed - CXSecurity.com
Know Your Adversary
Know Your Adversary
P
Privacy International News Feed
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The Register - Security
The Register - Security
Cisco Talos Blog
Cisco Talos Blog
AWS News Blog
AWS News Blog
K
Kaspersky official blog
T
True Tiger Recordings
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
P
Palo Alto Networks Blog
T
The Exploit Database - CXSecurity.com
小众软件
小众软件
B
Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Microsoft Azure Blog
Microsoft Azure Blog
Cyberwarzone
Cyberwarzone
C
Cybersecurity and Infrastructure Security Agency CISA
T
Tor Project blog
Spread Privacy
Spread Privacy
Malwarebytes
Malwarebytes
P
Proofpoint News Feed
F
Fox-IT International blog
F
Fortinet All Blogs
P
Privacy & Cybersecurity Law Blog
G
GRAHAM CLULEY
量子位
Latest news
Latest news
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 叶小钗
Project Zero
Project Zero
T
Tailwind CSS Blog
N
Netflix TechBlog - Medium
Martin Fowler
Martin Fowler
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
I
Intezer
博客园_首页
腾讯CDC
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
Darknet – Hacking Tools, Hacker News & Cyber Security

Recent Commits to openclaw:main

fix(hooks): enforce default hook agent allowlist · openclaw/openclaw@e72621e fix(e2e): handle docker helper cli help · openclaw/openclaw@2814ab6 fix(codex): avoid native compaction on budget triggers (#86772) · openclaw/openclaw@eb8f9b4 test: speed up plugin test fixtures · openclaw/openclaw@05ff771 fix(e2e): bound openai chat tools client · openclaw/openclaw@de94217 fix(e2e): bound upgrade survivor probes · openclaw/openclaw@981ae13 fix(doctor): keep hooks model checks read-only (#86101) · openclaw/openclaw@371c4d6 fix(installer): tighten nonroot smoke node preflight · openclaw/openclaw@340f480 fix(e2e): bound HTTP readiness probes · openclaw/openclaw@d58f864 fix(daemon): keep node tasks off gateway listener cleanup · openclaw/openclaw@a4e0b6e perf(gateway): reuse prepared auth stores · openclaw/openclaw@d2711c9 test: speed up codex app server run attempts · openclaw/openclaw@1ce3637 build(codex): update Codex CLI to 0.134.0 · openclaw/openclaw@231a812 docs(skills): omit advisory ids from changelog notes · openclaw/openclaw@989a369 test: speed up test project routing · openclaw/openclaw@140892c Fix stale approval prompts in Control UI (#86270) · openclaw/openclaw@5297eeb fix(installer): reject stale cli node runtimes · openclaw/openclaw@49d605e test: harden e2e harness isolation · openclaw/openclaw@acbb06e fix: keep approval runtime token local-only · openclaw/openclaw@96c5766 docs(changelog): omit advisory id from release notes · openclaw/openclaw@d606881 docs(changelog): refresh 2026.5.26 notes · openclaw/openclaw@26c0c19 docs(skills): add release changelog update workflow · openclaw/openclaw@c8d20ae fix(e2e): bound upgrade survivor cli checks · openclaw/openclaw@c965b3a test: speed up doctor config flow tests · openclaw/openclaw@5177180 fix(events): sanitize queued system markers (#87094) · openclaw/openclaw@c1151ea fix(gateway): remove redundant unknown union · openclaw/openclaw@f393ebe test: speed up model fallback tests · openclaw/openclaw@e7f644c fix(imessage): stage remote media before understanding · openclaw/openclaw@ae52be9 fix(gateway): drop stale subagent announce history · openclaw/openclaw@982e888 fix: repair local approval resolution (#86771) · openclaw/openclaw@13cfb77 fix(e2e): bound codex media plugin setup · openclaw/openclaw@f89fcdd fix(gateway): stop chat timeout fallback cascade · openclaw/openclaw@b4f6928 perf(gateway): defer scheduled service imports · openclaw/openclaw@b74cd69 test: speed up capability cli tests · openclaw/openclaw@0126aba perf(gateway): defer startup warning fallback imports · openclaw/openclaw@0ee4ccf fix(gateway): bound watch regression teardown · openclaw/openclaw@7014bd0 fix(codex): keep WebChat delivery hints out of user requests · openclaw/openclaw@0cfccdb test: type current plugin metadata snapshot mock · openclaw/openclaw@a43cf2b test: align WebChat delivery hint expectations · openclaw/openclaw@1242931 test: speed up command secret gateway tests · openclaw/openclaw@657f9d1 fix(status): show explicit fast mode state (#87115) · openclaw/openclaw@41962ed fix: preserve plugin LLM command auth (#85936) · openclaw/openclaw@9119492 test: align loopback prompt metadata · openclaw/openclaw@f7a39f4 perf(gateway): reuse metadata for startup warnings · openclaw/openclaw@166097e fix(plugin-sdk): stabilize diagnostic event root alias · openclaw/openclaw@53f36a8 fix(tui): queue prompts submitted while busy (#86722) · openclaw/openclaw@6842d72 test: speed up tooling tests · openclaw/openclaw@f34a527 fix(plugin-sdk): use Function.name to find onDiagnosticEvent export (… · openclaw/openclaw@b3f8a0e Suppress transient runner failures in channels (#87069) · openclaw/openclaw@df6ec28 fix(e2e): bound telegram live hot path · openclaw/openclaw@698c40e test: speed up crabbox wrapper tests · openclaw/openclaw@5aaad5f refactor(telegram): encode conversation binding mode · openclaw/openclaw@df659d1 fix(agents): correlate pathless read diagnostics (#86977) · openclaw/openclaw@cecb076 perf: trim gateway session cache churn · openclaw/openclaw@cdfb1b4 test: speed up update cli tests · openclaw/openclaw@9065377 fix(doctor): map runtime tool schema health · openclaw/openclaw@27ad3d7 fix(e2e): bound update channel CLI checks · openclaw/openclaw@8fa5ecb test: speed up run-node tests · openclaw/openclaw@c8364b4 fix(browser): validate current tab before snapshots (#78526) · openclaw/openclaw@0604700 fix(media): require staged sandbox media refs · openclaw/openclaw@42d6cf6 perf: trim gateway startup planning · openclaw/openclaw@8d6b599 fix(codex): quarantine unsupported dynamic tool schemas · openclaw/openclaw@d7d037b fix(e2e): bound package cli scenarios · openclaw/openclaw@d0cb7ba ci: prepare pnpm for crabbox hydrate · openclaw/openclaw@716d719 fix(e2e): bound kitchen sink gateway teardown · openclaw/openclaw@81d22e8 test: speed up test routing and parallels smoke tests · openclaw/openclaw@9754117 fix(onboard): preserve configured default model (#87000) · openclaw/openclaw@5304682 fix(telegram): route plugin-bound topic messages · openclaw/openclaw@b8ea6d2 fix(gateway): bound benchmark teardown waits · openclaw/openclaw@1baab3b fix(diagnostics): recover orphaned session activity · openclaw/openclaw@286964c perf: avoid redundant runtime postbuild sync · openclaw/openclaw@a67ee0f fix(media): resolve inbound media refs consistently · openclaw/openclaw@6290ed5 fix(e2e): bound logged onboard commands · openclaw/openclaw@b74984d fix(ollama): normalize greedy top_p (#87049) · openclaw/openclaw@dfadc7b test: speed up crabbox wrapper tests · openclaw/openclaw@1954468 test: speed up crabbox config shim · openclaw/openclaw@1d2bf82 clickclack: enforce inbound sender allowlist [AI] (#83741) · openclaw/openclaw@10546e5 fix: isolate chat transcript fallback failures · openclaw/openclaw@fafed25 refactor: centralize prepared user turn merge · openclaw/openclaw@481f432 fix: preserve inline image routing with staged media · openclaw/openclaw@9263e38 test: wait for initial session task cleanup · openclaw/openclaw@00ab2f2 fix: keep user turn replay hooks idempotent · openclaw/openclaw@91cb042 refactor: carry prepared user turns on recorder · openclaw/openclaw@44bdc52 fix: preserve provenance through user turn hooks · openclaw/openclaw@223655d fix: use cleaned user turn transcript text · openclaw/openclaw@b9c2590 fix: preserve user turn provenance metadata · openclaw/openclaw@2e8f1d4 fix: keep user turn enrichment off dispatch · openclaw/openclaw@c862143 refactor: trim user turn transcript API · openclaw/openclaw@8bbd4ba fix: mark final codex mirror user persistence · openclaw/openclaw@2bd38da fix: resolve final codex mirror prompt · openclaw/openclaw@c0f8224 fix: use selected user transcript text · openclaw/openclaw@e4c42ae fix: restore user turn persistence checks · openclaw/openclaw@696fb41 fix: persist cli user turns to admitted session target · openclaw/openclaw@d55fe4b refactor: trim duplicated transcript tests · openclaw/openclaw@fe44ecd test: trim duplicate user turn persistence coverage · openclaw/openclaw@ffb8350 refactor: remove duplicate user turn handoff · openclaw/openclaw@20d7bf7 refactor: drop unused user turn update mode · openclaw/openclaw@848c389 fix(filefetch): wrap fetched text as external content (#87062) · openclaw/openclaw@42b8898 fix(ci): satisfy script oxlint sort rule · openclaw/openclaw@ffe1213 ci: tolerate gateway status help probe hangs
perf(gateway): defer skipped-channel sidecars · openclaw/openclaw@145b57c
steipete · 2026-05-27 · via Recent Commits to openclaw:main

@@ -29,6 +29,7 @@ const ACP_BACKEND_READY_TIMEOUT_MS = 5_000;

2929

const ACP_BACKEND_READY_POLL_MS = 50;

3030

const PROVIDER_AUTH_PREWARM_START_DELAY_MS = 1_000;

3131

const PROVIDER_AUTH_REWARM_DELAY_MS = 1_000;

32+

const DEFERRED_SIDECAR_START_DELAY_MS = 100;

3233

const QMD_STARTUP_IDLE_DELAY_MS = 120_000;

3334

const RESTART_SENTINEL_FILENAME = "restart-sentinel.json";

3435

@@ -887,6 +888,7 @@ export async function startGatewayPostAttachRuntime(

887888

isClosing?: () => boolean;

888889

startupTrace?: GatewayStartupTrace;

889890

deferSidecars?: boolean;

891+

logReadyOnSidecars?: boolean;

890892

providerAuthPrewarm?: {

891893

enabled?: boolean;

892894

delayMs?: number;

@@ -896,21 +898,38 @@ export async function startGatewayPostAttachRuntime(

896898

runtimeDeps: GatewayPostAttachRuntimeDeps = defaultGatewayPostAttachRuntimeDeps,

897899

) {

898900

let pluginRegistry = params.pluginRegistry;

899-

if (!params.minimalTestGateway && params.loadStartupPlugins) {

900-

params.onStartupPluginsLoading?.();

901-

const loaded = await measureStartup(params.startupTrace, "plugins.runtime-post-bind", () =>

902-

params.loadStartupPlugins!(),

903-

);

904-

pluginRegistry = loaded.pluginRegistry;

905-

params.startupTrace?.detail("plugins.runtime-post-bind", [

906-

[

907-

"loadedPluginCount",

908-

pluginRegistry.plugins.filter((plugin) => plugin.status === "loaded").length,

909-

],

910-

["gatewayMethodCount", loaded.gatewayMethods.length],

911-

]);

912-

await params.onStartupPluginsLoaded?.(loaded);

913-

}

901+

let startupPluginsLoaded = false;

902+

let startupPluginsLoadPromise: Promise<{

903+

pluginRegistry: PluginRegistry;

904+

gatewayMethods: string[];

905+

}> | null = null;

906+

const loadStartupPluginsIfNeeded = async () => {

907+

if (params.minimalTestGateway || !params.loadStartupPlugins) {

908+

return { pluginRegistry, gatewayMethods: [] };

909+

}

910+

if (startupPluginsLoaded) {

911+

return { pluginRegistry, gatewayMethods: [] };

912+

}

913+

startupPluginsLoadPromise ??= (async () => {

914+

params.onStartupPluginsLoading?.();

915+

const loaded = await measureStartup(params.startupTrace, "plugins.runtime-post-bind", () =>

916+

params.loadStartupPlugins!(),

917+

);

918+

pluginRegistry = loaded.pluginRegistry;

919+

startupPluginsLoaded = true;

920+

params.startupTrace?.detail("plugins.runtime-post-bind", [

921+

[

922+

"loadedPluginCount",

923+

pluginRegistry.plugins.filter((plugin) => plugin.status === "loaded").length,

924+

],

925+

["gatewayMethodCount", loaded.gatewayMethods.length],

926+

]);

927+

await params.onStartupPluginsLoaded?.(loaded);

928+

return loaded;

929+

})();

930+

return await startupPluginsLoadPromise;

931+

};

932+

await loadStartupPluginsIfNeeded();

914933915934

const startupLogPromise = measureStartup(params.startupTrace, "post-attach.log", () =>

916935

runtimeDeps.logGatewayStartup({

@@ -961,10 +980,20 @@ export async function startGatewayPostAttachRuntime(

961980

reportedPluginServices = pluginServices;

962981

params.onPluginServices?.(pluginServices);

963982

};

983+

const waitForSidecarStartTurn = () =>

984+

new Promise<void>((resolve) => {

985+

if (params.deferSidecars === true) {

986+

const timer = setTimeout(resolve, DEFERRED_SIDECAR_START_DELAY_MS);

987+

timer.unref?.();

988+

return;

989+

}

990+

setImmediate(resolve);

991+

});

964992965993

const sidecarsPromise = params.minimalTestGateway

966994

? Promise.resolve({ pluginServices: null, pluginRegistry, postReadySidecars: [] })

967-

: new Promise<void>((resolve) => setImmediate(resolve)).then(async () => {

995+

: waitForSidecarStartTurn().then(async () => {

996+

await loadStartupPluginsIfNeeded();

968997

params.log.info("starting channels and sidecars...");

969998

const loaderStatsBefore = getPluginModuleLoaderStats();

970999

const result = await measureStartup(params.startupTrace, "sidecars.total", () =>

@@ -1034,7 +1063,9 @@ export async function startGatewayPostAttachRuntime(

10341063

["postReadySidecarCount", postReadySidecars.length + gatewayLifetimeSidecars.length],

10351064

]);

10361065

params.startupTrace?.mark("sidecars.ready");

1037-

params.log.info("gateway ready");

1066+

if (params.logReadyOnSidecars !== false) {

1067+

params.log.info("gateway ready");

1068+

}

10381069

return { ...result, postReadySidecars, gatewayLifetimeSidecars, pluginRegistry };

10391070

});

10401071