This SDK is in Beta. The API is stable but updates may include minor changes in behavior. Please reach out on GitHub if you have any feedback or concerns. This SDK is for Nuxt. If you're using Vue see our Vue SDK here.
The minimum supported version of Nuxt is 3.0.0
.
This package is a wrapper around @sentry/node
for the server and @sentry/vue
for the client side, with added
functionality related to Nuxt.
Limitations:
- Server monitoring is not available during development mode (
nuxt dev
)
-
Install the Sentry Nuxt SDK:
# Using npm npm install @sentry/nuxt # Using yarn yarn add @sentry/nuxt
The Sentry Nuxt SDK is based on Nuxt Modules.
- Add
@sentry/nuxt/module
to the modules section ofnuxt.config.ts
:
// nuxt.config.ts
export default defineNuxtConfig({
modules: ['@sentry/nuxt/module'],
});
Add a sentry.client.config.ts
file to the root of your project:
import { useRuntimeConfig } from '#imports';
import * as Sentry from '@sentry/nuxt';
Sentry.init({
// If set up, you can use your runtime config here
dsn: useRuntimeConfig().public.sentry.dsn,
});
Add a sentry.server.config.ts
file to the root of your project:
import * as Sentry from '@sentry/nuxt';
// Only run `init` when process.env.SENTRY_DSN is available.
if (process.env.SENTRY_DSN) {
Sentry.init({
dsn: 'your-dsn',
});
}
Using useRuntimeConfig
does not work in the Sentry server config file due to technical reasons (the file has to be
loaded before Nuxt is loaded). To be able to use process.env
you either have to add --env-file=.env
to your node
command
node --env-file=.env .output/server/index.mjs
or use the dotenv
package:
import dotenv from 'dotenv';
import * as Sentry from '@sentry/nuxt';
dotenv.config();
Sentry.init({
dsn: process.env.SENTRY_DSN,
});
To upload source maps, you have to enable client source maps in your nuxt.config.ts
. Then, you add your project
settings to the sentry.sourceMapsUploadOptions
of your nuxt.config.ts
:
// nuxt.config.ts
export default defineNuxtConfig({
sourcemap: { client: true },
modules: ['@sentry/nuxt/module'],
sentry: {
sourceMapsUploadOptions: {
org: 'your-org-slug',
project: 'your-project-slug',
authToken: process.env.SENTRY_AUTH_TOKEN,
},
},
});
When adding sentry.server.config.ts
, you might get an error like this:
"Failed to register ESM hook import-in-the-middle/hook.mjs
". You can add an override (npm/pnpm) or a resolution (yarn)
for @vercel/nft
to fix this. This will add the hook.mjs
file to your build output
(Nitro issue here).
For npm
:
"overrides": {
"@vercel/nft": "^0.27.4"
}
for yarn
:
"resolutions": {
"@vercel/nft": "^0.27.4"
}
or for pnpm
:
"pnpm": {
"overrides": {
"@vercel/nft": "^0.27.4"
}
}