Next.js環境インストール
Next.jsなどのサーバーサイドレンダリング(Server-side Rendering、SSR)フレームワークでアプリケーションをモニタリングするためにCustom Serverの設定が必要です。 一般的なNode.jsフレームワーク(例、Express.js、Nest.js)とは異なるアプローチが求められます。
エージェント インストール
次のコマンドを実行してエージェントをインストールしてください。
npm install whatap
エージェントファイル構成
エージェントのファイル構成については、以下を参照してください。
- package.jsonサンプルアプリケーション情報と依存関係(dependency)の管理文書ファイルです。
- whatap.confモニタリングのためのエージェントの情報とアクセスキー、WhaTapデータ収集サーバーのIP情報などを保存する設定ファイルです。
- security.conf (or paramkey.txt)SQL変数、HTTPクエリの照会、Thread中止機能を利用する時に入力するセキュリティキーを保存します。
- server.js例のファイル名です。 Next.jsアプリインスタンス用のサーバー設定ファイルです。
server.jsコードを作成する
Next.jsアプリケーションインスタンスのためのserver.jsファイルを作成してください。 このファイルは、プロジェクトのルート(Root) 経路に位置する必要があります。
WhaTapエージェントの初期化
var WhatapAgent = require('whatap').NodeAgent;
Next.js及びその他の必要モジュールの読み込み
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
Next.jsアプリケーションのインスタンス作成
次のコードでdev
は開発モードの起動有無を示し、hostname
と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}`)
})
})
全体コードを見る
完成した完全なコードを参照してください。
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}`)
})
})
アプリケーションを実行する
次のコマンドを使用してアプリケーションを実行します。
node server.js
次の段階
-
インストールの点検
プロジェクトの生成とエージェントのインストールまですべて適用した場合は、次の文書で点検事項を確認します。
-
エージェント設定
エージェント設定(whatap.conf)ファイルにオプションを適用して、モニタリングのための様々な機能を提供します。 デフォルト設定から、サーバーの接続とデータ転送の設定、複数のアプリケーションサーバーの設定ファイルの管理方法、トランザクションの追跡などが含まれます。 詳細については、次の文書を参照してください。
-
モニタリングの開始
すべての設定を完了してから、アプリケーションサーバーを再起動します。 エージェントが情報の収集を開始します。 まず、アプリケーションメニューでモニタリングデータが収集されていることを確認します。 アプリケーションについての詳細は、次の文書を参照してください。