Diagnostics
Flagi diagnostyczne
Flagi diagnostyczne pozwalają włączać ukierunkowane logi debugowania bez uruchamiania szczegółowego logowania wszędzie. Flagi są opcjonalne i nie mają efektu, dopóki podsystem ich nie sprawdzi.
Jak to działa
- Flagi są ciągami znaków (bez rozróżniania wielkości liter).
- Możesz włączać flagi w konfiguracji albo przez nadpisanie zmienną środowiskową.
- Obsługiwane są symbole wieloznaczne:
telegram.*pasuje dotelegram.http*włącza wszystkie flagi
Włączanie przez konfigurację
{ "diagnostics": { "flags": ["telegram.http"] }}Wiele flag:
{ "diagnostics": { "flags": ["telegram.http", "brave.http", "gateway.*"] }}Po zmianie flag uruchom ponownie Gateway.
Nadpisanie zmienną środowiskową (jednorazowe)
OPENCLAW_DIAGNOSTICS=telegram.http,telegram.payloadWyłącz wszystkie flagi:
OPENCLAW_DIAGNOSTICS=0OPENCLAW_DIAGNOSTICS=0 to nadpisanie wyłączające na poziomie procesu: wyłącza
flagi zarówno ze zmiennych środowiskowych, jak i z konfiguracji dla tego procesu.
Flagi profilowania
Flagi profilera włączają ukierunkowane przedziały pomiaru czasu bez podnoszenia globalnych poziomów logowania. Domyślnie są wyłączone.
Włącz wszystkie przedziały chronione profilerem dla jednego uruchomienia Gateway:
OPENCLAW_DIAGNOSTICS=profiler openclaw gateway runWłącz tylko przedziały profilera wysyłania odpowiedzi:
OPENCLAW_DIAGNOSTICS=reply.profiler openclaw gateway runWłącz tylko przedziały profilera uruchamiania serwera aplikacji Codex, narzędzi i wątków:
OPENCLAW_DIAGNOSTICS=codex.profiler openclaw gateway runWłącz flagi profilera z konfiguracji:
{ "diagnostics": { "flags": ["reply.profiler", "codex.profiler"] }}Po zmianie flag konfiguracji uruchom ponownie Gateway. Aby wyłączyć flagę profilera,
usuń ją z diagnostics.flags i uruchom ponownie. Aby tymczasowo wyłączyć każdą
flagę diagnostyczną nawet wtedy, gdy konfiguracja włącza flagi profilera, uruchom proces z:
OPENCLAW_DIAGNOSTICS=0 openclaw gateway runArtefakty osi czasu
Flaga timeline zapisuje ustrukturyzowane zdarzenia pomiaru czasu uruchamiania i działania dla
zewnętrznych harnessów QA:
OPENCLAW_DIAGNOSTICS=timeline \OPENCLAW_DIAGNOSTICS_TIMELINE_PATH=/tmp/openclaw-timeline.jsonl \openclaw gateway runMożesz też włączyć ją w konfiguracji:
{ "diagnostics": { "flags": ["timeline"] }}Ścieżka pliku osi czasu nadal pochodzi z
OPENCLAW_DIAGNOSTICS_TIMELINE_PATH. Gdy timeline jest włączona tylko z
konfiguracji, najwcześniejsze przedziały ładowania konfiguracji nie są emitowane, ponieważ OpenClaw
nie odczytał jeszcze konfiguracji; kolejne przedziały uruchamiania używają flagi z konfiguracji.
OPENCLAW_DIAGNOSTICS=1, OPENCLAW_DIAGNOSTICS=all i
OPENCLAW_DIAGNOSTICS=* również włączają oś czasu, ponieważ włączają każdą
flagę diagnostyczną. Wybierz timeline, gdy chcesz tylko artefakt pomiaru czasu JSONL.
Rekordy osi czasu używają otoczki openclaw.diagnostics.v1. Zdarzenia mogą zawierać
identyfikatory procesów, nazwy faz, nazwy przedziałów, czasy trwania, identyfikatory pluginów, liczby zależności,
próbki opóźnień pętli zdarzeń, nazwy operacji dostawców, stan wyjścia procesów potomnych
oraz nazwy/komunikaty błędów uruchamiania. Traktuj pliki osi czasu jako lokalne artefakty diagnostyczne;
przejrzyj je przed udostępnieniem poza swoją maszyną.
Gdzie trafiają logi
Flagi emitują logi do standardowego pliku logu diagnostycznego. Domyślnie:
/tmp/openclaw/openclaw-YYYY-MM-DD.logJeśli ustawisz logging.file, użyj zamiast tego tej ścieżki. Logi są w formacie JSONL (jeden obiekt JSON na wiersz). Redagowanie nadal obowiązuje na podstawie logging.redactSensitive.
Wyodrębnianie logów
Wybierz najnowszy plik logu:
ls -t /tmp/openclaw/openclaw-*.log | head -n 1Filtruj diagnostykę HTTP Telegram:
rg "telegram http error" /tmp/openclaw/openclaw-*.logFiltruj diagnostykę HTTP Brave Search:
rg "brave http" /tmp/openclaw/openclaw-*.logAlbo śledź log podczas odtwarzania problemu:
tail -f /tmp/openclaw/openclaw-$(date +%F).log | rg "telegram http error"W przypadku zdalnych Gateway możesz też użyć openclaw logs --follow (zobacz /cli/logs).
Uwagi
- Jeśli
logging.leveljest ustawiony wyżej niżwarn, te logi mogą zostać pominięte. Domyślneinfojest odpowiednie. brave.httploguje adresy URL/parametry zapytań żądań Brave Search, status/czas odpowiedzi oraz zdarzenia trafienia/chybienia/zapisu pamięci podręcznej. Nie loguje kluczy API ani treści odpowiedzi, ale zapytania wyszukiwania mogą być wrażliwe.- Flagi można bezpiecznie pozostawić włączone; wpływają tylko na objętość logów dla konkretnego podsystemu.
- Użyj /logging, aby zmienić miejsca docelowe logów, poziomy i redagowanie.