目次
プロセス メモリの監視
方法ノード プロセスの PID を確認するには
pidstat を使用してメモリを監視する
現在の運用環境のほとんどは、
概要
ホームページ ウェブフロントエンド jsチュートリアル Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?

Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?

Aug 28, 2020 am 10:21 AM
node

Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?

実稼働環境でサーバー言語として Node を使用する場合、過剰な同時実行性またはコードの問題により OOM (メモリ不足) が発生するか、CPU がフル稼働します。これらはサーバーによくある問題ですが、現時点では、ログやリリースと組み合わせて CPU とメモリを監視することで、問題を簡単に発見できます。

#[ビデオ チュートリアルの推奨:

node js チュートリアル]

この章では、ローカル環境と運用環境でメモリの変更を監視する方法を紹介します

ノード アプリケーション インスタンス

では、ノード プロセスのメモリ変更を動的に監視するにはどうすればよいでしょうか?

以下はノード サーバーの例です。これはメモリ リークの問題を伴う例であり、Shanyue が運用環境で長い間指摘してきた問題の合理化されたバージョンです。

そのメモリ リークの問題では、単一コンテナ内のメモリが元の 400M から 700M に急増しました。800M のコンテナ リソース制限下では、OOM が発生し、再起動が発生することがありました。しばらく問題が見つからなかった(問題の発見が遅すぎて、半月前の時系列データを飲み込んでしまったため、Release が見つからなかった)ため、リソース制限が 1000M に引き上げられました。その後、データベースに大きなフィールドをマウントする ctx.request が原因であることが判明しました。
const Koa = require('koa')
const app = new Koa()

function getData () {
  return Array.from(Array(1000)).map(x => 10086)
}

app.use(async (ctx, next) => {
  ctx.data = getData()
  await next()
})

app.use(ctx => {
  ctx.body = 'hello, world'
})

app.listen(3200, () => console.log('Port: 3200'))
ログイン後にコピー

プロセス メモリの監視

いくつかの問題は、時間内に解決する必要があります。実稼働環境への大きな影響を回避するため、ローカル環境とテスト環境。次に、メモリをローカルで監視する方法を理解することが重要です。

pidstat は、Linux パフォーマンス デバッグ ツールの sysstat シリーズのパッケージです。メモリ、ネットワーク、IO、CPU などの Linux パフォーマンスの問題をデバッグするために実際に使用されます。 、など。

これは node で試行されるだけでなく、pythonjava を含むすべてのプロセスにも適用されます。 go

# -r: 指输出内存指标
# -p: 指定 pid
# 1: 每一秒输出一次
# 100: 输出100次
$ pidstat -r -p pid 1 100
ログイン後にコピー

pidstat を使用する前に、プロセスの PID を見つける必要があります pid

方法ノード プロセスの PID を確認するには

node では、process を通じてプロセスの pid<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>&gt; process.pid 16425</pre><div class="contentsignin">ログイン後にコピー</div></div> を見つけることができます。 .pid

を記述することによってコードは

pid を見つけることができますが、煩雑であまり実用的ではありません。では、非侵襲的な手段で pid を見つけるにはどうすればよいでしょうか?方法は 2 つあります。

    冗長パラメータと組み合わせる
  1. psプロセスを見つける
  2. ポート番号と組み合わせる
  3. lsofプロセスを見つける
  4. $ node index.js shanyue
    
    # 第一种方法:通过多余的参数快速定位 pid
    $ ps -ef | grep shanyue
    root     31796 23839  1 16:38 pts/5    00:00:00 node index.js shanyue
    
    # 第二种方法:通过端口号定位 pid
    lsof -i:3200
    COMMAND   PID USER   FD   TYPE    DEVICE SIZE/OFF NODE NAME
    node    31796 root   20u  IPv6 235987334      0t0  TCP *:tick-port (LISTEN)
    ログイン後にコピー

pidstat を使用してメモリを監視する

Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?

上記のコードから、ノード サービスの pid が

31796 、メモリの動的な変化を観察するために、ストレス テストを適用します

$ ab -c 10000 -n 1000000 http://localhost:3200/
ログイン後にコピー
# -r: 指输出内存指标
# -p: 指定 pid
# 1: 每一秒输出一次
# 100: 输出100次
$ pidstat -r -p 31796 1 100
Linux 3.10.0-957.21.3.el7.x86_64 (shuifeng)     2020年07月02日  _x86_64_        (2 CPU)

             UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
19时20分39秒     0     11401      0.00      0.00  566768  19800   0.12  node
19时20分40秒     0     11401      0.00      0.00  566768  19800   0.12  node
19时20分41秒     0     11401   9667.00      0.00  579024  37792   0.23  node
19时20分42秒     0     11401  11311.00      0.00  600716  59988   0.37  node
19时20分43秒     0     11401   5417.82      0.00  611420  70900   0.44  node
19时20分44秒     0     11401   3901.00      0.00  627292  85928   0.53  node
19时20分45秒     0     11401   1560.00      0.00  621660  81208   0.50  node
19时20分46秒     0     11401   2390.00      0.00  623964  83696   0.51  node
19时20分47秒     0     11401   1764.00      0.00  625500  85204   0.52  node
ログイン後にコピー

出力インジケーターの意味は次のとおりです

    RSS
  • : 常駐セット サイズ (常駐メモリ セット) はメモリとして理解できます。これは監視する必要があるメモリ インジケータです。
  • VSZ
  • : 仮想サイズ、仮想メモリ
  • 出力からわかるように、
ストレス テストの適用後、メモリは 19M から 85M に増加しました。

top を使用してメモリを監視する

pidstat

sysstat にある Linux パフォーマンス ツールですが、Mac でメモリを見つける方法バラエティ?

top/htop

<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>$ htop -p 31796</pre><div class="contentsignin">ログイン後にコピー</div></div><p><img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/image/488/272/209/1598581094937067.png" class="lazy" title="1598581094937067.png" alt="Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?">運用環境のメモリ監視</p> <h2 id="現在の運用環境のほとんどは">現在の運用環境のほとんどは、 </h2>k8s<p> にデプロイされた環境 <code>したがって、運用環境における特定のアプリケーションのメモリ監視は、本質的には、k8s による特定の ワークロード/デプロイメントのメモリ監視になります。メモリ監視metric のデータ フローの方向は大まかに次のとおりです:

k8s

-> metric server -> prometheus -> grafanaアーキテクチャ図は次のとおりです:

Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?

Node サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか? ##上の写真は次の記事から引用しています

Prometheus を使用した Kubernetes 監視
  • ##Kubernetes 監視アーキテクチャ
  • ##ついに #grafana で収集されたアプリケーションのメモリ監視のリアルタイム グラフができるようになりました:
  • この部分には設計内容が多すぎるため、次の章で紹介します

    これはノード サービスに適用されるだけでなく、すべての k8s ワークロードにも適用されます

    概要

    この章では、ローカル環境および運用環境におけるノード サービス メモリの監視について紹介します

    1. ローカル使用htop/ top または pidstat プロセス メモリの監視

    2. 本番環境での使用k8s/metric-server/prometheus/grafana ノード アプリケーション全体のメモリの監視

    特定のサービスでメモリリークが検出された場合、問題を解決するにはどうすればよいですか?したがって、次の記事では、

    1. 実稼働環境がアプリケーション全体のメモリを監視する方法

    2. 実稼働環境で OOM が発生した場合に、迅速にその場所を特定する方法について説明します。

    3. 実際の運用環境における OOM の位置付けのいくつかの例

    プログラミング関連の知識の詳細については、

    プログラミング入門をご覧ください。 !

以上がNode サービスのローカル環境と運用環境でメモリの変化を監視するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

nvmでノードを削除する方法 nvmでノードを削除する方法 Dec 29, 2022 am 10:07 AM

nvm でノードを削除する方法: 1. 「nvm-setup.zip」をダウンロードして C ドライブにインストールします; 2. 「nvm -v」コマンドで環境変数を構成し、バージョン番号を確認します; 3. 「nvm」を使用しますinstall" コマンド ノードのインストール; 4. "nvm uninstall" コマンドでインストールしたノードを削除します。

Express を使用してノード プロジェクトでファイルのアップロードを処理する方法 Express を使用してノード プロジェクトでファイルのアップロードを処理する方法 Mar 28, 2023 pm 07:28 PM

ファイルのアップロードをどのように処理するか?次の記事では、Express を使用してノード プロジェクトでファイルのアップロードを処理する方法を紹介します。

NodeサービスのDockerミラーリングを行うにはどうすればよいですか?極限最適化の詳しい説明 NodeサービスのDockerミラーリングを行うにはどうすればよいですか?極限最適化の詳しい説明 Oct 19, 2022 pm 07:38 PM

この期間中、私は Tencent ドキュメントのすべてのカテゴリに共通する HTML 動的サービスを開発していましたが、さまざまなカテゴリへのアクセスの生成と展開を容易にし、クラウド移行のトレンドに従うために、Docker を使用して修正することを検討しました。サービス内容や製品バージョンを一元管理します。この記事では、私が Docker を提供するプロセスで蓄積した最適化の経験を参考として共有します。

Nodeのプロセス管理ツール「pm2」を徹底分析 Nodeのプロセス管理ツール「pm2」を徹底分析 Apr 03, 2023 pm 06:02 PM

この記事では、Node のプロセス管理ツール「pm2」について説明し、pm2 が必要な理由、pm2 のインストール方法と使用方法について説明します。皆様のお役に立てれば幸いです。

PIノードティーチング:PIノードとは何ですか? PIノードをインストールしてセットアップする方法は? PIノードティーチング:PIノードとは何ですか? PIノードをインストールしてセットアップする方法は? Mar 05, 2025 pm 05:57 PM

ピン張りのノードの詳細な説明とインストールガイドこの記事では、ピネットワークのエコシステムを詳細に紹介します - PIノードは、ピン系生態系における重要な役割であり、設置と構成の完全な手順を提供します。 Pinetworkブロックチェーンテストネットワークの発売後、PIノードは多くの先駆者の重要な部分になり、テストに積極的に参加し、今後のメインネットワークリリースの準備をしています。まだピン張りのものがわからない場合は、ピコインとは何かを参照してください。リストの価格はいくらですか? PIの使用、マイニング、セキュリティ分析。パインワークとは何ですか?ピン競技プロジェクトは2019年に開始され、独占的な暗号通貨PIコインを所有しています。このプロジェクトは、誰もが参加できるものを作成することを目指しています

pkg を使用して Node.js プロジェクトを実行可能ファイルにパッケージ化する方法について説明します。 pkg を使用して Node.js プロジェクトを実行可能ファイルにパッケージ化する方法について説明します。 Dec 02, 2022 pm 09:06 PM

Nodejs実行可能ファイルをpkgでパッケージ化するにはどうすればよいですか?次の記事では、pkg を使用して Node プロジェクトを実行可能ファイルにパッケージ化する方法を紹介します。

npm ノード gyp が失敗した場合の対処方法 npm ノード gyp が失敗した場合の対処方法 Dec 29, 2022 pm 02:42 PM

「node-gyp.js」が「Node.js」のバージョンと一致しないため、npm node gyp が失敗します。解決策は次のとおりです: 1. 「npm cache clean -f」を使用してノード キャッシュをクリアします; 2. 「npm install -」を使用します。 g n" n モジュールをインストールします。 3. 「n v12.21.0」コマンドを使用して、「node v12.21.0」バージョンをインストールします。

Angular と Node を使用したトークンベースの認証 Angular と Node を使用したトークンベースの認証 Sep 01, 2023 pm 02:01 PM

認証は、Web アプリケーションの最も重要な部分の 1 つです。このチュートリアルでは、トークンベースの認証システムと、それが従来のログイン システムとどのように異なるかについて説明します。このチュートリアルを終えると、Angular と Node.js で書かれた完全に動作するデモが表示されます。従来の認証システム トークンベースの認証システムに進む前に、従来の認証システムを見てみましょう。ユーザーはログイン フォームにユーザー名とパスワードを入力し、[ログイン] をクリックします。リクエストを行った後、データベースにクエリを実行してバックエンドでユーザーを認証します。リクエストが有効な場合、データベースから取得したユーザー情報を使用してセッションが作成され、セッション情報が応答ヘッダーで返され、セッション ID がブラウザに保存されます。対象となるアプリケーションへのアクセスを提供します。

See all articles