[{"data":1,"prerenderedAt":2743},["ShallowReactive",2],{"navigation_docs":3,"-core-concepts-sampling":388,"-core-concepts-sampling-surround":2738},[4,35,155,197,285,372],{"title":5,"path":6,"stem":7,"children":8,"page":34},"Getting Started","\u002Fgetting-started","1.getting-started",[9,14,19,24,29],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fgetting-started\u002Fintroduction","1.getting-started\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Installation","\u002Fgetting-started\u002Finstallation","1.getting-started\u002F2.installation","i-lucide-download",{"title":20,"path":21,"stem":22,"icon":23},"Quick Start","\u002Fgetting-started\u002Fquick-start","1.getting-started\u002F3.quick-start","i-lucide-zap",{"title":25,"path":26,"stem":27,"icon":28},"Agent Skills","\u002Fgetting-started\u002Fagent-skills","1.getting-started\u002F4.agent-skills","i-lucide-sparkles",{"title":30,"path":31,"stem":32,"icon":33},"vs Other Loggers","\u002Fgetting-started\u002Fvs-other-loggers","1.getting-started\u002F5.vs-other-loggers","i-lucide-scale",false,{"title":36,"path":37,"stem":38,"children":39,"page":34},"Logging","\u002Flogging","2.logging",[40,45,50,55,60,65,94,122],{"title":41,"path":42,"stem":43,"icon":44},"Overview","\u002Flogging\u002Foverview","2.logging\u002F0.overview","i-lucide-list",{"title":46,"path":47,"stem":48,"icon":49},"Simple Logging","\u002Flogging\u002Fsimple-logging","2.logging\u002F1.simple-logging","i-lucide-terminal",{"title":51,"path":52,"stem":53,"icon":54},"Wide Events","\u002Flogging\u002Fwide-events","2.logging\u002F2.wide-events","i-lucide-layers",{"title":56,"path":57,"stem":58,"icon":59},"Structured Errors","\u002Flogging\u002Fstructured-errors","2.logging\u002F3.structured-errors","i-lucide-shield-alert",{"title":61,"path":62,"stem":63,"icon":64},"Client Logging","\u002Flogging\u002Fclient-logging","2.logging\u002F4.client-logging","i-lucide-monitor",{"title":66,"icon":67,"path":68,"stem":69,"children":70,"page":34},"AI SDK","i-simple-icons-vercel","\u002Flogging\u002Fai-sdk","2.logging\u002F5.ai-sdk",[71,74,79,84,89],{"title":41,"path":72,"stem":73,"icon":44},"\u002Flogging\u002Fai-sdk\u002Foverview","2.logging\u002F5.ai-sdk\u002F01.overview",{"title":75,"path":76,"stem":77,"icon":78},"Usage","\u002Flogging\u002Fai-sdk\u002Fusage","2.logging\u002F5.ai-sdk\u002F02.usage","i-lucide-code",{"title":80,"path":81,"stem":82,"icon":83},"Options","\u002Flogging\u002Fai-sdk\u002Foptions","2.logging\u002F5.ai-sdk\u002F03.options","i-lucide-sliders",{"title":85,"path":86,"stem":87,"icon":88},"Metadata","\u002Flogging\u002Fai-sdk\u002Fmetadata","2.logging\u002F5.ai-sdk\u002F04.metadata","i-lucide-database",{"title":90,"path":91,"stem":92,"icon":93},"Telemetry","\u002Flogging\u002Fai-sdk\u002Ftelemetry","2.logging\u002F5.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":95,"icon":96,"path":97,"stem":98,"children":99,"page":34},"Better Auth","i-simple-icons-betterauth","\u002Flogging\u002Fbetter-auth","2.logging\u002F6.better-auth",[100,103,108,113,117],{"title":41,"path":101,"stem":102,"icon":44},"\u002Flogging\u002Fbetter-auth\u002Foverview","2.logging\u002F6.better-auth\u002F01.overview",{"title":104,"path":105,"stem":106,"icon":107},"Identify User","\u002Flogging\u002Fbetter-auth\u002Fidentify-user","2.logging\u002F6.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":109,"path":110,"stem":111,"icon":112},"Middleware","\u002Flogging\u002Fbetter-auth\u002Fmiddleware","2.logging\u002F6.better-auth\u002F03.middleware","i-lucide-shield",{"title":114,"path":115,"stem":116,"icon":64},"Client Sync","\u002Flogging\u002Fbetter-auth\u002Fclient-sync","2.logging\u002F6.better-auth\u002F04.client-sync",{"title":118,"path":119,"stem":120,"icon":121},"Performance","\u002Flogging\u002Fbetter-auth\u002Fperformance","2.logging\u002F6.better-auth\u002F05.performance","i-lucide-gauge",{"title":123,"icon":124,"path":125,"stem":126,"children":127,"page":34},"Audit Logs","i-lucide-shield-check","\u002Flogging\u002Faudit","2.logging\u002F7.audit",[128,131,136,141,146,150],{"title":41,"path":129,"stem":130,"icon":44},"\u002Flogging\u002Faudit\u002Foverview","2.logging\u002F7.audit\u002F01.overview",{"title":132,"path":133,"stem":134,"icon":135},"Schema","\u002Flogging\u002Faudit\u002Fschema","2.logging\u002F7.audit\u002F02.schema","i-lucide-file-text",{"title":137,"path":138,"stem":139,"icon":140},"Recording","\u002Flogging\u002Faudit\u002Frecording","2.logging\u002F7.audit\u002F03.recording","i-lucide-pen-line",{"title":142,"path":143,"stem":144,"icon":145},"Drains","\u002Flogging\u002Faudit\u002Fpipeline","2.logging\u002F7.audit\u002F04.pipeline","i-lucide-link",{"title":147,"path":148,"stem":149,"icon":124},"Compliance","\u002Flogging\u002Faudit\u002Fcompliance","2.logging\u002F7.audit\u002F05.compliance",{"title":151,"path":152,"stem":153,"icon":154},"Recipes","\u002Flogging\u002Faudit\u002Frecipes","2.logging\u002F7.audit\u002F06.recipes","i-lucide-book-open",{"title":156,"path":157,"stem":158,"children":159,"page":34},"Core Concepts","\u002Fcore-concepts","3.core-concepts",[160,165,170,175,180,184,187,192],{"title":161,"path":162,"stem":163,"icon":164},"Lifecycle","\u002Fcore-concepts\u002Flifecycle","3.core-concepts\u002F0.lifecycle","i-lucide-arrow-right-left",{"title":166,"path":167,"stem":168,"icon":169},"Configuration","\u002Fcore-concepts\u002Fconfiguration","3.core-concepts\u002F1.configuration","i-lucide-settings",{"title":171,"path":172,"stem":173,"icon":174},"Sampling","\u002Fcore-concepts\u002Fsampling","3.core-concepts\u002F2.sampling","i-lucide-filter",{"title":176,"path":177,"stem":178,"icon":179},"Typed Fields","\u002Fcore-concepts\u002Ftyped-fields","3.core-concepts\u002F3.typed-fields","i-simple-icons-typescript",{"title":181,"path":182,"stem":183,"icon":124},"Best Practices","\u002Fcore-concepts\u002Fbest-practices","3.core-concepts\u002F4.best-practices",{"title":118,"path":185,"stem":186,"icon":121},"\u002Fcore-concepts\u002Fperformance","3.core-concepts\u002F5.performance",{"title":188,"path":189,"stem":190,"icon":191},"Vite Plugin","\u002Fcore-concepts\u002Fvite-plugin","3.core-concepts\u002F6.vite-plugin","i-custom-vite",{"title":193,"path":194,"stem":195,"icon":196},"Auto-Redaction","\u002Fcore-concepts\u002Fredaction","3.core-concepts\u002F7.redaction","i-lucide-eye-off",{"title":198,"path":199,"stem":200,"children":201,"page":34},"Frameworks","\u002Fframeworks","4.frameworks",[202,206,211,216,221,226,231,236,241,246,251,256,261,266,270,275,280],{"title":41,"path":203,"stem":204,"icon":205},"\u002Fframeworks\u002Foverview","4.frameworks\u002F00.overview","i-lucide-layout-grid",{"title":207,"path":208,"stem":209,"icon":210},"Nuxt","\u002Fframeworks\u002Fnuxt","4.frameworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":212,"path":213,"stem":214,"icon":215},"Next.js","\u002Fframeworks\u002Fnextjs","4.frameworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":217,"path":218,"stem":219,"icon":220},"SvelteKit","\u002Fframeworks\u002Fsveltekit","4.frameworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":222,"path":223,"stem":224,"icon":225},"Nitro","\u002Fframeworks\u002Fnitro","4.frameworks\u002F04.nitro","i-custom-nitro",{"title":227,"path":228,"stem":229,"icon":230},"TanStack Start","\u002Fframeworks\u002Ftanstack-start","4.frameworks\u002F05.tanstack-start","i-custom-tanstack",{"title":232,"path":233,"stem":234,"icon":235},"NestJS","\u002Fframeworks\u002Fnestjs","4.frameworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":237,"path":238,"stem":239,"icon":240},"Express","\u002Fframeworks\u002Fexpress","4.frameworks\u002F07.express","i-simple-icons-express",{"title":242,"path":243,"stem":244,"icon":245},"Hono","\u002Fframeworks\u002Fhono","4.frameworks\u002F08.hono","i-simple-icons-hono",{"title":247,"path":248,"stem":249,"icon":250},"Fastify","\u002Fframeworks\u002Ffastify","4.frameworks\u002F09.fastify","i-simple-icons-fastify",{"title":252,"path":253,"stem":254,"icon":255},"Elysia","\u002Fframeworks\u002Felysia","4.frameworks\u002F10.elysia","i-custom-elysia",{"title":257,"path":258,"stem":259,"icon":260},"React Router","\u002Fframeworks\u002Freact-router","4.frameworks\u002F11.react-router","i-custom-reactrouter",{"title":262,"path":263,"stem":264,"icon":265},"Cloudflare Workers","\u002Fframeworks\u002Fcloudflare-workers","4.frameworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":267,"path":268,"stem":269,"icon":179},"Standalone","\u002Fframeworks\u002Fstandalone","4.frameworks\u002F13.standalone",{"title":271,"path":272,"stem":273,"icon":274},"Astro","\u002Fframeworks\u002Fastro","4.frameworks\u002F14.astro","i-simple-icons-astro",{"title":276,"path":277,"stem":278,"icon":279},"AWS Lambda","\u002Fframeworks\u002Faws-lambda","4.frameworks\u002F16.aws-lambda","i-custom-lambda",{"title":281,"path":282,"stem":283,"icon":284},"Custom Integration","\u002Fframeworks\u002Fcustom-integration","4.frameworks\u002F17.custom-integration","i-lucide-puzzle",{"title":286,"path":287,"stem":288,"children":289,"page":34},"Adapters","\u002Fadapters","6.adapters",[290,293,333,348],{"title":41,"path":291,"stem":292,"icon":44},"\u002Fadapters\u002Foverview","6.adapters\u002F01.overview",{"title":294,"path":295,"stem":296,"children":297,"page":34},"Cloud destinations","\u002Fadapters\u002Fcloud","6.adapters\u002F02.cloud",[298,303,308,313,318,323,328],{"title":299,"path":300,"stem":301,"icon":302},"Axiom","\u002Fadapters\u002Fcloud\u002Faxiom","6.adapters\u002F02.cloud\u002F01.axiom","i-custom-axiom",{"title":304,"path":305,"stem":306,"icon":307},"OTLP","\u002Fadapters\u002Fcloud\u002Fotlp","6.adapters\u002F02.cloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":309,"path":310,"stem":311,"icon":312},"PostHog","\u002Fadapters\u002Fcloud\u002Fposthog","6.adapters\u002F02.cloud\u002F03.posthog","i-simple-icons-posthog",{"title":314,"path":315,"stem":316,"icon":317},"Sentry","\u002Fadapters\u002Fcloud\u002Fsentry","6.adapters\u002F02.cloud\u002F04.sentry","i-simple-icons-sentry",{"title":319,"path":320,"stem":321,"icon":322},"Better Stack","\u002Fadapters\u002Fcloud\u002Fbetter-stack","6.adapters\u002F02.cloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":324,"path":325,"stem":326,"icon":327},"Datadog","\u002Fadapters\u002Fcloud\u002Fdatadog","6.adapters\u002F02.cloud\u002F06.datadog","i-simple-icons-datadog",{"title":329,"path":330,"stem":331,"icon":332},"HyperDX","\u002Fadapters\u002Fcloud\u002Fhyperdx","6.adapters\u002F02.cloud\u002F07.hyperdx","i-custom-hyperdx",{"title":334,"path":335,"stem":336,"children":337,"page":34},"Self-hosted","\u002Fadapters\u002Fself-hosted","6.adapters\u002F03.self-hosted",[338,343],{"title":339,"path":340,"stem":341,"icon":342},"File System","\u002Fadapters\u002Fself-hosted\u002Ffs","6.adapters\u002F03.self-hosted\u002F01.fs","i-lucide-hard-drive",{"title":344,"path":345,"stem":346,"icon":347},"NuxtHub","\u002Fadapters\u002Fself-hosted\u002Fnuxthub","6.adapters\u002F03.self-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":349,"path":350,"stem":351,"children":352,"page":34},"Building blocks","\u002Fadapters\u002Fbuilding-blocks","6.adapters\u002F04.building-blocks",[353,358,363,367],{"title":354,"path":355,"stem":356,"icon":357},"Pipeline","\u002Fadapters\u002Fbuilding-blocks\u002Fpipeline","6.adapters\u002F04.building-blocks\u002F01.pipeline","i-lucide-workflow",{"title":359,"path":360,"stem":361,"icon":362},"HTTP","\u002Fadapters\u002Fbuilding-blocks\u002Fhttp","6.adapters\u002F04.building-blocks\u002F02.http","i-lucide-globe",{"title":364,"path":365,"stem":366,"icon":78},"Custom Adapters","\u002Fadapters\u002Fbuilding-blocks\u002Fcustom","6.adapters\u002F04.building-blocks\u002F03.custom",{"title":368,"path":369,"stem":370,"icon":371},"Toolkit","\u002Fadapters\u002Fbuilding-blocks\u002Ftoolkit","6.adapters\u002F04.building-blocks\u002F04.toolkit","i-lucide-blocks",{"title":373,"path":374,"stem":375,"children":376,"page":34},"Enrichers","\u002Fenrichers","7.enrichers",[377,380,384],{"title":41,"path":378,"stem":379,"icon":28},"\u002Fenrichers\u002Foverview","7.enrichers\u002F1.overview",{"title":381,"path":382,"stem":383,"icon":284},"Built-in","\u002Fenrichers\u002Fbuilt-in","7.enrichers\u002F2.built-in",{"title":385,"path":386,"stem":387,"icon":78},"Custom","\u002Fenrichers\u002Fcustom","7.enrichers\u002F3.custom",{"id":389,"title":171,"body":390,"description":2727,"extension":2728,"links":2729,"meta":2734,"navigation":2735,"path":172,"seo":2736,"stem":173,"__hash__":2737},"docs\u002F3.core-concepts\u002F2.sampling.md",{"type":391,"value":392,"toc":2717},"minimark",[393,397,445,450,458,939,946,955,959,966,1093,1116,1121,1193,1197,1200,1231,1241,1244,1449,1453,1463,1913,1919,2024,2028,2031,2688,2697,2701,2713],[394,395,396],"p",{},"At scale, logging everything gets expensive fast. Sampling lets you keep costs under control without losing visibility into what matters. evlog uses a two-tier approach: head sampling drops noise upfront, tail sampling rescues critical events after the fact.",[398,399,402,405,431],"prompt",{":actions":400,"description":401,"icon":174},"[\"copy\",\"cursor\",\"windsurf\"]","Enable head and tail sampling",[394,403,404],{},"Enable head and tail sampling in my evlog production config.",[406,407,408,412,415,422,425,428],"ul",{},[409,410,411],"li",{},"Identify my framework and locate the evlog config (nuxt.config.ts, lib\u002Fevlog.ts, initLogger, etc.)",[409,413,414],{},"Configure sampling.rates per level: { info: 10, warn: 50, debug: 0, error: 100 } as a starting point",[409,416,417,418],{},"Add sampling.keep rules to force-keep critical events: ",[419,420,421],"span",{},"{ status: 400 }, { duration: 1000 }, { path: '\u002Fapi\u002Fcritical\u002F**' }",[409,423,424],{},"For business-specific keep logic (e.g. premium users), add a custom keep callback or evlog:emit:keep hook",[409,426,427],{},"Wrap sampling in a $production override so dev keeps full logging",[409,429,430],{},"Confirm errors are always kept by default unless I explicitly set error: 0",[394,432,433,434,440,441],{},"Docs: ",[435,436,437],"a",{"href":437,"rel":438},"https:\u002F\u002Fwww.evlog.dev\u002Fcore-concepts\u002Fsampling",[439],"nofollow","\nBest practices: ",[435,442,443],{"href":443,"rel":444},"https:\u002F\u002Fwww.evlog.dev\u002Fcore-concepts\u002Fbest-practices",[439],[446,447,449],"h2",{"id":448},"head-sampling","Head Sampling",[394,451,452,453,457],{},"Head sampling randomly keeps a percentage of logs per level. It runs ",[454,455,456],"strong",{},"before"," the request completes, acting as a coin flip at emission time.",[459,460,461,648,807],"code-group",{},[462,463,469],"pre",{"className":464,"code":465,"filename":466,"language":467,"meta":468,"style":468},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","export default defineNuxtConfig({\n  modules: ['evlog\u002Fnuxt'],\n  evlog: {\n    sampling: {\n      rates: {\n        info: 10,    \u002F\u002F Keep 10% of info logs\n        warn: 50,    \u002F\u002F Keep 50% of warnings\n        debug: 0,    \u002F\u002F Drop all debug logs\n        error: 100,  \u002F\u002F Always keep errors (default)\n      },\n    },\n  },\n})\n","nuxt.config.ts","typescript","",[470,471,472,495,523,534,544,554,573,589,605,621,627,633,639],"code",{"__ignoreMap":468},[419,473,476,480,483,487,491],{"class":474,"line":475},"line",1,[419,477,479],{"class":478},"s7zQu","export",[419,481,482],{"class":478}," default",[419,484,486],{"class":485},"s2Zo4"," defineNuxtConfig",[419,488,490],{"class":489},"sTEyZ","(",[419,492,494],{"class":493},"sMK4o","{\n",[419,496,498,502,505,508,511,515,517,520],{"class":474,"line":497},2,[419,499,501],{"class":500},"swJcz","  modules",[419,503,504],{"class":493},":",[419,506,507],{"class":489}," [",[419,509,510],{"class":493},"'",[419,512,514],{"class":513},"sfazB","evlog\u002Fnuxt",[419,516,510],{"class":493},[419,518,519],{"class":489},"]",[419,521,522],{"class":493},",\n",[419,524,526,529,531],{"class":474,"line":525},3,[419,527,528],{"class":500},"  evlog",[419,530,504],{"class":493},[419,532,533],{"class":493}," {\n",[419,535,537,540,542],{"class":474,"line":536},4,[419,538,539],{"class":500},"    sampling",[419,541,504],{"class":493},[419,543,533],{"class":493},[419,545,547,550,552],{"class":474,"line":546},5,[419,548,549],{"class":500},"      rates",[419,551,504],{"class":493},[419,553,533],{"class":493},[419,555,557,560,562,566,569],{"class":474,"line":556},6,[419,558,559],{"class":500},"        info",[419,561,504],{"class":493},[419,563,565],{"class":564},"sbssI"," 10",[419,567,568],{"class":493},",",[419,570,572],{"class":571},"sHwdD","    \u002F\u002F Keep 10% of info logs\n",[419,574,576,579,581,584,586],{"class":474,"line":575},7,[419,577,578],{"class":500},"        warn",[419,580,504],{"class":493},[419,582,583],{"class":564}," 50",[419,585,568],{"class":493},[419,587,588],{"class":571},"    \u002F\u002F Keep 50% of warnings\n",[419,590,592,595,597,600,602],{"class":474,"line":591},8,[419,593,594],{"class":500},"        debug",[419,596,504],{"class":493},[419,598,599],{"class":564}," 0",[419,601,568],{"class":493},[419,603,604],{"class":571},"    \u002F\u002F Drop all debug logs\n",[419,606,608,611,613,616,618],{"class":474,"line":607},9,[419,609,610],{"class":500},"        error",[419,612,504],{"class":493},[419,614,615],{"class":564}," 100",[419,617,568],{"class":493},[419,619,620],{"class":571},"  \u002F\u002F Always keep errors (default)\n",[419,622,624],{"class":474,"line":623},10,[419,625,626],{"class":493},"      },\n",[419,628,630],{"class":474,"line":629},11,[419,631,632],{"class":493},"    },\n",[419,634,636],{"class":474,"line":635},12,[419,637,638],{"class":493},"  },\n",[419,640,642,645],{"class":474,"line":641},13,[419,643,644],{"class":493},"}",[419,646,647],{"class":489},")\n",[462,649,652],{"className":464,"code":650,"filename":651,"language":467,"meta":468,"style":468},"import { createEvlog } from 'evlog\u002Fnext'\n\nexport const { withEvlog, useLogger } = createEvlog({\n  service: 'my-app',\n  sampling: {\n    rates: {\n      info: 10,\n      warn: 50,\n      debug: 0,\n      error: 100,\n    },\n  },\n})\n","lib\u002Fevlog.ts (Next.js)",[470,653,654,680,686,715,731,740,749,760,771,782,793,797,801],{"__ignoreMap":468},[419,655,656,659,662,665,668,671,674,677],{"class":474,"line":475},[419,657,658],{"class":478},"import",[419,660,661],{"class":493}," {",[419,663,664],{"class":489}," createEvlog",[419,666,667],{"class":493}," }",[419,669,670],{"class":478}," from",[419,672,673],{"class":493}," '",[419,675,676],{"class":513},"evlog\u002Fnext",[419,678,679],{"class":493},"'\n",[419,681,682],{"class":474,"line":497},[419,683,685],{"emptyLinePlaceholder":684},true,"\n",[419,687,688,690,694,696,699,701,704,706,709,711,713],{"class":474,"line":525},[419,689,479],{"class":478},[419,691,693],{"class":692},"spNyl"," const",[419,695,661],{"class":493},[419,697,698],{"class":489}," withEvlog",[419,700,568],{"class":493},[419,702,703],{"class":489}," useLogger ",[419,705,644],{"class":493},[419,707,708],{"class":493}," =",[419,710,664],{"class":485},[419,712,490],{"class":489},[419,714,494],{"class":493},[419,716,717,720,722,724,727,729],{"class":474,"line":536},[419,718,719],{"class":500},"  service",[419,721,504],{"class":493},[419,723,673],{"class":493},[419,725,726],{"class":513},"my-app",[419,728,510],{"class":493},[419,730,522],{"class":493},[419,732,733,736,738],{"class":474,"line":546},[419,734,735],{"class":500},"  sampling",[419,737,504],{"class":493},[419,739,533],{"class":493},[419,741,742,745,747],{"class":474,"line":556},[419,743,744],{"class":500},"    rates",[419,746,504],{"class":493},[419,748,533],{"class":493},[419,750,751,754,756,758],{"class":474,"line":575},[419,752,753],{"class":500},"      info",[419,755,504],{"class":493},[419,757,565],{"class":564},[419,759,522],{"class":493},[419,761,762,765,767,769],{"class":474,"line":591},[419,763,764],{"class":500},"      warn",[419,766,504],{"class":493},[419,768,583],{"class":564},[419,770,522],{"class":493},[419,772,773,776,778,780],{"class":474,"line":607},[419,774,775],{"class":500},"      debug",[419,777,504],{"class":493},[419,779,599],{"class":564},[419,781,522],{"class":493},[419,783,784,787,789,791],{"class":474,"line":623},[419,785,786],{"class":500},"      error",[419,788,504],{"class":493},[419,790,615],{"class":564},[419,792,522],{"class":493},[419,794,795],{"class":474,"line":629},[419,796,632],{"class":493},[419,798,799],{"class":474,"line":635},[419,800,638],{"class":493},[419,802,803,805],{"class":474,"line":641},[419,804,644],{"class":493},[419,806,647],{"class":489},[462,808,811],{"className":464,"code":809,"filename":810,"language":467,"meta":468,"style":468},"import { initLogger } from 'evlog'\n\ninitLogger({\n  env: { service: 'my-app' },\n  sampling: {\n    rates: {\n      info: 10,\n      warn: 50,\n      debug: 0,\n      error: 100,\n    },\n  },\n})\n","index.ts (Hono \u002F Express \u002F Fastify)",[470,812,813,833,837,846,869,877,885,895,905,915,925,929,933],{"__ignoreMap":468},[419,814,815,817,819,822,824,826,828,831],{"class":474,"line":475},[419,816,658],{"class":478},[419,818,661],{"class":493},[419,820,821],{"class":489}," initLogger",[419,823,667],{"class":493},[419,825,670],{"class":478},[419,827,673],{"class":493},[419,829,830],{"class":513},"evlog",[419,832,679],{"class":493},[419,834,835],{"class":474,"line":497},[419,836,685],{"emptyLinePlaceholder":684},[419,838,839,842,844],{"class":474,"line":525},[419,840,841],{"class":485},"initLogger",[419,843,490],{"class":489},[419,845,494],{"class":493},[419,847,848,851,853,855,858,860,862,864,866],{"class":474,"line":536},[419,849,850],{"class":500},"  env",[419,852,504],{"class":493},[419,854,661],{"class":493},[419,856,857],{"class":500}," service",[419,859,504],{"class":493},[419,861,673],{"class":493},[419,863,726],{"class":513},[419,865,510],{"class":493},[419,867,868],{"class":493}," },\n",[419,870,871,873,875],{"class":474,"line":546},[419,872,735],{"class":500},[419,874,504],{"class":493},[419,876,533],{"class":493},[419,878,879,881,883],{"class":474,"line":556},[419,880,744],{"class":500},[419,882,504],{"class":493},[419,884,533],{"class":493},[419,886,887,889,891,893],{"class":474,"line":575},[419,888,753],{"class":500},[419,890,504],{"class":493},[419,892,565],{"class":564},[419,894,522],{"class":493},[419,896,897,899,901,903],{"class":474,"line":591},[419,898,764],{"class":500},[419,900,504],{"class":493},[419,902,583],{"class":564},[419,904,522],{"class":493},[419,906,907,909,911,913],{"class":474,"line":607},[419,908,775],{"class":500},[419,910,504],{"class":493},[419,912,599],{"class":564},[419,914,522],{"class":493},[419,916,917,919,921,923],{"class":474,"line":623},[419,918,786],{"class":500},[419,920,504],{"class":493},[419,922,615],{"class":564},[419,924,522],{"class":493},[419,926,927],{"class":474,"line":629},[419,928,632],{"class":493},[419,930,931],{"class":474,"line":635},[419,932,638],{"class":493},[419,934,935,937],{"class":474,"line":641},[419,936,644],{"class":493},[419,938,647],{"class":489},[394,940,941,942,945],{},"Each level is a percentage from 0 to 100. Levels you don't configure default to 100% (keep everything). Error defaults to 100% even when other levels are configured, so you have to explicitly set ",[470,943,944],{},"error: 0"," to drop errors.",[947,948,950,951,954],"callout",{"color":949,"icon":13},"info","Head sampling is random. A ",[470,952,953],{},"10%"," rate means roughly 1 in 10 info logs are kept, not exactly 1 in 10.",[446,956,958],{"id":957},"tail-sampling","Tail Sampling",[394,960,961,962,965],{},"Head sampling is blind: it doesn't know if a request was slow, failed, or hit a critical path. Tail sampling fixes this by evaluating ",[454,963,964],{},"after"," the request completes and force-keeping logs that match specific conditions.",[462,967,969],{"className":464,"code":968,"filename":466,"language":467,"meta":468,"style":468},"\u002F\u002F Sampling config, works the same across all frameworks\nevlog: {\n  sampling: {\n    rates: { info: 10 },\n    keep: [\n      { status: 400 },              \u002F\u002F HTTP status >= 400\n      { duration: 1000 },           \u002F\u002F Request took >= 1s\n      { path: '\u002Fapi\u002Fpayments\u002F**' }, \u002F\u002F Critical path (glob)\n    ],\n  },\n}\n",[470,970,971,976,985,993,1010,1020,1039,1056,1077,1084,1088],{"__ignoreMap":468},[419,972,973],{"class":474,"line":475},[419,974,975],{"class":571},"\u002F\u002F Sampling config, works the same across all frameworks\n",[419,977,978,981,983],{"class":474,"line":497},[419,979,830],{"class":980},"sBMFI",[419,982,504],{"class":493},[419,984,533],{"class":493},[419,986,987,989,991],{"class":474,"line":525},[419,988,735],{"class":980},[419,990,504],{"class":493},[419,992,533],{"class":493},[419,994,995,997,999,1001,1004,1006,1008],{"class":474,"line":536},[419,996,744],{"class":980},[419,998,504],{"class":493},[419,1000,661],{"class":493},[419,1002,1003],{"class":980}," info",[419,1005,504],{"class":493},[419,1007,565],{"class":564},[419,1009,868],{"class":493},[419,1011,1012,1015,1017],{"class":474,"line":546},[419,1013,1014],{"class":980},"    keep",[419,1016,504],{"class":493},[419,1018,1019],{"class":500}," [\n",[419,1021,1022,1025,1028,1030,1033,1036],{"class":474,"line":556},[419,1023,1024],{"class":493},"      {",[419,1026,1027],{"class":500}," status",[419,1029,504],{"class":493},[419,1031,1032],{"class":564}," 400",[419,1034,1035],{"class":493}," },",[419,1037,1038],{"class":571},"              \u002F\u002F HTTP status >= 400\n",[419,1040,1041,1043,1046,1048,1051,1053],{"class":474,"line":575},[419,1042,1024],{"class":493},[419,1044,1045],{"class":500}," duration",[419,1047,504],{"class":493},[419,1049,1050],{"class":564}," 1000",[419,1052,1035],{"class":493},[419,1054,1055],{"class":571},"           \u002F\u002F Request took >= 1s\n",[419,1057,1058,1060,1063,1065,1067,1070,1072,1074],{"class":474,"line":591},[419,1059,1024],{"class":493},[419,1061,1062],{"class":500}," path",[419,1064,504],{"class":493},[419,1066,673],{"class":493},[419,1068,1069],{"class":513},"\u002Fapi\u002Fpayments\u002F**",[419,1071,510],{"class":493},[419,1073,1035],{"class":493},[419,1075,1076],{"class":571}," \u002F\u002F Critical path (glob)\n",[419,1078,1079,1082],{"class":474,"line":607},[419,1080,1081],{"class":500},"    ]",[419,1083,522],{"class":493},[419,1085,1086],{"class":474,"line":623},[419,1087,638],{"class":493},[419,1089,1090],{"class":474,"line":629},[419,1091,1092],{"class":493},"}\n",[394,1094,1095,1096,1099,1100,1103,1104,1107,1108,1111,1112,1115],{},"Conditions use ",[454,1097,1098],{},">="," comparison for ",[470,1101,1102],{},"status"," and ",[470,1105,1106],{},"duration",", and glob matching for ",[470,1109,1110],{},"path",". If ",[454,1113,1114],{},"any"," condition matches, the log is kept regardless of head sampling (OR logic).",[1117,1118,1120],"h3",{"id":1119},"available-conditions","Available Conditions",[1122,1123,1124,1140],"table",{},[1125,1126,1127],"thead",{},[1128,1129,1130,1134,1137],"tr",{},[1131,1132,1133],"th",{},"Condition",[1131,1135,1136],{},"Type",[1131,1138,1139],{},"Description",[1141,1142,1143,1162,1175],"tbody",{},[1128,1144,1145,1150,1155],{},[1146,1147,1148],"td",{},[470,1149,1102],{},[1146,1151,1152],{},[470,1153,1154],{},"number",[1146,1156,1157,1158,1161],{},"Keep if HTTP status >= value (e.g., ",[470,1159,1160],{},"400"," catches all 4xx and 5xx)",[1128,1163,1164,1168,1172],{},[1146,1165,1166],{},[470,1167,1106],{},[1146,1169,1170],{},[470,1171,1154],{},[1146,1173,1174],{},"Keep if request duration >= value in milliseconds",[1128,1176,1177,1181,1186],{},[1146,1178,1179],{},[470,1180,1110],{},[1146,1182,1183],{},[470,1184,1185],{},"string",[1146,1187,1188,1189,1192],{},"Keep if request path matches glob pattern (e.g., ",[470,1190,1191],{},"'\u002Fapi\u002Fcritical\u002F**'",")",[446,1194,1196],{"id":1195},"how-they-work-together","How They Work Together",[394,1198,1199],{},"The two tiers complement each other:",[1201,1202,1203,1209,1219,1225],"ol",{},[409,1204,1205,1208],{},[454,1206,1207],{},"Request completes"," - evlog knows the status, duration, and path",[409,1210,1211,1214,1215,1218],{},[454,1212,1213],{},"Tail sampling evaluates"," - if any ",[470,1216,1217],{},"keep"," condition matches, the log is force-kept",[409,1220,1221,1224],{},[454,1222,1223],{},"Head sampling applies"," - only if tail sampling didn't force-keep, the random percentage check runs",[409,1226,1227,1230],{},[454,1228,1229],{},"Log emits or drops"," - kept logs go through enrichment and draining as normal",[394,1232,1233,1234,1237,1238,1240],{},"This means a request to ",[470,1235,1236],{},"\u002Fapi\u002Fpayments\u002Fcharge"," that returns a 500 in 2 seconds will always be logged, even if ",[470,1239,949],{}," is set to 1%. The tail conditions rescue it.",[1242,1243],"tail-sample-decision",{},[459,1245,1246,1322],{},[462,1247,1249],{"className":464,"code":1248,"filename":166,"language":467,"meta":468,"style":468},"sampling: {\n  rates: { info: 10 },\n  keep: [\n    { status: 400 },\n    { duration: 1000 },\n  ],\n}\n",[470,1250,1251,1260,1277,1286,1299,1311,1318],{"__ignoreMap":468},[419,1252,1253,1256,1258],{"class":474,"line":475},[419,1254,1255],{"class":980},"sampling",[419,1257,504],{"class":493},[419,1259,533],{"class":493},[419,1261,1262,1265,1267,1269,1271,1273,1275],{"class":474,"line":497},[419,1263,1264],{"class":980},"  rates",[419,1266,504],{"class":493},[419,1268,661],{"class":493},[419,1270,1003],{"class":980},[419,1272,504],{"class":493},[419,1274,565],{"class":564},[419,1276,868],{"class":493},[419,1278,1279,1282,1284],{"class":474,"line":525},[419,1280,1281],{"class":980},"  keep",[419,1283,504],{"class":493},[419,1285,1019],{"class":500},[419,1287,1288,1291,1293,1295,1297],{"class":474,"line":536},[419,1289,1290],{"class":493},"    {",[419,1292,1027],{"class":500},[419,1294,504],{"class":493},[419,1296,1032],{"class":564},[419,1298,868],{"class":493},[419,1300,1301,1303,1305,1307,1309],{"class":474,"line":546},[419,1302,1290],{"class":493},[419,1304,1045],{"class":500},[419,1306,504],{"class":493},[419,1308,1050],{"class":564},[419,1310,868],{"class":493},[419,1312,1313,1316],{"class":474,"line":556},[419,1314,1315],{"class":500},"  ]",[419,1317,522],{"class":493},[419,1319,1320],{"class":474,"line":575},[419,1321,1092],{"class":493},[462,1323,1328],{"className":1324,"code":1325,"filename":1326,"language":1327,"meta":468,"style":468},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","POST \u002Fapi\u002Fusers     200  45ms   → 10% chance (head sampling)\nPOST \u002Fapi\u002Fusers     500  45ms   → always kept (status >= 400)\nGET  \u002Fapi\u002Fproducts  200  2300ms → always kept (duration >= 1000)\nPOST \u002Fapi\u002Fcheckout  200  120ms  → 10% chance (head sampling)\n","What gets logged","bash",[470,1329,1330,1360,1392,1424],{"__ignoreMap":468},[419,1331,1332,1335,1338,1341,1344,1347,1350,1353,1356,1358],{"class":474,"line":475},[419,1333,1334],{"class":980},"POST",[419,1336,1337],{"class":513}," \u002Fapi\u002Fusers",[419,1339,1340],{"class":564},"     200",[419,1342,1343],{"class":513},"  45ms",[419,1345,1346],{"class":513},"   →",[419,1348,1349],{"class":513}," 10%",[419,1351,1352],{"class":513}," chance",[419,1354,1355],{"class":489}," (head ",[419,1357,1255],{"class":513},[419,1359,647],{"class":489},[419,1361,1362,1364,1366,1369,1371,1373,1376,1379,1382,1385,1388,1390],{"class":474,"line":497},[419,1363,1334],{"class":980},[419,1365,1337],{"class":513},[419,1367,1368],{"class":564},"     500",[419,1370,1343],{"class":513},[419,1372,1346],{"class":513},[419,1374,1375],{"class":513}," always",[419,1377,1378],{"class":513}," kept",[419,1380,1381],{"class":489}," (status ",[419,1383,1384],{"class":493},">",[419,1386,1387],{"class":513},"=",[419,1389,1032],{"class":564},[419,1391,647],{"class":489},[419,1393,1394,1397,1400,1403,1406,1409,1411,1413,1416,1418,1420,1422],{"class":474,"line":525},[419,1395,1396],{"class":980},"GET",[419,1398,1399],{"class":513},"  \u002Fapi\u002Fproducts",[419,1401,1402],{"class":564},"  200",[419,1404,1405],{"class":513},"  2300ms",[419,1407,1408],{"class":513}," →",[419,1410,1375],{"class":513},[419,1412,1378],{"class":513},[419,1414,1415],{"class":489}," (duration ",[419,1417,1384],{"class":493},[419,1419,1387],{"class":513},[419,1421,1050],{"class":564},[419,1423,647],{"class":489},[419,1425,1426,1428,1431,1433,1436,1439,1441,1443,1445,1447],{"class":474,"line":536},[419,1427,1334],{"class":980},[419,1429,1430],{"class":513}," \u002Fapi\u002Fcheckout",[419,1432,1402],{"class":564},[419,1434,1435],{"class":513},"  120ms",[419,1437,1438],{"class":513},"  →",[419,1440,1349],{"class":513},[419,1442,1352],{"class":513},[419,1444,1355],{"class":489},[419,1446,1255],{"class":513},[419,1448,647],{"class":489},[446,1450,1452],{"id":1451},"custom-tail-sampling","Custom Tail Sampling",[394,1454,1455,1456,1459,1460,1462],{},"For conditions beyond status, duration, and path, use the ",[470,1457,1458],{},"evlog:emit:keep"," hook in Nuxt\u002FNitro or the ",[470,1461,1217],{}," callback in other frameworks.",[459,1464,1465,1607,1794],{},[462,1466,1469],{"className":464,"code":1467,"filename":1468,"language":467,"meta":468,"style":468},"export default defineNitroPlugin((nitroApp) => {\n  nitroApp.hooks.hook('evlog:emit:keep', (ctx) => {\n    if (ctx.context.user?.plan === 'enterprise') {\n      ctx.shouldKeep = true\n    }\n  })\n})\n","server\u002Fplugins\u002Fsampling.ts (Nuxt)",[470,1470,1471,1495,1533,1573,1589,1594,1601],{"__ignoreMap":468},[419,1472,1473,1475,1477,1480,1482,1484,1488,1490,1493],{"class":474,"line":475},[419,1474,479],{"class":478},[419,1476,482],{"class":478},[419,1478,1479],{"class":485}," defineNitroPlugin",[419,1481,490],{"class":489},[419,1483,490],{"class":493},[419,1485,1487],{"class":1486},"sHdIc","nitroApp",[419,1489,1192],{"class":493},[419,1491,1492],{"class":692}," =>",[419,1494,533],{"class":493},[419,1496,1497,1500,1503,1506,1508,1511,1513,1515,1517,1519,1521,1524,1527,1529,1531],{"class":474,"line":497},[419,1498,1499],{"class":489},"  nitroApp",[419,1501,1502],{"class":493},".",[419,1504,1505],{"class":489},"hooks",[419,1507,1502],{"class":493},[419,1509,1510],{"class":485},"hook",[419,1512,490],{"class":500},[419,1514,510],{"class":493},[419,1516,1458],{"class":513},[419,1518,510],{"class":493},[419,1520,568],{"class":493},[419,1522,1523],{"class":493}," (",[419,1525,1526],{"class":1486},"ctx",[419,1528,1192],{"class":493},[419,1530,1492],{"class":692},[419,1532,533],{"class":493},[419,1534,1535,1538,1540,1542,1544,1547,1549,1552,1555,1558,1561,1563,1566,1568,1571],{"class":474,"line":525},[419,1536,1537],{"class":478},"    if",[419,1539,1523],{"class":500},[419,1541,1526],{"class":489},[419,1543,1502],{"class":493},[419,1545,1546],{"class":489},"context",[419,1548,1502],{"class":493},[419,1550,1551],{"class":489},"user",[419,1553,1554],{"class":493},"?.",[419,1556,1557],{"class":489},"plan",[419,1559,1560],{"class":493}," ===",[419,1562,673],{"class":493},[419,1564,1565],{"class":513},"enterprise",[419,1567,510],{"class":493},[419,1569,1570],{"class":500},") ",[419,1572,494],{"class":493},[419,1574,1575,1578,1580,1583,1585],{"class":474,"line":536},[419,1576,1577],{"class":489},"      ctx",[419,1579,1502],{"class":493},[419,1581,1582],{"class":489},"shouldKeep",[419,1584,708],{"class":493},[419,1586,1588],{"class":1587},"sfNiH"," true\n",[419,1590,1591],{"class":474,"line":546},[419,1592,1593],{"class":493},"    }\n",[419,1595,1596,1599],{"class":474,"line":556},[419,1597,1598],{"class":493},"  }",[419,1600,647],{"class":500},[419,1602,1603,1605],{"class":474,"line":575},[419,1604,644],{"class":493},[419,1606,647],{"class":489},[462,1608,1610],{"className":464,"code":1609,"filename":651,"language":467,"meta":468,"style":468},"import { createEvlog } from 'evlog\u002Fnext'\n\nexport const { withEvlog, useLogger } = createEvlog({\n  service: 'my-app',\n  sampling: {\n    rates: { info: 10 },\n    keep: [{ status: 400 }],\n  },\n  keep(ctx) {\n    if (ctx.context.user?.plan === 'enterprise') {\n      ctx.shouldKeep = true\n    }\n  },\n})\n",[470,1611,1612,1630,1634,1658,1672,1680,1696,1719,1723,1735,1767,1779,1783,1787],{"__ignoreMap":468},[419,1613,1614,1616,1618,1620,1622,1624,1626,1628],{"class":474,"line":475},[419,1615,658],{"class":478},[419,1617,661],{"class":493},[419,1619,664],{"class":489},[419,1621,667],{"class":493},[419,1623,670],{"class":478},[419,1625,673],{"class":493},[419,1627,676],{"class":513},[419,1629,679],{"class":493},[419,1631,1632],{"class":474,"line":497},[419,1633,685],{"emptyLinePlaceholder":684},[419,1635,1636,1638,1640,1642,1644,1646,1648,1650,1652,1654,1656],{"class":474,"line":525},[419,1637,479],{"class":478},[419,1639,693],{"class":692},[419,1641,661],{"class":493},[419,1643,698],{"class":489},[419,1645,568],{"class":493},[419,1647,703],{"class":489},[419,1649,644],{"class":493},[419,1651,708],{"class":493},[419,1653,664],{"class":485},[419,1655,490],{"class":489},[419,1657,494],{"class":493},[419,1659,1660,1662,1664,1666,1668,1670],{"class":474,"line":536},[419,1661,719],{"class":500},[419,1663,504],{"class":493},[419,1665,673],{"class":493},[419,1667,726],{"class":513},[419,1669,510],{"class":493},[419,1671,522],{"class":493},[419,1673,1674,1676,1678],{"class":474,"line":546},[419,1675,735],{"class":500},[419,1677,504],{"class":493},[419,1679,533],{"class":493},[419,1681,1682,1684,1686,1688,1690,1692,1694],{"class":474,"line":556},[419,1683,744],{"class":500},[419,1685,504],{"class":493},[419,1687,661],{"class":493},[419,1689,1003],{"class":500},[419,1691,504],{"class":493},[419,1693,565],{"class":564},[419,1695,868],{"class":493},[419,1697,1698,1700,1702,1704,1707,1709,1711,1713,1715,1717],{"class":474,"line":575},[419,1699,1014],{"class":500},[419,1701,504],{"class":493},[419,1703,507],{"class":489},[419,1705,1706],{"class":493},"{",[419,1708,1027],{"class":500},[419,1710,504],{"class":493},[419,1712,1032],{"class":564},[419,1714,667],{"class":493},[419,1716,519],{"class":489},[419,1718,522],{"class":493},[419,1720,1721],{"class":474,"line":591},[419,1722,638],{"class":493},[419,1724,1725,1727,1729,1731,1733],{"class":474,"line":607},[419,1726,1281],{"class":500},[419,1728,490],{"class":493},[419,1730,1526],{"class":1486},[419,1732,1192],{"class":493},[419,1734,533],{"class":493},[419,1736,1737,1739,1741,1743,1745,1747,1749,1751,1753,1755,1757,1759,1761,1763,1765],{"class":474,"line":623},[419,1738,1537],{"class":478},[419,1740,1523],{"class":500},[419,1742,1526],{"class":489},[419,1744,1502],{"class":493},[419,1746,1546],{"class":489},[419,1748,1502],{"class":493},[419,1750,1551],{"class":489},[419,1752,1554],{"class":493},[419,1754,1557],{"class":489},[419,1756,1560],{"class":493},[419,1758,673],{"class":493},[419,1760,1565],{"class":513},[419,1762,510],{"class":493},[419,1764,1570],{"class":500},[419,1766,494],{"class":493},[419,1768,1769,1771,1773,1775,1777],{"class":474,"line":629},[419,1770,1577],{"class":489},[419,1772,1502],{"class":493},[419,1774,1582],{"class":489},[419,1776,708],{"class":493},[419,1778,1588],{"class":1587},[419,1780,1781],{"class":474,"line":635},[419,1782,1593],{"class":493},[419,1784,1785],{"class":474,"line":641},[419,1786,638],{"class":493},[419,1788,1790,1792],{"class":474,"line":1789},14,[419,1791,644],{"class":493},[419,1793,647],{"class":489},[462,1795,1798],{"className":464,"code":1796,"filename":1797,"language":467,"meta":468,"style":468},"import { evlog } from 'evlog\u002Fhono'\n\napp.use(evlog({\n  keep(ctx) {\n    if (ctx.context.user?.plan === 'enterprise') {\n      ctx.shouldKeep = true\n    }\n  },\n}))\n","index.ts (Hono)",[470,1799,1800,1820,1824,1842,1854,1886,1898,1902,1906],{"__ignoreMap":468},[419,1801,1802,1804,1806,1809,1811,1813,1815,1818],{"class":474,"line":475},[419,1803,658],{"class":478},[419,1805,661],{"class":493},[419,1807,1808],{"class":489}," evlog",[419,1810,667],{"class":493},[419,1812,670],{"class":478},[419,1814,673],{"class":493},[419,1816,1817],{"class":513},"evlog\u002Fhono",[419,1819,679],{"class":493},[419,1821,1822],{"class":474,"line":497},[419,1823,685],{"emptyLinePlaceholder":684},[419,1825,1826,1829,1831,1834,1836,1838,1840],{"class":474,"line":525},[419,1827,1828],{"class":489},"app",[419,1830,1502],{"class":493},[419,1832,1833],{"class":485},"use",[419,1835,490],{"class":489},[419,1837,830],{"class":485},[419,1839,490],{"class":489},[419,1841,494],{"class":493},[419,1843,1844,1846,1848,1850,1852],{"class":474,"line":536},[419,1845,1281],{"class":500},[419,1847,490],{"class":493},[419,1849,1526],{"class":1486},[419,1851,1192],{"class":493},[419,1853,533],{"class":493},[419,1855,1856,1858,1860,1862,1864,1866,1868,1870,1872,1874,1876,1878,1880,1882,1884],{"class":474,"line":546},[419,1857,1537],{"class":478},[419,1859,1523],{"class":500},[419,1861,1526],{"class":489},[419,1863,1502],{"class":493},[419,1865,1546],{"class":489},[419,1867,1502],{"class":493},[419,1869,1551],{"class":489},[419,1871,1554],{"class":493},[419,1873,1557],{"class":489},[419,1875,1560],{"class":493},[419,1877,673],{"class":493},[419,1879,1565],{"class":513},[419,1881,510],{"class":493},[419,1883,1570],{"class":500},[419,1885,494],{"class":493},[419,1887,1888,1890,1892,1894,1896],{"class":474,"line":556},[419,1889,1577],{"class":489},[419,1891,1502],{"class":493},[419,1893,1582],{"class":489},[419,1895,708],{"class":493},[419,1897,1588],{"class":1587},[419,1899,1900],{"class":474,"line":575},[419,1901,1593],{"class":493},[419,1903,1904],{"class":474,"line":591},[419,1905,638],{"class":493},[419,1907,1908,1910],{"class":474,"line":607},[419,1909,644],{"class":493},[419,1911,1912],{"class":489},"))\n",[394,1914,1915,1916,1918],{},"The ",[470,1917,1526],{}," object contains:",[1122,1920,1921,1932],{},[1125,1922,1923],{},[1128,1924,1925,1928,1930],{},[1131,1926,1927],{},"Field",[1131,1929,1136],{},[1131,1931,1139],{},[1141,1933,1934,1948,1961,1975,1989,2006],{},[1128,1935,1936,1940,1945],{},[1146,1937,1938],{},[470,1939,1102],{},[1146,1941,1942],{},[470,1943,1944],{},"number | undefined",[1146,1946,1947],{},"HTTP response status",[1128,1949,1950,1954,1958],{},[1146,1951,1952],{},[470,1953,1106],{},[1146,1955,1956],{},[470,1957,1944],{},[1146,1959,1960],{},"Request duration in ms",[1128,1962,1963,1967,1972],{},[1146,1964,1965],{},[470,1966,1110],{},[1146,1968,1969],{},[470,1970,1971],{},"string | undefined",[1146,1973,1974],{},"Request path",[1128,1976,1977,1982,1986],{},[1146,1978,1979],{},[470,1980,1981],{},"method",[1146,1983,1984],{},[470,1985,1971],{},[1146,1987,1988],{},"HTTP method",[1128,1990,1991,1995,2000],{},[1146,1992,1993],{},[470,1994,1546],{},[1146,1996,1997],{},[470,1998,1999],{},"Record\u003Cstring, unknown>",[1146,2001,2002,2003],{},"All fields set via ",[470,2004,2005],{},"log.set()",[1128,2007,2008,2012,2017],{},[1146,2009,2010],{},[470,2011,1582],{},[1146,2013,2014],{},[470,2015,2016],{},"boolean",[1146,2018,2019,2020,2023],{},"Set to ",[470,2021,2022],{},"true"," to force-keep",[446,2025,2027],{"id":2026},"production-example","Production Example",[394,2029,2030],{},"A typical production configuration that balances cost and visibility:",[459,2032,2033,2288,2493],{},[462,2034,2036],{"className":464,"code":2035,"filename":466,"language":467,"meta":468,"style":468},"export default defineNuxtConfig({\n  modules: ['evlog\u002Fnuxt'],\n  evlog: {\n    env: { service: 'my-app' },\n  },\n  $production: {\n    evlog: {\n      sampling: {\n        rates: {\n          info: 10,\n          warn: 50,\n          debug: 0,\n          error: 100,\n        },\n        keep: [\n          { status: 400 },\n          { duration: 1000 },\n          { path: '\u002Fapi\u002Fpayments\u002F**' },\n          { path: '\u002Fapi\u002Fauth\u002F**' },\n        ],\n      },\n    },\n  },\n})\n",[470,2037,2038,2050,2068,2076,2097,2101,2110,2119,2128,2137,2148,2159,2170,2181,2186,2196,2210,2223,2240,2258,2266,2271,2276,2281],{"__ignoreMap":468},[419,2039,2040,2042,2044,2046,2048],{"class":474,"line":475},[419,2041,479],{"class":478},[419,2043,482],{"class":478},[419,2045,486],{"class":485},[419,2047,490],{"class":489},[419,2049,494],{"class":493},[419,2051,2052,2054,2056,2058,2060,2062,2064,2066],{"class":474,"line":497},[419,2053,501],{"class":500},[419,2055,504],{"class":493},[419,2057,507],{"class":489},[419,2059,510],{"class":493},[419,2061,514],{"class":513},[419,2063,510],{"class":493},[419,2065,519],{"class":489},[419,2067,522],{"class":493},[419,2069,2070,2072,2074],{"class":474,"line":525},[419,2071,528],{"class":500},[419,2073,504],{"class":493},[419,2075,533],{"class":493},[419,2077,2078,2081,2083,2085,2087,2089,2091,2093,2095],{"class":474,"line":536},[419,2079,2080],{"class":500},"    env",[419,2082,504],{"class":493},[419,2084,661],{"class":493},[419,2086,857],{"class":500},[419,2088,504],{"class":493},[419,2090,673],{"class":493},[419,2092,726],{"class":513},[419,2094,510],{"class":493},[419,2096,868],{"class":493},[419,2098,2099],{"class":474,"line":546},[419,2100,638],{"class":493},[419,2102,2103,2106,2108],{"class":474,"line":556},[419,2104,2105],{"class":500},"  $production",[419,2107,504],{"class":493},[419,2109,533],{"class":493},[419,2111,2112,2115,2117],{"class":474,"line":575},[419,2113,2114],{"class":500},"    evlog",[419,2116,504],{"class":493},[419,2118,533],{"class":493},[419,2120,2121,2124,2126],{"class":474,"line":591},[419,2122,2123],{"class":500},"      sampling",[419,2125,504],{"class":493},[419,2127,533],{"class":493},[419,2129,2130,2133,2135],{"class":474,"line":607},[419,2131,2132],{"class":500},"        rates",[419,2134,504],{"class":493},[419,2136,533],{"class":493},[419,2138,2139,2142,2144,2146],{"class":474,"line":623},[419,2140,2141],{"class":500},"          info",[419,2143,504],{"class":493},[419,2145,565],{"class":564},[419,2147,522],{"class":493},[419,2149,2150,2153,2155,2157],{"class":474,"line":629},[419,2151,2152],{"class":500},"          warn",[419,2154,504],{"class":493},[419,2156,583],{"class":564},[419,2158,522],{"class":493},[419,2160,2161,2164,2166,2168],{"class":474,"line":635},[419,2162,2163],{"class":500},"          debug",[419,2165,504],{"class":493},[419,2167,599],{"class":564},[419,2169,522],{"class":493},[419,2171,2172,2175,2177,2179],{"class":474,"line":641},[419,2173,2174],{"class":500},"          error",[419,2176,504],{"class":493},[419,2178,615],{"class":564},[419,2180,522],{"class":493},[419,2182,2183],{"class":474,"line":1789},[419,2184,2185],{"class":493},"        },\n",[419,2187,2189,2192,2194],{"class":474,"line":2188},15,[419,2190,2191],{"class":500},"        keep",[419,2193,504],{"class":493},[419,2195,1019],{"class":489},[419,2197,2199,2202,2204,2206,2208],{"class":474,"line":2198},16,[419,2200,2201],{"class":493},"          {",[419,2203,1027],{"class":500},[419,2205,504],{"class":493},[419,2207,1032],{"class":564},[419,2209,868],{"class":493},[419,2211,2213,2215,2217,2219,2221],{"class":474,"line":2212},17,[419,2214,2201],{"class":493},[419,2216,1045],{"class":500},[419,2218,504],{"class":493},[419,2220,1050],{"class":564},[419,2222,868],{"class":493},[419,2224,2226,2228,2230,2232,2234,2236,2238],{"class":474,"line":2225},18,[419,2227,2201],{"class":493},[419,2229,1062],{"class":500},[419,2231,504],{"class":493},[419,2233,673],{"class":493},[419,2235,1069],{"class":513},[419,2237,510],{"class":493},[419,2239,868],{"class":493},[419,2241,2243,2245,2247,2249,2251,2254,2256],{"class":474,"line":2242},19,[419,2244,2201],{"class":493},[419,2246,1062],{"class":500},[419,2248,504],{"class":493},[419,2250,673],{"class":493},[419,2252,2253],{"class":513},"\u002Fapi\u002Fauth\u002F**",[419,2255,510],{"class":493},[419,2257,868],{"class":493},[419,2259,2261,2264],{"class":474,"line":2260},20,[419,2262,2263],{"class":489},"        ]",[419,2265,522],{"class":493},[419,2267,2269],{"class":474,"line":2268},21,[419,2270,626],{"class":493},[419,2272,2274],{"class":474,"line":2273},22,[419,2275,632],{"class":493},[419,2277,2279],{"class":474,"line":2278},23,[419,2280,638],{"class":493},[419,2282,2284,2286],{"class":474,"line":2283},24,[419,2285,644],{"class":493},[419,2287,647],{"class":489},[462,2289,2291],{"className":464,"code":2290,"filename":651,"language":467,"meta":468,"style":468},"import { createEvlog } from 'evlog\u002Fnext'\n\nexport const { withEvlog, useLogger } = createEvlog({\n  service: 'my-app',\n  sampling: {\n    rates: {\n      info: 10,\n      warn: 50,\n      debug: 0,\n      error: 100,\n    },\n    keep: [\n      { status: 400 },\n      { duration: 1000 },\n      { path: '\u002Fapi\u002Fpayments\u002F**' },\n      { path: '\u002Fapi\u002Fauth\u002F**' },\n    ],\n  },\n})\n",[470,2292,2293,2311,2315,2339,2353,2361,2369,2379,2389,2399,2409,2413,2421,2433,2445,2461,2477,2483,2487],{"__ignoreMap":468},[419,2294,2295,2297,2299,2301,2303,2305,2307,2309],{"class":474,"line":475},[419,2296,658],{"class":478},[419,2298,661],{"class":493},[419,2300,664],{"class":489},[419,2302,667],{"class":493},[419,2304,670],{"class":478},[419,2306,673],{"class":493},[419,2308,676],{"class":513},[419,2310,679],{"class":493},[419,2312,2313],{"class":474,"line":497},[419,2314,685],{"emptyLinePlaceholder":684},[419,2316,2317,2319,2321,2323,2325,2327,2329,2331,2333,2335,2337],{"class":474,"line":525},[419,2318,479],{"class":478},[419,2320,693],{"class":692},[419,2322,661],{"class":493},[419,2324,698],{"class":489},[419,2326,568],{"class":493},[419,2328,703],{"class":489},[419,2330,644],{"class":493},[419,2332,708],{"class":493},[419,2334,664],{"class":485},[419,2336,490],{"class":489},[419,2338,494],{"class":493},[419,2340,2341,2343,2345,2347,2349,2351],{"class":474,"line":536},[419,2342,719],{"class":500},[419,2344,504],{"class":493},[419,2346,673],{"class":493},[419,2348,726],{"class":513},[419,2350,510],{"class":493},[419,2352,522],{"class":493},[419,2354,2355,2357,2359],{"class":474,"line":546},[419,2356,735],{"class":500},[419,2358,504],{"class":493},[419,2360,533],{"class":493},[419,2362,2363,2365,2367],{"class":474,"line":556},[419,2364,744],{"class":500},[419,2366,504],{"class":493},[419,2368,533],{"class":493},[419,2370,2371,2373,2375,2377],{"class":474,"line":575},[419,2372,753],{"class":500},[419,2374,504],{"class":493},[419,2376,565],{"class":564},[419,2378,522],{"class":493},[419,2380,2381,2383,2385,2387],{"class":474,"line":591},[419,2382,764],{"class":500},[419,2384,504],{"class":493},[419,2386,583],{"class":564},[419,2388,522],{"class":493},[419,2390,2391,2393,2395,2397],{"class":474,"line":607},[419,2392,775],{"class":500},[419,2394,504],{"class":493},[419,2396,599],{"class":564},[419,2398,522],{"class":493},[419,2400,2401,2403,2405,2407],{"class":474,"line":623},[419,2402,786],{"class":500},[419,2404,504],{"class":493},[419,2406,615],{"class":564},[419,2408,522],{"class":493},[419,2410,2411],{"class":474,"line":629},[419,2412,632],{"class":493},[419,2414,2415,2417,2419],{"class":474,"line":635},[419,2416,1014],{"class":500},[419,2418,504],{"class":493},[419,2420,1019],{"class":489},[419,2422,2423,2425,2427,2429,2431],{"class":474,"line":641},[419,2424,1024],{"class":493},[419,2426,1027],{"class":500},[419,2428,504],{"class":493},[419,2430,1032],{"class":564},[419,2432,868],{"class":493},[419,2434,2435,2437,2439,2441,2443],{"class":474,"line":1789},[419,2436,1024],{"class":493},[419,2438,1045],{"class":500},[419,2440,504],{"class":493},[419,2442,1050],{"class":564},[419,2444,868],{"class":493},[419,2446,2447,2449,2451,2453,2455,2457,2459],{"class":474,"line":2188},[419,2448,1024],{"class":493},[419,2450,1062],{"class":500},[419,2452,504],{"class":493},[419,2454,673],{"class":493},[419,2456,1069],{"class":513},[419,2458,510],{"class":493},[419,2460,868],{"class":493},[419,2462,2463,2465,2467,2469,2471,2473,2475],{"class":474,"line":2198},[419,2464,1024],{"class":493},[419,2466,1062],{"class":500},[419,2468,504],{"class":493},[419,2470,673],{"class":493},[419,2472,2253],{"class":513},[419,2474,510],{"class":493},[419,2476,868],{"class":493},[419,2478,2479,2481],{"class":474,"line":2212},[419,2480,1081],{"class":489},[419,2482,522],{"class":493},[419,2484,2485],{"class":474,"line":2225},[419,2486,638],{"class":493},[419,2488,2489,2491],{"class":474,"line":2242},[419,2490,644],{"class":493},[419,2492,647],{"class":489},[462,2494,2496],{"className":464,"code":2495,"filename":810,"language":467,"meta":468,"style":468},"import { initLogger } from 'evlog'\n\ninitLogger({\n  env: { service: 'my-app' },\n  sampling: {\n    rates: {\n      info: 10,\n      warn: 50,\n      debug: 0,\n      error: 100,\n    },\n    keep: [\n      { status: 400 },\n      { duration: 1000 },\n      { path: '\u002Fapi\u002Fpayments\u002F**' },\n      { path: '\u002Fapi\u002Fauth\u002F**' },\n    ],\n  },\n})\n",[470,2497,2498,2516,2520,2528,2548,2556,2564,2574,2584,2594,2604,2608,2616,2628,2640,2656,2672,2678,2682],{"__ignoreMap":468},[419,2499,2500,2502,2504,2506,2508,2510,2512,2514],{"class":474,"line":475},[419,2501,658],{"class":478},[419,2503,661],{"class":493},[419,2505,821],{"class":489},[419,2507,667],{"class":493},[419,2509,670],{"class":478},[419,2511,673],{"class":493},[419,2513,830],{"class":513},[419,2515,679],{"class":493},[419,2517,2518],{"class":474,"line":497},[419,2519,685],{"emptyLinePlaceholder":684},[419,2521,2522,2524,2526],{"class":474,"line":525},[419,2523,841],{"class":485},[419,2525,490],{"class":489},[419,2527,494],{"class":493},[419,2529,2530,2532,2534,2536,2538,2540,2542,2544,2546],{"class":474,"line":536},[419,2531,850],{"class":500},[419,2533,504],{"class":493},[419,2535,661],{"class":493},[419,2537,857],{"class":500},[419,2539,504],{"class":493},[419,2541,673],{"class":493},[419,2543,726],{"class":513},[419,2545,510],{"class":493},[419,2547,868],{"class":493},[419,2549,2550,2552,2554],{"class":474,"line":546},[419,2551,735],{"class":500},[419,2553,504],{"class":493},[419,2555,533],{"class":493},[419,2557,2558,2560,2562],{"class":474,"line":556},[419,2559,744],{"class":500},[419,2561,504],{"class":493},[419,2563,533],{"class":493},[419,2565,2566,2568,2570,2572],{"class":474,"line":575},[419,2567,753],{"class":500},[419,2569,504],{"class":493},[419,2571,565],{"class":564},[419,2573,522],{"class":493},[419,2575,2576,2578,2580,2582],{"class":474,"line":591},[419,2577,764],{"class":500},[419,2579,504],{"class":493},[419,2581,583],{"class":564},[419,2583,522],{"class":493},[419,2585,2586,2588,2590,2592],{"class":474,"line":607},[419,2587,775],{"class":500},[419,2589,504],{"class":493},[419,2591,599],{"class":564},[419,2593,522],{"class":493},[419,2595,2596,2598,2600,2602],{"class":474,"line":623},[419,2597,786],{"class":500},[419,2599,504],{"class":493},[419,2601,615],{"class":564},[419,2603,522],{"class":493},[419,2605,2606],{"class":474,"line":629},[419,2607,632],{"class":493},[419,2609,2610,2612,2614],{"class":474,"line":635},[419,2611,1014],{"class":500},[419,2613,504],{"class":493},[419,2615,1019],{"class":489},[419,2617,2618,2620,2622,2624,2626],{"class":474,"line":641},[419,2619,1024],{"class":493},[419,2621,1027],{"class":500},[419,2623,504],{"class":493},[419,2625,1032],{"class":564},[419,2627,868],{"class":493},[419,2629,2630,2632,2634,2636,2638],{"class":474,"line":1789},[419,2631,1024],{"class":493},[419,2633,1045],{"class":500},[419,2635,504],{"class":493},[419,2637,1050],{"class":564},[419,2639,868],{"class":493},[419,2641,2642,2644,2646,2648,2650,2652,2654],{"class":474,"line":2188},[419,2643,1024],{"class":493},[419,2645,1062],{"class":500},[419,2647,504],{"class":493},[419,2649,673],{"class":493},[419,2651,1069],{"class":513},[419,2653,510],{"class":493},[419,2655,868],{"class":493},[419,2657,2658,2660,2662,2664,2666,2668,2670],{"class":474,"line":2198},[419,2659,1024],{"class":493},[419,2661,1062],{"class":500},[419,2663,504],{"class":493},[419,2665,673],{"class":493},[419,2667,2253],{"class":513},[419,2669,510],{"class":493},[419,2671,868],{"class":493},[419,2673,2674,2676],{"class":474,"line":2212},[419,2675,1081],{"class":489},[419,2677,522],{"class":493},[419,2679,2680],{"class":474,"line":2225},[419,2681,638],{"class":493},[419,2683,2684,2686],{"class":474,"line":2242},[419,2685,644],{"class":493},[419,2687,647],{"class":489},[947,2689,2692,2693,2696],{"color":2690,"icon":2691},"warning","i-lucide-lightbulb","In Nuxt, use the ",[470,2694,2695],{},"$production"," override to keep full logging in development while sampling in production. In other frameworks, use your own environment check or config system.",[446,2698,2700],{"id":2699},"next-steps","Next Steps",[406,2702,2703,2708],{},[409,2704,2705,2707],{},[435,2706,181],{"href":182}," - Security and production checklist",[409,2709,2710,2712],{},[435,2711,51],{"href":52}," - Design effective wide events",[2714,2715,2716],"style",{},"html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}",{"title":468,"searchDepth":497,"depth":497,"links":2718},[2719,2720,2723,2724,2725,2726],{"id":448,"depth":497,"text":449},{"id":957,"depth":497,"text":958,"children":2721},[2722],{"id":1119,"depth":525,"text":1120},{"id":1195,"depth":497,"text":1196},{"id":1451,"depth":497,"text":1452},{"id":2026,"depth":497,"text":2027},{"id":2699,"depth":497,"text":2700},"Control log volume with two-tier sampling. Head sampling drops noise by level, tail sampling rescues critical events based on outcome. Never miss errors, slow requests, or critical paths.","md",[2730,2733],{"label":181,"icon":124,"to":182,"color":2731,"variant":2732},"neutral","subtle",{"label":51,"icon":54,"to":52,"color":2731,"variant":2732},{},{"icon":174},{"title":171,"description":2727},"CdwETfiRtk1X6T1fmGN22FJpcAsaU-h6ubTzmP_vLtQ",[2739,2741],{"title":166,"path":167,"stem":168,"description":2740,"icon":169,"children":-1},"Complete reference for all evlog configuration options including global logger settings, middleware options, environment context, and framework-specific overrides.",{"title":176,"path":177,"stem":178,"description":2742,"icon":179,"children":-1},"Add compile-time type safety to your wide events with TypeScript module augmentation. Prevent typos and ensure consistent field names across your codebase.",1777907754625]