Skip to content

Conversation

@brophdawg11
Copy link
Contributor

@brophdawg11 brophdawg11 commented Oct 2, 2025

Initial implementation of the unstable_instrumentations API to provide a first-class way to instrument applications for logging, perf tracing, OTEL, etc.

Here's an example of a simple logging instrumentation on the server and the client:

Server

// entry.server.tsx

export const unstable_instrumentations = [loggingInstrumentations];

const serverLoggingInstrumentations = {
  handler({ instrument }) {
    instrument({
      async request(callHandler, info) {
        let path = new URL(info.request.url).pathname;
        await log(`request ${path}`, callHandler);
      },
    });
  },
  route({ instrument, id }) {
    instrument({
      middleware: (callMiddleware) => log(` middleware (${id})`, callMiddleware),
      loader: (callLoader) => log(`  loader (${id})`, callLoader),
      action: (callAction) => log(`  action (${id})`, callAction),
    });
  },
};

async function log(label: string, cb: () => Promise<void>) {
  let start = Date.now();
  console.log(`➡️ ${label}`);
  try {
    await cb();
  } finally {
    console.log(`⬅️ ${label} (${Date.now() - start}ms)`);
  }
}
Screenshot 2025-10-02 at 11 09 23 AM

Client

// entry.client.ts

<HydratedRouter unstable_instrumentations={[clientLoggingInstrumentations]} />

const clientLoggingInstrumentations = {
  router({ instrument }) {
    instrument({
      async navigate(callNavigate, info) { /*...*/ },
      async fetch(callNavigate, info) { /*...*/ },
    });
  },
  route({ instrument, id }) {
    instrument({
      middleware(callMiddleware, info) { /* ... */ },
      loader(callLoader, info) { /* ... */ },
      action(callAction, info) { /* ... */ },
    });
  },
};
Screenshot 2025-10-02 at 11 10 04 AM

TODO:

  • Docs

Playground App
RFC: #13749
Closes: #14376

@changeset-bot
Copy link

changeset-bot bot commented Oct 2, 2025

🦋 Changeset detected

Latest commit: 39524e0

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 11 packages
Name Type
react-router Patch
@react-router/architect Patch
@react-router/cloudflare Patch
@react-router/dev Patch
react-router-dom Patch
@react-router/express Patch
@react-router/node Patch
@react-router/serve Patch
@react-router/fs-routes Patch
@react-router/remix-routes-option-adapter Patch
create-react-router Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@brophdawg11 brophdawg11 added pkg:react-router alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR labels Oct 2, 2025
@github-actions github-actions bot removed the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 2, 2025
@brophdawg11 brophdawg11 added the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 2, 2025
@remix-run remix-run deleted a comment from github-actions bot Oct 2, 2025
@github-actions github-actions bot removed the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 2, 2025
@brophdawg11 brophdawg11 added the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 2, 2025
@brophdawg11 brophdawg11 added the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 2, 2025
@github-actions
Copy link
Contributor

github-actions bot commented Oct 2, 2025

Alpha release created: 0.0.0-experimental-e0b6ce9

⚠️ Note: This release was created from the HEAD of this branch so it may contain commits that have landed in dev but have not been released yet depending on when this branch was created. You can run the following command to see the commits that may not have been released yet:

git log --pretty=oneline [email protected]

@github-actions github-actions bot removed the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 2, 2025
@rossipedia
Copy link
Contributor

Really loving this API direction 🥳

@rossipedia
Copy link
Contributor

The test failures here all seem related to JSON serialization order? ie: the objects being compared should be equivalent, but because their keys are out of order the serialized strings aren't matching.

@brophdawg11 brophdawg11 marked this pull request as ready for review October 21, 2025 15:56
@brophdawg11 brophdawg11 added the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 22, 2025
@github-actions
Copy link
Contributor

Alpha release created: 0.0.0-experimental-66357d4

⚠️ Note: This release was created from the HEAD of this branch so it may contain commits that have landed in dev but have not been released yet depending on when this branch was created. You can run the following command to see the commits that may not have been released yet:

git log --pretty=oneline [email protected]

@github-actions github-actions bot removed the alpha-release Used by maintainers to trigger a Stage 2 (alpha) release on a PR label Oct 22, 2025
@brophdawg11 brophdawg11 merged commit adadca5 into dev Oct 22, 2025
8 checks passed
@brophdawg11 brophdawg11 deleted the brophdawg11/instrument branch October 22, 2025 16:43
@github-actions
Copy link
Contributor

🤖 Hello there,

We just published version 7.9.5-pre.0 which includes this pull request. If you'd like to take it for a test run please try it out and let us know what you think!

Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants