-
Notifications
You must be signed in to change notification settings - Fork 54
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Spans not exported for requests without IO operations in Cloudflare Workers #179
Comments
Doing this very ugly patch seems to do the trick const app = {
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
const startTime = performance.now();
// Rest of code (Calling or not IOs)
const endTime = performance.now();
// This means that there hasn't been any IO, so we need to make a dummy call
if (endTime - startTime === 0) {
ctx.waitUntil(
Promise.resolve().then(async () => {
await incrementTime(env, 10);
}),
);
}
}
};
async function incrementTime(env: Env, delay: number): Promise<void> {
const startTime = performance.now();
const id = crypto.randomUUID();
const maxTries = 50;
let tries = 0;
while (performance.now() - startTime < delay && tries < maxTries) {
tries++;
try {
await env.CACHE.put(`dummy-call-to-trigger-spans ${id}`, 'dummy-value');
await env.CACHE.delete(`dummy-call-to-trigger-spans ${id}`);
} catch {
// noop
}
}
} |
That is a very ugly trick.. And absolutely a bug. |
Hey @gbmarc1, Apologies for the delay, but I just wanted to let you know that this is fixed in the core-logic-refactor branch.. (https://github.com/evanderkoogh/otel-cf-workers/tree/core-logic-refactor). Please do not try this as everything but HTTP is broken in there, but here is what it looks like in Honeycomb.. |
Description
When using the otel-cf-workers library to instrument a Cloudflare Worker, spans are not being exported for requests that don't involve any IO operations outside of the worker.
Context
My worker is instrumented using this library. It works like a dream when we have IOs outside of the worker in the request. However, when there is no IO, the spans are not exported.
I did add a dummy KV cache GET/PUT to test that theory and it works (most of the time).
I noticed that when I could not see spans with 401s. A 401 does not make any call outside of the worker; but, successful requests which involve a network call had spans associated to them.
I may be wrong on the cause of this.
Current Behavior
Expected Behavior
Spans should be exported consistently for all requests, regardless of whether they involve IO operations or not.
Possible Cause ( I may strongly be wrong about this)
The issue may be related to how the worker's clock is updated (See details here). The
scheduler.wait
function in the library might be waiting indefinitely when there's no IO operation, as the clock is not being updated.The text was updated successfully, but these errors were encountered: