Installation of the Next.js environment
Server-side rendering (SSR) frameworks such as Next.js require the Custom Server settings for application monitoring. They require an approach different from typical Node.js frameworks (e.g. Express.js, Nest.js).
Reference: Next.js Custom Server Configuration
Installing the agent
Execute the following command to install the agent.
npm install whatap
Agent file structure
For the agent file configuration, see the following.
- package.jsonDocument file for sample applications and dependency management.
- whatap.confThis configuration file stores monitoring agent settings, access key, and WhaTap data collection server IP.
- security.conf (or paramkey.txt)It stores the security key that is entered for viewing SQL variables and HTTP queries, or using the Thread stop function.
- server.jsExample file names. Server configuration file for Next.js app instances.
Creating the server.js code
Create the server.js file for Next.js application instances. This file must be located in the root path of the project.
Initializing the WhaTap agent
var WhatapAgent = require('whatap').NodeAgent;
Loading Next.js and other required modules
const {createServer} = require('http')
const {parse} = require('url')
const next = require('next')
Configuring the application
const dev = process.env.NODE_ENV !== 'production'
const hostname = 'localhost'
const port = 3000
Creating an instance of the Next.js application
In the following code, dev
indicates whether it is in development mode. Set the host name and port number in hostname
and port
.
const app = next({dev, hostname, port})
const handle = app.getRequestHandler()
app.prepare().then(() => {
createServer(async (req, res) => {
try {
const parsedUrl = parse(req.url, true)
const {pathname, query} = parsedUrl
/**
* Render the page.
*/
await handle(req, res, parsedUrl);
} catch (err) {
console.error('Error occurred handling', req.url, err)
res.statusCode = 500
res.end('internal server error')
}
})
.once('error', (err) => {
console.error(err)
process.exit(1)
})
.listen(port, () => {
console.log(`> Ready on http://${hostname}:${port}`)
})
})
Viewing the full code
See the completed full code.
var WhatapAgent = require('whatap').NodeAgent;
const {createServer} = require('http')
const {parse} = require('url')
const next = require('next')
const dev = process.env.NODE_ENV !== 'production'
const hostname = 'localhost'
const port = 3000
const app = next({dev, hostname, port})
const handle = app.getRequestHandler()
app.prepare().then(() => {
createServer(async (req, res) => {
try {
const parsedUrl = parse(req.url, true)
const {pathname, query} = parsedUrl
/**
* Render the page.
*/
await handle(req, res, parsedUrl);
} catch (err) {
console.error('Error occurred handling', req.url, err)
res.statusCode = 500
res.end('internal server error')
}
})
.once('error', (err) => {
console.error(err)
process.exit(1)
})
.listen(port, () => {
console.log(`> Ready on http://${hostname}:${port}`)
})
})
Running the application
Use the following command to run the application.
node server.js
Next steps
-
Checking the installation
If you have applied all for project creation and agent installation, check the checklist in [the following] (install-check).
-
Agent setting
It provides various features for monitoring by applying some options to the agent configuration file (whatap.conf). It includes basic configuration, configuration for server connection and data transfer, how to manage the configuration files for multiple application servers, and transaction tracing, and more. For more information, see the following.
-
Starting the monitoring
After all settings are made, restart the application server. The agent starts collecting data. First, check whether the monitoring data has been collected in Application Dashboard. For more information about Application Dashboard, see the following.