Skip to content

診断レポート

[安定版: 2 - 安定版]

安定版: 2 安定性: 2 - 安定版

[履歴]

バージョン変更内容
v23.3.0レポート生成から環境変数を除外するための--report-exclude-envオプションを追加しました。
v22.0.0, v20.13.0レポート生成を遅くする可能性のあるネットワーク操作を除外するための--report-exclude-networkオプションを追加しました。

ファイルに書き込まれる JSON 形式の診断サマリーを提供します。

このレポートは、問題の特定のために情報を取得して保存するために、開発、テスト、および運用での使用を目的としています。JavaScript とネイティブのスタックトレース、ヒープ統計、プラットフォーム情報、リソース使用量などを含みます。レポートオプションを有効にすると、プログラムによる API 呼び出しによるトリガーに加えて、未処理の例外、致命的なエラー、ユーザーシグナルで診断レポートをトリガーできます。

キャッチされない例外で生成された完全な例レポートを以下に参照として示します。

json
{
  "header": {
    "reportVersion": 5,
    "event": "exception",
    "trigger": "Exception",
    "filename": "report.20181221.005011.8974.0.001.json",
    "dumpEventTime": "2018-12-21T00:50:11Z",
    "dumpEventTimeStamp": "1545371411331",
    "processId": 8974,
    "cwd": "/home/nodeuser/project/node",
    "commandLine": [
      "/home/nodeuser/project/node/out/Release/node",
      "--report-uncaught-exception",
      "/home/nodeuser/project/node/test/report/test-exception.js",
      "child"
    ],
    "nodejsVersion": "v12.0.0-pre",
    "glibcVersionRuntime": "2.17",
    "glibcVersionCompiler": "2.17",
    "wordSize": "64 bit",
    "arch": "x64",
    "platform": "linux",
    "componentVersions": {
      "node": "12.0.0-pre",
      "v8": "7.1.302.28-node.5",
      "uv": "1.24.1",
      "zlib": "1.2.11",
      "ares": "1.15.0",
      "modules": "68",
      "nghttp2": "1.34.0",
      "napi": "3",
      "llhttp": "1.0.1",
      "openssl": "1.1.0j"
    },
    "release": {
      "name": "node"
    },
    "osName": "Linux",
    "osRelease": "3.10.0-862.el7.x86_64",
    "osVersion": "#1 SMP Wed Mar 21 18:14:51 EDT 2018",
    "osMachine": "x86_64",
    "cpus": [
      {
        "model": "Intel(R) Core(TM) i7-6820HQ CPU @ 2.70GHz",
        "speed": 2700,
        "user": 88902660,
        "nice": 0,
        "sys": 50902570,
        "idle": 241732220,
        "irq": 0
      },
      {
        "model": "Intel(R) Core(TM) i7-6820HQ CPU @ 2.70GHz",
        "speed": 2700,
        "user": 88902660,
        "nice": 0,
        "sys": 50902570,
        "idle": 241732220,
        "irq": 0
      }
    ],
    "networkInterfaces": [
      {
        "name": "en0",
        "internal": false,
        "mac": "13:10:de:ad:be:ef",
        "address": "10.0.0.37",
        "netmask": "255.255.255.0",
        "family": "IPv4"
      }
    ],
    "host": "test_machine"
  },
  "javascriptStack": {
    "message": "Error: *** test-exception.js: throwing uncaught Error",
    "stack": [
      "at myException (/home/nodeuser/project/node/test/report/test-exception.js:9:11)",
      "at Object.<anonymous> (/home/nodeuser/project/node/test/report/test-exception.js:12:3)",
      "at Module._compile (internal/modules/cjs/loader.js:718:30)",
      "at Object.Module._extensions..js (internal/modules/cjs/loader.js:729:10)",
      "at Module.load (internal/modules/cjs/loader.js:617:32)",
      "at tryModuleLoad (internal/modules/cjs/loader.js:560:12)",
      "at Function.Module._load (internal/modules/cjs/loader.js:552:3)",
      "at Function.Module.runMain (internal/modules/cjs/loader.js:771:12)",
      "at executeUserCode (internal/bootstrap/node.js:332:15)"
    ]
  },
  "nativeStack": [
    {
      "pc": "0x000055b57f07a9ef",
      "symbol": "report::GetNodeReport(v8::Isolate*, node::Environment*, char const*, char const*, v8::Local<v8::String>, std::ostream&) [./node]"
    },
    {
      "pc": "0x000055b57f07cf03",
      "symbol": "report::GetReport(v8::FunctionCallbackInfo<v8::Value> const&) [./node]"
    },
    {
      "pc": "0x000055b57f1bccfd",
      "symbol": " [./node]"
    },
    {
      "pc": "0x000055b57f1be048",
      "symbol": "v8::internal::Builtin_HandleApiCall(int, v8::internal::Object**, v8::internal::Isolate*) [./node]"
    },
    {
      "pc": "0x000055b57feeda0e",
      "symbol": " [./node]"
    }
  ],
  "javascriptHeap": {
    "totalMemory": 5660672,
    "executableMemory": 524288,
    "totalCommittedMemory": 5488640,
    "availableMemory": 4341379928,
    "totalGlobalHandlesMemory": 8192,
    "usedGlobalHandlesMemory": 3136,
    "usedMemory": 4816432,
    "memoryLimit": 4345298944,
    "mallocedMemory": 254128,
    "externalMemory": 315644,
    "peakMallocedMemory": 98752,
    "nativeContextCount": 1,
    "detachedContextCount": 0,
    "doesZapGarbage": 0,
    "heapSpaces": {
      "read_only_space": {
        "memorySize": 524288,
        "committedMemory": 39208,
        "capacity": 515584,
        "used": 30504,
        "available": 485080
      },
      "new_space": {
        "memorySize": 2097152,
        "committedMemory": 2019312,
        "capacity": 1031168,
        "used": 985496,
        "available": 45672
      },
      "old_space": {
        "memorySize": 2273280,
        "committedMemory": 1769008,
        "capacity": 1974640,
        "used": 1725488,
        "available": 249152
      },
      "code_space": {
        "memorySize": 696320,
        "committedMemory": 184896,
        "capacity": 152128,
        "used": 152128,
        "available": 0
      },
      "map_space": {
        "memorySize": 536576,
        "committedMemory": 344928,
        "capacity": 327520,
        "used": 327520,
        "available": 0
      },
      "large_object_space": {
        "memorySize": 0,
        "committedMemory": 0,
        "capacity": 1520590336,
        "used": 0,
        "available": 1520590336
      },
      "new_large_object_space": {
        "memorySize": 0,
        "committedMemory": 0,
        "capacity": 0,
        "used": 0,
        "available": 0
      }
    }
  },
  "resourceUsage": {
    "rss": "35766272",
    "free_memory": "1598337024",
    "total_memory": "17179869184",
    "available_memory": "1598337024",
    "maxRss": "36624662528",
    "constrained_memory": "36624662528",
    "userCpuSeconds": 0.040072,
    "kernelCpuSeconds": 0.016029,
    "cpuConsumptionPercent": 5.6101,
    "userCpuConsumptionPercent": 4.0072,
    "kernelCpuConsumptionPercent": 1.6029,
    "pageFaults": {
      "IORequired": 0,
      "IONotRequired": 4610
    },
    "fsActivity": {
      "reads": 0,
      "writes": 0
    }
  },
  "uvthreadResourceUsage": {
    "userCpuSeconds": 0.039843,
    "kernelCpuSeconds": 0.015937,
    "cpuConsumptionPercent": 5.578,
    "userCpuConsumptionPercent": 3.9843,
    "kernelCpuConsumptionPercent": 1.5937,
    "fsActivity": {
      "reads": 0,
      "writes": 0
    }
  },
  "libuv": [
    {
      "type": "async",
      "is_active": true,
      "is_referenced": false,
      "address": "0x0000000102910900",
      "details": ""
    },
    {
      "type": "timer",
      "is_active": false,
      "is_referenced": false,
      "address": "0x00007fff5fbfeab0",
      "repeat": 0,
      "firesInMsFromNow": 94403548320796,
      "expired": true
    },
    {
      "type": "check",
      "is_active": true,
      "is_referenced": false,
      "address": "0x00007fff5fbfeb48"
    },
    {
      "type": "idle",
      "is_active": false,
      "is_referenced": true,
      "address": "0x00007fff5fbfebc0"
    },
    {
      "type": "prepare",
      "is_active": false,
      "is_referenced": false,
      "address": "0x00007fff5fbfec38"
    },
    {
      "type": "check",
      "is_active": false,
      "is_referenced": false,
      "address": "0x00007fff5fbfecb0"
    },
    {
      "type": "async",
      "is_active": true,
      "is_referenced": false,
      "address": "0x000000010188f2e0"
    },
    {
      "type": "tty",
      "is_active": false,
      "is_referenced": true,
      "address": "0x000055b581db0e18",
      "width": 204,
      "height": 55,
      "fd": 17,
      "writeQueueSize": 0,
      "readable": true,
      "writable": true
    },
    {
      "type": "signal",
      "is_active": true,
      "is_referenced": false,
      "address": "0x000055b581d80010",
      "signum": 28,
      "signal": "SIGWINCH"
    },
    {
      "type": "tty",
      "is_active": true,
      "is_referenced": true,
      "address": "0x000055b581df59f8",
      "width": 204,
      "height": 55,
      "fd": 19,
      "writeQueueSize": 0,
      "readable": true,
      "writable": true
    },
    {
      "type": "loop",
      "is_active": true,
      "address": "0x000055fc7b2cb180",
      "loopIdleTimeSeconds": 22644.8
    },
    {
      "type": "tcp",
      "is_active": true,
      "is_referenced": true,
      "address": "0x000055e70fcb85d8",
      "localEndpoint": {
        "host": "localhost",
        "ip4": "127.0.0.1",
        "port": 48986
      },
      "remoteEndpoint": {
        "host": "localhost",
        "ip4": "127.0.0.1",
        "port": 38573
      },
      "sendBufferSize": 2626560,
      "recvBufferSize": 131072,
      "fd": 24,
      "writeQueueSize": 0,
      "readable": true,
      "writable": true
    }
  ],
  "workers": [],
  "environmentVariables": {
    "REMOTEHOST": "REMOVED",
    "MANPATH": "/opt/rh/devtoolset-3/root/usr/share/man:",
    "XDG_SESSION_ID": "66126",
    "HOSTNAME": "test_machine",
    "HOST": "test_machine",
    "TERM": "xterm-256color",
    "SHELL": "/bin/csh",
    "SSH_CLIENT": "REMOVED",
    "PERL5LIB": "/opt/rh/devtoolset-3/root//usr/lib64/perl5/vendor_perl:/opt/rh/devtoolset-3/root/usr/lib/perl5:/opt/rh/devtoolset-3/root//usr/share/perl5/vendor_perl",
    "OLDPWD": "/home/nodeuser/project/node/src",
    "JAVACONFDIRS": "/opt/rh/devtoolset-3/root/etc/java:/etc/java",
    "SSH_TTY": "/dev/pts/0",
    "PCP_DIR": "/opt/rh/devtoolset-3/root",
    "GROUP": "normaluser",
    "USER": "nodeuser",
    "LD_LIBRARY_PATH": "/opt/rh/devtoolset-3/root/usr/lib64:/opt/rh/devtoolset-3/root/usr/lib",
    "HOSTTYPE": "x86_64-linux",
    "XDG_CONFIG_DIRS": "/opt/rh/devtoolset-3/root/etc/xdg:/etc/xdg",
    "MAIL": "/var/spool/mail/nodeuser",
    "PATH": "/home/nodeuser/project/node:/opt/rh/devtoolset-3/root/usr/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin",
    "PWD": "/home/nodeuser/project/node",
    "LANG": "en_US.UTF-8",
    "PS1": "\\u@\\h : \\[\\e[31m\\]\\w\\[\\e[m\\] >  ",
    "SHLVL": "2",
    "HOME": "/home/nodeuser",
    "OSTYPE": "linux",
    "VENDOR": "unknown",
    "PYTHONPATH": "/opt/rh/devtoolset-3/root/usr/lib64/python2.7/site-packages:/opt/rh/devtoolset-3/root/usr/lib/python2.7/site-packages",
    "MACHTYPE": "x86_64",
    "LOGNAME": "nodeuser",
    "XDG_DATA_DIRS": "/opt/rh/devtoolset-3/root/usr/share:/usr/local/share:/usr/share",
    "LESSOPEN": "||/usr/bin/lesspipe.sh %s",
    "INFOPATH": "/opt/rh/devtoolset-3/root/usr/share/info",
    "XDG_RUNTIME_DIR": "/run/user/50141",
    "_": "./node"
  },
  "userLimits": {
    "core_file_size_blocks": {
      "soft": "",
      "hard": "unlimited"
    },
    "data_seg_size_bytes": {
      "soft": "unlimited",
      "hard": "unlimited"
    },
    "file_size_blocks": {
      "soft": "unlimited",
      "hard": "unlimited"
    },
    "max_locked_memory_bytes": {
      "soft": "unlimited",
      "hard": 65536
    },
    "max_memory_size_bytes": {
      "soft": "unlimited",
      "hard": "unlimited"
    },
    "open_files": {
      "soft": "unlimited",
      "hard": 4096
    },
    "stack_size_bytes": {
      "soft": "unlimited",
      "hard": "unlimited"
    },
    "cpu_time_seconds": {
      "soft": "unlimited",
      "hard": "unlimited"
    },
    "max_user_processes": {
      "soft": "unlimited",
      "hard": 4127290
    },
    "virtual_memory_bytes": {
      "soft": "unlimited",
      "hard": "unlimited"
    }
  },
  "sharedObjects": [
    "/lib64/libdl.so.2",
    "/lib64/librt.so.1",
    "/lib64/libstdc++.so.6",
    "/lib64/libm.so.6",
    "/lib64/libgcc_s.so.1",
    "/lib64/libpthread.so.0",
    "/lib64/libc.so.6",
    "/lib64/ld-linux-x86-64.so.2"
  ]
}

使用方法

bash
node --report-uncaught-exception --report-on-signal \
--report-on-fatalerror app.js
  • --report-uncaught-exception アンキャッチされた例外発生時にレポートが生成されるようにします。ネイティブスタックやその他のランタイム環境データと合わせて JavaScript スタックを検査する際に便利です。
  • --report-on-signal 実行中の Node.js プロセスに指定された(または事前に定義された)シグナルを受信したときにレポートが生成されるようにします。(レポートをトリガーするシグナルの変更方法については以下を参照)。デフォルトのシグナルはSIGUSR2です。別のプログラムからレポートをトリガーする必要がある場合に便利です。アプリケーションモニターはこの機能を利用して、定期的にレポートを収集し、豊富な内部ランタイムデータをビューにプロットすることができます。

シグナルベースのレポート生成は Windows ではサポートされていません。

通常は、レポートをトリガーするシグナルを変更する必要はありません。ただし、SIGUSR2が既に他の目的で使用されている場合は、このフラグを使用してレポート生成のシグナルを変更し、前述の目的のためにSIGUSR2の元の意味を維持することができます。

  • --report-on-fatalerror 致命的エラー(メモリ不足など、Node.js ランタイム内部のエラー)が発生してアプリケーションが終了した場合にレポートがトリガーされるようにします。ヒープ、スタック、イベントループの状態、リソース消費量など、さまざまな診断データ要素を検査して、致命的なエラーの原因を調査するのに役立ちます。
  • --report-compact レポートをコンパクトな形式(1 行の JSON)で書き込みます。これは、人間が読むことを目的としたデフォルトの複数行形式よりも、ログ処理システムで処理しやすいです。
  • --report-directory レポートが生成される場所。
  • --report-filename レポートが書き込まれるファイル名。
  • --report-signal レポート生成のシグナルを設定またはリセットします(Windows ではサポートされていません)。デフォルトのシグナルはSIGUSR2です。
  • --report-exclude-network 診断レポートからheader.networkInterfacesを除外して、libuv.*.(remote|local)Endpoint.hostの逆引き DNS クエリを無効にします。デフォルトでは設定されておらず、ネットワークインターフェースが含まれています。
  • --report-exclude-env 診断レポートからenvironmentVariablesを除外します。デフォルトでは設定されておらず、環境変数が含まれています。

レポートは、JavaScript アプリケーションからの API 呼び出しによってもトリガーできます。

js
process.report.writeReport()

この関数は、レポートが書き込まれるファイル名であるオプションの追加引数filenameを取ります。

js
process.report.writeReport('./foo.json')

この関数は、レポートに表示される JavaScript スタックのコンテキストとして使用されるErrorオブジェクトであるオプションの追加引数errを取ります。コールバックまたは例外ハンドラーでエラーを処理するためにレポートを使用する場合、これにより、レポートに元のエラーの位置と、そのエラーが処理された位置の両方を含めることができます。

js
try {
  process.chdir('/non-existent-path')
} catch (err) {
  process.report.writeReport(err)
}
// その他のコード

writeReport()にファイル名とエラーオブジェクトの両方が渡された場合、エラーオブジェクトは 2 番目のパラメーターである必要があります。

js
try {
  process.chdir('/non-existent-path')
} catch (err) {
  process.report.writeReport(filename, err)
}
// その他のコード

診断レポートの内容は、JavaScript アプリケーションからの API 呼び出しによって JavaScript オブジェクトとして返すことができます。

js
const report = process.report.getReport()
console.log(typeof report === 'object') // true

// process.report.writeReport()出力と同様
console.log(JSON.stringify(report, null, 2))

この関数は、レポートに表示される JavaScript スタックのコンテキストとして使用されるErrorオブジェクトであるオプションの追加引数errを取ります。

js
const report = process.report.getReport(new Error('custom error'))
console.log(typeof report === 'object') // true

API バージョンは、リソース消費、負荷分散、監視などを自己調整することを期待して、アプリケーション内からランタイム状態を検査する場合に便利です。

レポートの内容は、イベントの種類、日付、時刻、PID、Node.js バージョンを含むヘッダーセクション、JavaScript とネイティブスタックトレースを含むセクション、V8 ヒープ情報を含むセクション、libuvハンドル情報を含むセクション、CPU とメモリの使用状況とシステム制限を示す OS プラットフォーム情報セクションで構成されます。サンプルレポートは、Node.js REPL を使用してトリガーできます。

bash
$ node
> process.report.writeReport();
Writing Node.js report to file: report.20181126.091102.8480.0.001.json
Node.js report completed
>

レポートが書き込まれると、開始メッセージと終了メッセージが stderr に出力され、レポートのファイル名が呼び出し元に返されます。デフォルトのファイル名には、日付、時刻、PID、シーケンス番号が含まれています。シーケンス番号は、同じ Node.js プロセスに対して複数回生成された場合に、レポートダンプをランタイム状態と関連付けるのに役立ちます。

レポートバージョン

診断レポートには、レポート形式を一意に表す 1 桁のバージョン番号(report.header.reportVersion)が関連付けられています。新しいキーの追加または削除、または値のデータ型の変更が行われると、バージョン番号が増加します。レポートのバージョンの定義は、LTS リリース間で一貫しています。

バージョン履歴

バージョン 5

[履歴]

バージョン変更点
v23.5.0メモリ制限単位のタイプミスを修正

userLimits セクションで、data_seg_size_kbytesmax_memory_size_kbytesvirtual_memory_kbytes というキーをそれぞれ data_seg_size_bytesmax_memory_size_bytesvirtual_memory_bytes に置き換えます。これらの値はバイト単位で与えられます。

json
{
  "userLimits": {
    // 一部のキーをスキップ ...
    "data_seg_size_bytes": {
      // data_seg_size_kbytes の置き換え
      "soft": "unlimited",
      "hard": "unlimited"
    },
    // ...
    "max_memory_size_bytes": {
      // max_memory_size_kbytes の置き換え
      "soft": "unlimited",
      "hard": "unlimited"
    },
    // ...
    "virtual_memory_bytes": {
      // virtual_memory_kbytes の置き換え
      "soft": "unlimited",
      "hard": "unlimited"
    }
  }
}

バージョン 4

[履歴]

バージョン変更点
v23.3.0レポート生成から環境変数を除外するための --report-exclude-env オプションを追加

tcp および udp の libuv ハンドルエンドポイントに、新しいフィールド ipv4 および ipv6 が追加されました。例:

json
{
  "libuv": [
    {
      "type": "tcp",
      "is_active": true,
      "is_referenced": true,
      "address": "0x000055e70fcb85d8",
      "localEndpoint": {
        "host": "localhost",
        "ip4": "127.0.0.1", // 新しいキー
        "port": 48986
      },
      "remoteEndpoint": {
        "host": "localhost",
        "ip4": "127.0.0.1", // 新しいキー
        "port": 38573
      },
      "sendBufferSize": 2626560,
      "recvBufferSize": 131072,
      "fd": 24,
      "writeQueueSize": 0,
      "readable": true,
      "writable": true
    },
    {
      "type": "tcp",
      "is_active": true,
      "is_referenced": true,
      "address": "0x000055e70fcd68c8",
      "localEndpoint": {
        "host": "ip6-localhost",
        "ip6": "::1", // 新しいキー
        "port": 52266
      },
      "remoteEndpoint": {
        "host": "ip6-localhost",
        "ip6": "::1", // 新しいキー
        "port": 38573
      },
      "sendBufferSize": 2626560,
      "recvBufferSize": 131072,
      "fd": 25,
      "writeQueueSize": 0,
      "readable": false,
      "writable": false
    }
  ]
}

バージョン 3

[履歴]

バージョン変更点
v19.1.0, v18.13.0メモリ情報の追加

以下のメモリ使用量キーが resourceUsage セクションに追加されました。

json
{
  "resourceUsage": {
    "rss": "35766272",
    "free_memory": "1598337024",
    "total_memory": "17179869184",
    "available_memory": "1598337024",
    "constrained_memory": "36624662528"
  }
}

バージョン 2

[履歴]

バージョン変更点
v13.9.0, v12.16.2ワーカーがレポートに含まれるようになりました。

Worker サポートを追加しました。詳細は ワーカーとの連携 セクションを参照してください。

バージョン 1

診断レポートの最初のバージョンです。

設定

レポート生成の追加のランタイム設定は、process.report の以下のプロパティを介して利用できます。

reportOnFatalError は、true の場合、致命的なエラー時に診断レポートをトリガーします。デフォルトは false です。

reportOnSignal は、true の場合、シグナル時に診断レポートをトリガーします。Windows ではサポートされていません。デフォルトは false です。

reportOnUncaughtException は、true の場合、キャッチされない例外時に診断レポートをトリガーします。デフォルトは false です。

signal は、レポート生成の外部トリガーをインターセプトするために使用される POSIX シグナル識別子を指定します。デフォルトは 'SIGUSR2' です。

filename は、ファイルシステム内の出力ファイル名を指定します。stdoutstderr には特別な意味が付けられています。これらを使用すると、関連付けられた標準ストリームにレポートが書き込まれます。標準ストリームが使用される場合、directory の値は無視されます。URL はサポートされていません。デフォルトは、タイムスタンプ、PID、シーケンス番号を含む複合ファイル名です。

directory は、レポートが書き込まれるファイルシステムディレクトリを指定します。URL はサポートされていません。デフォルトは、Node.js プロセスの現在の作業ディレクトリです。

excludeNetwork は、診断レポートから header.networkInterfaces を除外します。

js
// キャッチされない例外でのみレポートをトリガーします。
process.report.reportOnFatalError = false
process.report.reportOnSignal = false
process.report.reportOnUncaughtException = true

// 内部エラーと外部シグナルの両方に対してレポートをトリガーします。
process.report.reportOnFatalError = true
process.report.reportOnSignal = true
process.report.reportOnUncaughtException = false

// デフォルトのシグナルを 'SIGQUIT' に変更し、有効にします。
process.report.reportOnFatalError = false
process.report.reportOnUncaughtException = false
process.report.reportOnSignal = true
process.report.signal = 'SIGQUIT'

// ネットワークインターフェースのレポートを無効にします
process.report.excludeNetwork = true

モジュールの初期化時の設定は、環境変数でも利用できます。

bash
NODE_OPTIONS="--report-uncaught-exception \
  --report-on-fatalerror --report-on-signal \
  --report-signal=SIGUSR2  --report-filename=./report.json \
  --report-directory=/home/nodeuser"

特定の API ドキュメントは、process API documentation セクションにあります。

ワーカーとの対話

[履歴]

バージョン変更点
v13.9.0, v12.16.2レポートにワーカーが含まれるようになりました。

Worker スレッドは、メインスレッドと同様にレポートを作成できます。

レポートには、workers セクションの一部として、現在スレッドの子であるワーカーに関する情報が含まれます。各ワーカーは標準的なレポート形式でレポートを生成します。

レポートを生成しているスレッドは、ワーカースレッドからのレポートが完了するのを待ちます。ただし、JavaScript の実行とイベントループの両方がレポート生成のために中断されるため、この待ち時間は通常短くなります。