Inhaltsverzeichnis
Das Folgende ist ein Beispiel für einen Knotenserver. Es handelt sich um ein Beispiel mit einem Speicherverlustproblem und um eine optimierte Version des Problems, das Shanyue seit langem in der Produktionsumgebung positioniert. Bei diesem Speicherverlustproblem schoss der Speicher in einem einzelnen Container von ursprünglich 400 MB auf 700 MB hoch und unterschritt gelegentlich die Containerressourcengrenze von 800 MB, was zu Neustarts führte. Das Problem wurde eine Zeit lang nicht gefunden (das Problem wurde zu spät entdeckt, die Zeitreihendaten vor einem halben Monat waren verschluckt worden, sodass Release nicht gefunden werden konnte), sodass das Ressourcenlimit auf 1000 MB angehoben wurde. Später stellte sich heraus, dass es dadurch verursacht wurde, dass ctx.request ein großes Feld in der Datenbank anlegte Produktionsumgebung. Dann ist es wichtig zu verstehen, wie man den Speicher lokal überwacht.
Anleitung Finden Sie die PID des Node-Prozesses" >Bevor Sie pidstat verwenden, müssen Sie zuerst die pid des Prozesses finden

Anleitung Finden Sie die PID des Node-Prozesses

如何找到 Node 进程的 pid
使用 pidstat 监控内存
使用 top 监控内存
生产环境内存监控
总结
Heim Web-Frontend js-Tutorial Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

Aug 28, 2020 am 10:21 AM
node

Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

Bei der Verwendung von Node in einer Produktionsumgebung als Serversprache sind übermäßige Parallelität oder Codeprobleme, die zu OOM (nicht genügend Speicher) oder CPU-Vollauslastung führen, derzeit häufige Probleme bei der Überwachung der CPU und Speicher, kombiniert mit Protokollen und Release, ist es einfach, Probleme zu finden.

【Video-Tutorial-Empfehlung: Node-JS-Tutorial

In diesem Kapitel wird erläutert, wie Sie die Speicheränderungen der lokalen Umgebung und der Produktionsumgebung überwachen können Speicheränderungen eines Node-Prozesses Wolltuch?

Das Folgende ist ein Beispiel für einen Knotenserver. Es handelt sich um ein Beispiel mit einem Speicherverlustproblem und um eine optimierte Version des Problems, das Shanyue seit langem in der Produktionsumgebung positioniert. Bei diesem Speicherverlustproblem schoss der Speicher in einem einzelnen Container von ursprünglich 400 MB auf 700 MB hoch und unterschritt gelegentlich die Containerressourcengrenze von 800 MB, was zu Neustarts führte. Das Problem wurde eine Zeit lang nicht gefunden (das Problem wurde zu spät entdeckt, die Zeitreihendaten vor einem halben Monat waren verschluckt worden, sodass Release nicht gefunden werden konnte), sodass das Ressourcenlimit auf 1000 MB angehoben wurde. Später stellte sich heraus, dass es dadurch verursacht wurde, dass ctx.request ein großes Feld in der Datenbank anlegte Produktionsumgebung. Dann ist es wichtig zu verstehen, wie man den Speicher lokal überwacht.

pidstat ist ein Paket der sysstat-Reihe von Linux-Leistungs-Debugging-Tools. Es wird tatsächlich zum Debuggen von Linux-Leistungsproblemen verwendet, einschließlich Speicher, Netzwerk, E/A, CPU usw .

Dies wird nicht nur mit node versucht, sondern gilt auch für alle Prozesse, einschließlich python, java und go code><blockquote> </blockquote><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>const Koa = require(&amp;#39;koa&amp;#39;) const app = new Koa() function getData () { return Array.from(Array(1000)).map(x =&gt; 10086) } app.use(async (ctx, next) =&gt; { ctx.data = getData() await next() }) app.use(ctx =&gt; { ctx.body = &amp;#39;hello, world&amp;#39; }) app.listen(3200, () =&gt; console.log(&amp;#39;Port: 3200&amp;#39;))</pre><div class="contentsignin">Nach dem Login kopieren</div></div><h2 id="Bevor-Sie-code-pidstat-code-verwenden-müssen-Sie-zuerst-die-code-pid-code-des-Prozesses-finden-strong-h-id-item-strong-Anleitung-Finden-Sie-die-PID-des-Node-Prozesses">Bevor Sie <code>pidstat verwenden, müssen Sie zuerst die pid des Prozesses finden

Anleitung Finden Sie die PID des Node-Prozesses

In node können Sie die pid des Prozesses über process.pid finden

# -r: 指输出内存指标
# -p: 指定 pid
# 1: 每一秒输出一次
# 100: 输出100次
$ pidstat -r -p pid 1 100
Nach dem Login kopieren

Man kann es zwar finden, indem man den Code >pid schreibt, aber es ist aufdringlich und nicht sehr praktisch. Wie kann man also pid auf nicht-invasive Weise finden? Es gibt zwei Möglichkeitenpidstatsysstat 系列 linux 性能调试工具的一个包,竟然用它来调试 linux 的性能问题,包括内存,网络,IO,CPU 等。

这不仅试用与 node,而且适用于一切进程,包括 pythonjava 以及 go

> process.pid
16425
Nach dem Login kopieren

而在使用 pidstat 之前,需要先找到进程的 pid

如何找到 Node 进程的 pid

node 中可以通过 process.pid 来找到进程的 pid

$ 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)
Nach dem Login kopieren

虽然通过写代码可以找到 pid,但是具有侵入性,不太实用。那如何通过非侵入的手段找到 pid 呢?有两种办法

  1. 通过多余的参数结合 ps 定位进程
  2. 通过端口号结合 lsof 定位进程
$ ab -c 10000 -n 1000000 http://localhost:3200/
Nach dem Login kopieren

使用 pidstat 监控内存

Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

从以上代码中可以知道,node 服务的 pid 为 31796,为了可以观察到内存的动态变化,再施加一个压力测试

# -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
Nach dem Login kopieren
$ htop -p 31796
Nach dem Login kopieren

对于输出指标的含义如下

  • RSS: Resident Set Size,常驻内存集,可理解为内存,这就是我们需要监控的内存指标
  • VSZ: virtual size,虚拟内存

从输出可以看出,当施加了压力测试后,内存由 19M 涨到了 85M。

使用 top 监控内存

pidstat 是属于 sysstat 下的 linux 性能工具,但在 mac 中,如何定位内存的变化?

此时可以使用 top/htop

rrreee

Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

生产环境内存监控

由于目前生产环境大都部署在 k8s因此生产环境对于某个应用的内存监控本质上是 k8s 对于某个 workload/deployment 的内存监控,关于内存监控 metric 的数据流向大致如下:

k8s -> metric server -> prometheus -> grafana

架构图如下:

Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?

以上图片取自以下文章

最终能够在 grafana

  1. Lokalisieren Sie den Prozess durch redundante Parameter in Kombination mit ps
  2. Verwenden Sie zum Lokalisieren die Portnummer in Kombination mit lsof der Prozess
rrreee

Verwenden Sie pidstat, um den Speicher zu überwachen🎜🎜🎜Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?🎜🎜Wie Sie dem obigen Code entnehmen können, lautet die PID des Knotendienstes 31796, um die dynamischen Veränderungen des Gedächtnisses zu beobachten und dann einen Stresstest durchzuführen🎜rrreeerrreee🎜Die Bedeutung der Ausgabeindikatoren ist wie folgt🎜
  • RSS: Resident Set Size, residenter Speichersatz, der als Speicher verstanden werden kann. Dies ist der Speicherindikator, den wir überwachen müssen
  • VSZ: virtuelle Größe Code>, virtueller Speicher
🎜Aus der Ausgabe können Sie erkennen, dass der Speicher nach Anwendung des Stresstests von 19 MB auf 85 MB gestiegen ist. 🎜🎜

Verwenden Sie top, um den Speicher zu überwachen🎜🎜pidstat ist ein Linux-Leistungstool unter sysstat, aber auf dem Mac finden Sie das Gedächtnisveränderungen? 🎜🎜Sie können derzeit top/htop verwenden🎜rrreee🎜Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?🎜

Speicherüberwachung der Produktionsumgebung🎜🎜Da die meisten aktuellen Produktionsumgebungen in k8sbereitgestellt werden >,🎜so Produktion Die Speicherüberwachung einer Anwendung durch die Umgebung ist im Wesentlichen die Speicherüberwachung einer bestimmten Arbeitslast/Bereitstellung durch k8s Der Datenfluss der Speicherüberwachungs-Metrik ist ungefähr wie folgt: 🎜🎜k8s -> prometheus -> 🎜Das Architekturdiagramm sieht wie folgt aus:🎜🎜🎜🎜Wie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?🎜🎜🎜Die obigen Bilder stammen aus dem folgenden Artikel 🎜🎜🎜Schließlich kann das Echtzeit-Speicherüberwachungsdiagramm einer Anwendung in grafana erfasst werden :🎜

Da es in diesem Teil zu viele Designinhalte gibt, werde ich sie in den folgenden Kapiteln vorstellen

Dies gilt nicht nur für Knotendienste, sondern gilt auch für alle Workloadsworkload

总结

本章介绍了关于 Node 服务的内存在本地环境及生产环境的监控

1、本地使用 htop/top 或者 pidstat 监控进程内存

2、生产环境使用 k8s/metric-server/prometheus/grafanaZusammenfassung

Dieses Kapitel stellt die Überwachung des Knotendienstspeichers in der lokalen Umgebung und Produktionsumgebung vor

1 Verwenden Sie lokal htop/top oder pidstat überwacht den Prozessspeicher

2. Verwenden Sie k8s/metric-server/prometheus/grafana in der Produktionsumgebung, um den Speicher der gesamten Knotenanwendung zu überwachen

Wenn ein Speicherverlust erkannt wird Wie kann das Problem in einem bestimmten Dienst gelöst werden? Daher geht es im nächsten Artikel um

1. Wie die Produktionsumgebung den Speicher der gesamten Anwendung überwacht

2. Wie man OOM schnell findet

3 die reale Produktionsumgebung 🎜 🎜Weitere Kenntnisse zum Thema Programmierung finden Sie unter: 🎜Einführung in die Programmierung🎜! ! 🎜

Das obige ist der detaillierte Inhalt vonWie können Speicheränderungen in der lokalen Umgebung und der Produktionsumgebung im Node-Dienst überwacht werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So löschen Sie einen Knoten in NVM So löschen Sie einen Knoten in NVM Dec 29, 2022 am 10:07 AM

So löschen Sie einen Knoten mit nvm: 1. Laden Sie „nvm-setup.zip“ herunter und installieren Sie es auf dem Laufwerk C. 2. Konfigurieren Sie Umgebungsvariablen und überprüfen Sie die Versionsnummer mit dem Befehl „nvm -v“. install“-Befehl Knoten installieren; 4. Löschen Sie den installierten Knoten über den Befehl „nvm uninstall“.

So verwenden Sie Express für den Datei-Upload im Knotenprojekt So verwenden Sie Express für den Datei-Upload im Knotenprojekt Mar 28, 2023 pm 07:28 PM

Wie gehe ich mit dem Datei-Upload um? Der folgende Artikel stellt Ihnen vor, wie Sie Express zum Hochladen von Dateien im Knotenprojekt verwenden. Ich hoffe, er ist hilfreich für Sie!

Wie führt man eine Docker-Spiegelung des Node-Dienstes durch? Detaillierte Erläuterung der ultimativen Optimierung Wie führt man eine Docker-Spiegelung des Node-Dienstes durch? Detaillierte Erläuterung der ultimativen Optimierung Oct 19, 2022 pm 07:38 PM

Während dieser Zeit habe ich einen dynamischen HTML-Dienst entwickelt, der allen Kategorien von Tencent-Dokumenten gemeinsam ist. Um die Generierung und Bereitstellung des Zugriffs auf verschiedene Kategorien zu erleichtern und dem Trend der Cloud-Migration zu folgen, habe ich über die Verwendung von Docker nachgedacht Serviceinhalte verwalten und Produktversionen einheitlich verwalten. In diesem Artikel werden die Optimierungserfahrungen, die ich bei der Bereitstellung von Docker gesammelt habe, als Referenz weitergegeben.

Eine ausführliche Analyse des Prozessmanagement-Tools „pm2' von Node Eine ausführliche Analyse des Prozessmanagement-Tools „pm2' von Node Apr 03, 2023 pm 06:02 PM

In diesem Artikel stellen wir Ihnen das Prozessmanagement-Tool „pm2“ von Node vor und sprechen darüber, warum PM2 benötigt wird und wie Sie PM2 installieren und verwenden. Ich hoffe, dass es für alle hilfreich ist!

PI -Knotenunterricht: Was ist ein PI -Knoten? Wie installiere und richte ich einen PI -Knoten ein? PI -Knotenunterricht: Was ist ein PI -Knoten? Wie installiere und richte ich einen PI -Knoten ein? Mar 05, 2025 pm 05:57 PM

Detaillierte Erläuterungs- und Installationshandbuch für Pinetwork -Knoten In diesem Artikel wird das Pinetwork -Ökosystem im Detail vorgestellt - PI -Knoten, eine Schlüsselrolle im Pinetwork -Ökosystem und vollständige Schritte für die Installation und Konfiguration. Nach dem Start des Pinetwork -Blockchain -Testnetzes sind PI -Knoten zu einem wichtigen Bestandteil vieler Pioniere geworden, die aktiv an den Tests teilnehmen und sich auf die bevorstehende Hauptnetzwerkveröffentlichung vorbereiten. Wenn Sie Pinetwork noch nicht kennen, wenden Sie sich bitte an was Picoin ist? Was ist der Preis für die Auflistung? PI -Nutzung, Bergbau und Sicherheitsanalyse. Was ist Pinetwork? Das Pinetwork -Projekt begann 2019 und besitzt seine exklusive Kryptowährung PI -Münze. Das Projekt zielt darauf ab, eine zu erstellen, an der jeder teilnehmen kann

Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Dec 02, 2022 pm 09:06 PM

Wie packe ich die ausführbare Datei von nodejs mit pkg? Im folgenden Artikel erfahren Sie, wie Sie mit pkg ein Node-Projekt in eine ausführbare Datei packen. Ich hoffe, dass er Ihnen weiterhilft!

Was tun, wenn npm node gyp ausfällt? Was tun, wenn npm node gyp ausfällt? Dec 29, 2022 pm 02:42 PM

npm node gyp schlägt fehl, weil „node-gyp.js“ nicht mit der Version von „Node.js“ übereinstimmt. Die Lösung ist: 1. Löschen Sie den Knotencache über „npm cache clean -f“ 2. Über „npm install -“ g n“ Installieren Sie das n-Modul. 3. Installieren Sie die Version „node v12.21.0“ über den Befehl „n v12.21.0“.

Tokenbasierte Authentifizierung mit Angular und Node Tokenbasierte Authentifizierung mit Angular und Node Sep 01, 2023 pm 02:01 PM

Die Authentifizierung ist einer der wichtigsten Teile jeder Webanwendung. In diesem Tutorial werden tokenbasierte Authentifizierungssysteme und ihre Unterschiede zu herkömmlichen Anmeldesystemen erläutert. Am Ende dieses Tutorials sehen Sie eine voll funktionsfähige Demo, die in Angular und Node.js geschrieben wurde. Traditionelle Authentifizierungssysteme Bevor wir zu tokenbasierten Authentifizierungssystemen übergehen, werfen wir einen Blick auf traditionelle Authentifizierungssysteme. Der Benutzer gibt seinen Benutzernamen und sein Passwort im Anmeldeformular ein und klickt auf „Anmelden“. Nachdem Sie die Anfrage gestellt haben, authentifizieren Sie den Benutzer im Backend, indem Sie die Datenbank abfragen. Wenn die Anfrage gültig ist, wird eine Sitzung mit den aus der Datenbank erhaltenen Benutzerinformationen erstellt und die Sitzungsinformationen werden im Antwortheader zurückgegeben, sodass die Sitzungs-ID im Browser gespeichert wird. Bietet Zugriff auf Anwendungen, die unterliegen

See all articles