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

推荐订阅源

N
News and Events Feed by Topic
Malwarebytes
Malwarebytes
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
F
Future of Privacy Forum
C
Cisco Blogs
T
The Exploit Database - CXSecurity.com
A
Arctic Wolf
S
Securelist
K
Kaspersky official blog
S
Schneier on Security
T
ThreatConnect
T
Tenable Blog
Spread Privacy
Spread Privacy
T
True Tiger Recordings
AWS News Blog
AWS News Blog
F
Fox-IT International blog
量子位
T
Threatpost
V
Vulnerabilities – Threatpost
C
CERT Recently Published Vulnerability Notes
Cisco Talos Blog
Cisco Talos Blog
GbyAI
GbyAI
宝玉的分享
宝玉的分享
腾讯CDC
G
Google Developers Blog
aimingoo的专栏
aimingoo的专栏
Cyberwarzone
Cyberwarzone
有赞技术团队
有赞技术团队
S
SegmentFault 最新的问题
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
V
Visual Studio Blog
U
Unit 42
雷峰网
雷峰网
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Simon Willison's Weblog
Simon Willison's Weblog
O
OpenAI News
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
The Register - Security
The Register - Security
MyScale Blog
MyScale Blog
小众软件
小众软件
A
About on SuperTechFans
Last Week in AI
Last Week in AI
Y
Y Combinator Blog
博客园 - 三生石上(FineUI控件)
美团技术团队
Google Online Security Blog
Google Online Security Blog
P
Proofpoint News Feed
MongoDB | Blog
MongoDB | Blog

Recent Commits to openclaw:main

fix(cron): respect isolated target and error on missing remove id (#8… fix(pi-embedded-runner): propagate trigger-derived priority to the gl… · openclaw/openclaw@0580f57 fix(cli): suppress self-update version warnings fix: preserve webchat source reply details · openclaw/openclaw@aa50c51 docs: replace OpenClaw docs skill and add plugin permissions guide · openclaw/openclaw@0dabb70 fix(codex): preserve source reply mode for active runs (#86325) · openclaw/openclaw@b962110 fix: make compaction reinjection opt-in · openclaw/openclaw@ab910f8 fix codex usage-limit recovery copy (#86305) · openclaw/openclaw@c3c8a65 feat(ui): add ephemeral Activity tab · openclaw/openclaw@3dd0e8e fix(tests): harden native macos plugin proof · openclaw/openclaw@a5d5604 fix(commitments): serialize load-modify-save with in-process queue + … · openclaw/openclaw@d3c293d Fail Codex compaction at the Codex boundary (#85958) · openclaw/openclaw@dd47e47 fix(docker): restore config parent ownership · openclaw/openclaw@908b894 docs: clarify config default review policy (#86329) · openclaw/openclaw@3a03dd5 docs: clean changelog script entries · openclaw/openclaw@0eead19 fix(scripts): budget restart benchmark timeouts · openclaw/openclaw@5bd5509 fix: align ui vitest config assertion · openclaw/openclaw@730fd19 fix: route unit ui vitest targets narrowly · openclaw/openclaw@777402e fix: route explicit ui vitest targets narrowly · openclaw/openclaw@56a383c fix(android): harden play media permission removal fix(webchat): stabilize live transcript run state · openclaw/openclaw@119a01c fix(scripts): fail restart benchmark regressions · openclaw/openclaw@95d1b39 fix(openai): scope external codex auth to realtime fix(openai): prefer codex auth for GPT realtime · openclaw/openclaw@48c4f57 fix(openai): discover codex cli auth for provider checks · openclaw/openclaw@4656275 fix(android): keep talk mode on realtime relay · openclaw/openclaw@70614f8 test(android): add gateway connect adb probe · openclaw/openclaw@d7aa1f3 fix(android): stabilize realtime talk connection state · openclaw/openclaw@ffb02a5 test(android): add voice mode adb e2e harness · openclaw/openclaw@e52a3b3 fix(ci): stabilize deadcode and catalog checks · openclaw/openclaw@3db1508 fix(scripts): prebuild gateway cpu bench · openclaw/openclaw@ca70015 fix(e2e): harden bundled lifecycle probe on Windows · openclaw/openclaw@4798264 test(e2e): sample kitchen sink rpc peak rss · openclaw/openclaw@60c0f24 fix(scripts): remove stale deadcode allowlist entries · openclaw/openclaw@ea3bb92 fix(telegram): route polling diagnostics away from errors · openclaw/openclaw@b5c1199 fix(plugins): support linked source checkouts on Windows · openclaw/openclaw@793e300 fix(gateway): back off session tool mirrors under pressure (#84846) · openclaw/openclaw@42bdc94 fix(config): skip shell env fallback on Windows (#85739) · openclaw/openclaw@06bf302 fix(gateway): avoid duplicate session message broadcasts · openclaw/openclaw@1459044 fix: repair anchorless iMessage watch payloads · openclaw/openclaw@f37fbc9 fix(cli): route node status hints to stdout (#85780) · openclaw/openclaw@749692e fix(oc-path): support deep config edits (#86060) · openclaw/openclaw@3a72a30 fix(config): quiet benign metadata anomaly output · openclaw/openclaw@f3f4f29 fix(test): fail multi-node update regressions · openclaw/openclaw@732cf54 fix(google-vertex): support production ADC modes (#83971) · openclaw/openclaw@f09b4eb test(e2e): expose corrupt plugin deps smoke · openclaw/openclaw@fa3ff4d fix(codex): log app-server approval promotion trigger · openclaw/openclaw@d9af23f test(e2e): harden multi-node update smoke Clean up browser MCP subprocess tree (#85832) · openclaw/openclaw@8dc6b4d fix(agents): log warnings instead of swallowing subagent errors (#82943) · openclaw/openclaw@907bc03 fix(compaction): preserve partial summary on mid-chain chunk failure … · openclaw/openclaw@f0061dd fix(config): do not suppress recovery retry after failed backup resto… · openclaw/openclaw@5d174a5 chore: release 2026.5.25 fix(installer): support alpine cli installs · openclaw/openclaw@f68ed72 test(agents): keep runtime-plan provider mock current fix(scripts): launch env package scripts on Windows · openclaw/openclaw@4d4ce9e fix(agents): cache fallback provider resolution · openclaw/openclaw@3c8d101 fix(test): make import timing scripts Windows-safe · openclaw/openclaw@8ae9977 fix(telegram): transient Telegram pairing prompts (#85555) · openclaw/openclaw@8209426 fix(test): make max Vitest scripts Windows-safe · openclaw/openclaw@b681d5d fix(doctor): migrate Feishu account bot names (#86081) · openclaw/openclaw@9e8cc7e fix(scripts): prefilter conflict marker scans docs: add ClawSweeper review policy to AGENTS (#86197) · openclaw/openclaw@242e876 fix(installer): avoid before with npm release-age configs (#85491) · openclaw/openclaw@4742db6 fix(e2e): retry Windows kitchen sink probes · openclaw/openclaw@3e275a5 fix(installer): install node with apk on alpine fix(installer): detect musl linux shells · openclaw/openclaw@acfed37 perf(plugins,gateway): thread metadata snapshot + discovery through h… · openclaw/openclaw@8ccb11c fix(ui): split control ui runtime chunks · openclaw/openclaw@8bf4f7d refactor(config): extract GoogleChat schema into zod-schema.providers… · openclaw/openclaw@fe34141 fix(update): suppress internal handoff version warnings · openclaw/openclaw@6cc8244 test(e2e): select installable bundled plugins · openclaw/openclaw@0acc3e3 fix(scripts): harden Windows native opus install · openclaw/openclaw@43252c8 fix(agents): match runtime policy entries when session provider is em… fix(scripts): harden Windows generated formatting · openclaw/openclaw@0a98559 fix(mcp): bound tools/list during catalog discovery (#85063) · openclaw/openclaw@07f500a fix(test): focus plugin binding Docker smoke · openclaw/openclaw@dfa1a51 test(e2e): fail release memory indexing errors test(daemon): fail launchd integration bootstrap errors · openclaw/openclaw@af07769 feat(imessage): support thumb approval reactions (#85952) · openclaw/openclaw@5c7980f fix(crabbox): default macos aws runs on demand fix(scripts): preserve test passthrough args · openclaw/openclaw@e4332f7 fix(e2e): harden Windows plugin assertions fix(test): mount upgrade survivor helper · openclaw/openclaw@5f03154 fix(android): prevent stale chat during session switches fix(android): keep permission setup action visible · openclaw/openclaw@94bc18a style(android): sharpen voice mode surfaces · openclaw/openclaw@c452510 fix(android): hide internal chat content blocks · openclaw/openclaw@d86ed21 style(android): refine list surface spacing · openclaw/openclaw@955909c feat(android): add pair new gateway action · openclaw/openclaw@cc5eb97 Advance iMessage catchup cursor after live handling (#85475) · openclaw/openclaw@102555c fix(scripts): ignore forwarded arg separator · openclaw/openclaw@79ee70c fix(test): fail empty gateway startup samples · openclaw/openclaw@5a8ce6a fix(e2e): harden Windows kitchen sink assertions · openclaw/openclaw@87a2eba fix(e2e): harden Telegram credential paths on Windows · openclaw/openclaw@c643370 fix(android): align setup pairing scopes fix(android): complete qr setup operator handoff · openclaw/openclaw@be9bb77 fix(test): copy cleanup smoke prepare hook · openclaw/openclaw@dbc08f6 fix(secrets): allow hash in exec SecretRef ids (#86072) · openclaw/openclaw@675158c fix(media): use static image compression metadata · openclaw/openclaw@694d45e
fix(e2e): sample Windows kitchen sink gateway RSS · openclaw/openclaw@73189e3
vincentkoc · 2026-05-25 · via Recent Commits to openclaw:main

@@ -557,7 +557,7 @@ export async function sampleProcess(pid, options = {}) {

557557

return null;

558558

}

559559

if (platform === "win32") {

560-

return sampleWindowsProcess(pid, run);

560+

return sampleWindowsProcess(pid, run, options.windowsCommandLineNeedles);

561561

}

562562

return samplePosixProcess(pid, run);

563563

}

@@ -601,35 +601,146 @@ async function samplePosixProcess(pid, run) {

601601

}

602602

}

603603604-

async function sampleWindowsProcess(pid, run) {

604+

function parseTasklistCsvLine(line) {

605+

const values = [];

606+

let current = "";

607+

let inQuotes = false;

608+

for (let index = 0; index < line.length; index += 1) {

609+

const char = line[index];

610+

if (char === '"') {

611+

if (inQuotes && line[index + 1] === '"') {

612+

current += '"';

613+

index += 1;

614+

} else {

615+

inQuotes = !inQuotes;

616+

}

617+

continue;

618+

}

619+

if (char === "," && !inQuotes) {

620+

values.push(current);

621+

current = "";

622+

continue;

623+

}

624+

current += char;

625+

}

626+

values.push(current);

627+

return values;

628+

}

629+630+

async function sampleWindowsPidWithTasklist(pid, run) {

631+

const safePid = Number(pid);

632+

if (!Number.isInteger(safePid) || safePid <= 0) {

633+

return null;

634+

}

635+

try {

636+

const { stdout } = await run(

637+

"tasklist.exe",

638+

["/FI", `PID eq ${safePid}`, "/FO", "CSV", "/NH"],

639+

{ timeoutMs: 15000 },

640+

);

641+

const line = stdout

642+

.split(/\r?\n/u)

643+

.map((entry) => entry.trim())

644+

.find((entry) => entry.startsWith('"'));

645+

if (!line) {

646+

return null;

647+

}

648+

const [, processIdRaw, , , memoryRaw] = parseTasklistCsvLine(line);

649+

const processId = Number.parseInt(processIdRaw ?? "", 10);

650+

const memoryKiB = Number.parseInt((memoryRaw ?? "").replace(/[^\d]/gu, ""), 10);

651+

if (!Number.isFinite(memoryKiB)) {

652+

return null;

653+

}

654+

return {

655+

rssMiB: Math.round((memoryKiB / 1024) * 10) / 10,

656+

cpuPercent: null,

657+

cpuSeconds: null,

658+

processId: Number.isFinite(processId) ? processId : safePid,

659+

};

660+

} catch {

661+

return null;

662+

}

663+

}

664+665+

export async function sampleWindowsProcessByPort(port, options = {}) {

666+

const safePort = Number(port);

667+

if (!Number.isInteger(safePort) || safePort <= 0) {

668+

return null;

669+

}

670+

const run = options.runCommand ?? runCommand;

671+

try {

672+

const { stdout } = await run("netstat.exe", ["-ano", "-p", "tcp"], { timeoutMs: 15000 });

673+

const pid = stdout

674+

.split(/\r?\n/u)

675+

.map((line) => line.trim())

676+

.filter((line) => line.includes(`:${safePort}`) && /\bLISTENING\b/iu.test(line))

677+

.map((line) => Number.parseInt(line.split(/\s+/u).at(-1) ?? "", 10))

678+

.find((candidate) => Number.isInteger(candidate) && candidate > 0);

679+

if (!pid) {

680+

return null;

681+

}

682+

return (await sampleWindowsProcess(pid, run)) ?? sampleWindowsPidWithTasklist(pid, run);

683+

} catch {

684+

return null;

685+

}

686+

}

687+688+

function powershellSingleQuoted(value) {

689+

return `'${String(value).replace(/'/gu, "''")}'`;

690+

}

691+692+

async function sampleWindowsProcess(pid, run, commandLineNeedles = []) {

605693

const safePid = Number(pid);

606694

if (!Number.isInteger(safePid) || safePid <= 0) {

607695

return null;

608696

}

609-

const command = [

610-

"$ErrorActionPreference = 'Stop'",

611-

`$process = Get-Process -Id ${safePid} -ErrorAction Stop`,

612-

"$cpu = 0",

613-

"if ($null -ne $process.CPU) { $cpu = $process.CPU }",

614-

"[Console]::Out.Write(('{0} {1}' -f $process.WorkingSet64, $cpu))",

615-

].join("; ");

697+

const needles = commandLineNeedles

698+

.map((needle) => String(needle ?? "").trim())

699+

.filter((needle) => needle.length > 0);

700+

const powershellNeedles = `@(${needles.map(powershellSingleQuoted).join(", ")})`;

701+

const command =

702+

needles.length === 0

703+

? [

704+

"$ErrorActionPreference = 'Stop'",

705+

`$process = Get-Process -Id ${safePid} -ErrorAction Stop`,

706+

"$cpu = 0",

707+

"if ($null -ne $process.CPU) { $cpu = $process.CPU }",

708+

"[Console]::Out.Write(('{0} {1} {2}' -f $process.WorkingSet64, $cpu, $process.Id))",

709+

].join("; ")

710+

: [

711+

"$ErrorActionPreference = 'Stop'",

712+

`$rootPid = ${safePid}`,

713+

`$commandLineNeedles = ${powershellNeedles}`,

714+

"$ids = [System.Collections.Generic.HashSet[int]]::new()",

715+

"[void]$ids.Add($rootPid)",

716+

'if ($commandLineNeedles.Count -gt 0) { $queryNeedle = $commandLineNeedles[$commandLineNeedles.Count - 1].Replace("\'", "\'\'"); $candidates = Get-CimInstance Win32_Process -Filter "CommandLine LIKE \'%$queryNeedle%\'" | Select-Object ProcessId, CommandLine; foreach ($process in $candidates) { if ([int]$process.ProcessId -eq $PID) { continue }; $line = [string]$process.CommandLine; $matches = $true; foreach ($needle in $commandLineNeedles) { if ($line.IndexOf($needle, [StringComparison]::OrdinalIgnoreCase) -lt 0) { $matches = $false; break } }; if ($matches) { [void]$ids.Add([int]$process.ProcessId) } } }',

717+

"if ($ids.Count -le 1) { $processes = Get-CimInstance Win32_Process | Select-Object ProcessId, ParentProcessId; $changed = $true; while ($changed) { $changed = $false; foreach ($process in $processes) { if ($ids.Contains([int]$process.ParentProcessId) -and -not $ids.Contains([int]$process.ProcessId)) { [void]$ids.Add([int]$process.ProcessId); $changed = $true } } } }",

718+

"$samples = foreach ($id in $ids) { try { Get-Process -Id $id -ErrorAction Stop } catch {} }",

719+

"$process = $samples | Sort-Object WorkingSet64 -Descending | Select-Object -First 1",

720+

"if ($null -eq $process) { exit 2 }",

721+

"$cpu = 0",

722+

"if ($null -ne $process.CPU) { $cpu = $process.CPU }",

723+

"[Console]::Out.Write(('{0} {1} {2}' -f $process.WorkingSet64, $cpu, $process.Id))",

724+

].join("; ");

616725

for (const powershell of ["powershell.exe", "powershell"]) {

617726

try {

618727

const { stdout } = await run(

619728

powershell,

620729

["-NoProfile", "-NonInteractive", "-ExecutionPolicy", "Bypass", "-Command", command],

621-

{ timeoutMs: 5000 },

730+

{ timeoutMs: 15000 },

622731

);

623-

const [workingSetBytesRaw, cpuSecondsRaw] = stdout.trim().split(/\s+/u);

732+

const [workingSetBytesRaw, cpuSecondsRaw, processIdRaw] = stdout.trim().split(/\s+/u);

624733

const workingSetBytes = Number.parseInt(workingSetBytesRaw ?? "", 10);

625734

const cpuSeconds = Number.parseFloat(cpuSecondsRaw ?? "");

735+

const processId = Number.parseInt(processIdRaw ?? "", 10);

626736

if (!Number.isFinite(workingSetBytes)) {

627737

return null;

628738

}

629739

return {

630740

rssMiB: Math.round((workingSetBytes / 1024 / 1024) * 10) / 10,

631741

cpuPercent: null,

632742

cpuSeconds: Number.isFinite(cpuSeconds) ? cpuSeconds : null,

743+

processId: Number.isFinite(processId) ? processId : safePid,

633744

};

634745

} catch {

635746

// Try the next Windows PowerShell command name.

@@ -689,7 +800,7 @@ function isNonEmptyString(value) {

689800

}

690801691802

export async function main() {

692-

const runner = resolveOpenClawRunner();

803+

let runner = resolveOpenClawRunner();

693804

const port = readPositiveInt(process.env.OPENCLAW_KITCHEN_SINK_RPC_PORT, DEFAULT_PORT);

694805

const { root, env } = makeEnv();

695806

const logPath = path.join(root, "gateway.log");

@@ -698,6 +809,8 @@ export async function main() {

698809

await runOpenClaw(runner, ["plugins", "install", PLUGIN_SPEC], env, {

699810

timeoutMs: INSTALL_TIMEOUT_MS,

700811

});

812+

runner = resolveOpenClawRunner();

813+

console.log(`Kitchen Sink RPC runtime runner: ${runner.label}`);

701814

configureKitchenSink(env, port);

702815

await runOpenClaw(runner, ["plugins", "enable", PLUGIN_ID], env, { timeoutMs: 60000 });

703816

const inspect = parseJsonOutput(

@@ -717,18 +830,31 @@ export async function main() {

717830

const child = await startGateway(runner, port, env, logPath);

718831

const processSamples = [];

719832

const sampleGateway = async () => {

720-

const sample = await sampleProcess(child.pid);

833+

const windowsSampleOptions = runner.pnpm

834+

? { windowsCommandLineNeedles: ["gateway", "--port", String(port)] }

835+

: {};

836+

let sample = await sampleProcess(child.pid, windowsSampleOptions);

837+

if (!sample && process.platform === "win32") {

838+

sample = await sampleWindowsProcessByPort(port);

839+

}

721840

if (sample) {

722841

processSamples.push(sample);

723842

}

724843

return sample;

725844

};

845+

let sampleInFlight = null;

846+

const collectTimedSample = () => {

847+

sampleInFlight ??= sampleGateway().finally(() => {

848+

sampleInFlight = null;

849+

});

850+

return sampleInFlight;

851+

};

726852

let sampleTimer;

727853

try {

728854

await waitForGatewayReady(child, port, logPath);

729855

const initialSample = await sampleGateway();

730856

sampleTimer = setInterval(() => {

731-

void sampleGateway().catch(() => {});

857+

void collectTimedSample().catch(() => {});

732858

}, 1000);

733859

sampleTimer.unref?.();

734860

const healthz = await fetchJson(`http://127.0.0.1:${port}/healthz`);

@@ -808,6 +934,7 @@ export async function main() {

808934

);

809935

}

810936

await retryRpcCall("diagnostics.stability", {}, { runner, port, env });

937+

await sampleInFlight?.catch(() => {});

811938

const finalSample = await sampleGateway();

812939

assertResourceCeiling(finalSample);

813940

const peakSample = summarizeProcessSamples(processSamples);