Node 서비스에서 로컬 환경과 프로덕션 환경의 메모리 변화를 어떻게 모니터링하나요?
프로덕션 환경에서 Node를 서버 언어로 사용하는 경우 과도한 동시성 또는 코드 문제로 인해 OOM(메모리 부족) 또는 CPU 전체 로드가 발생하는 것은 서버에서 흔히 발생하는 문제로, CPU를 모니터링합니다. 및 메모리, 로그 및 릴리스가 결합되어 문제를 쉽게 찾을 수 있습니다.
【동영상 튜토리얼 추천 : node js tutorial】
이 장에서는 로컬 환경과 프로덕션 환경의 메모리 변경을 모니터링하는 방법을 소개합니다
Node 애플리케이션 인스턴스
그래서 동적으로 모니터링하는 방법은 Node 프로세스의 메모리 변화 모직옷?
다음은 Node Server의 예시로, 메모리 누수 문제가 있는 예시이며, 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 성능 문제를 디버깅하는 데 사용됩니다. . pidstat
是 sysstat
系列 linux 性能调试工具的一个包,竟然用它来调试 linux 的性能问题,包括内存,网络,IO,CPU 等。
这不仅试用与 node
,而且适用于一切进程,包括 python
,java
以及 go
# -r: 指输出内存指标 # -p: 指定 pid # 1: 每一秒输出一次 # 100: 输出100次 $ pidstat -r -p pid 1 100
而在使用 pidstat
之前,需要先找到进程的 pid
如何找到 Node 进程的 pid
在 node
中可以通过 process.pid
来找到进程的 pid
> process.pid 16425
虽然通过写代码可以找到 pid
,但是具有侵入性,不太实用。那如何通过非侵入的手段找到 pid
呢?有两种办法
- 通过多余的参数结合
ps
定位进程 - 通过端口号结合
lsof
定位进程
$ 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
:Resident Set Size
,常驻内存集,可理解为内存,这就是我们需要监控的内存指标VSZ
:virtual size
,虚拟内存
从输出可以看出,当施加了压力测试后,内存由 19M 涨到了 85M。
使用 top 监控内存
pidstat
是属于 sysstat
下的 linux 性能工具,但在 mac 中,如何定位内存的变化?
此时可以使用 top/htop
$ htop -p 31796
生产环境内存监控
由于目前生产环境大都部署在 k8s
,因此生产环境对于某个应用的内存监控本质上是 k8s 对于某个 workload/deployment
的内存监控,关于内存监控 metric
的数据流向大致如下:
k8s
-> metric server
-> prometheus
-> grafana
架构图如下:
以上图片取自以下文章
最终能够在 grafana
node
로 시도했을 뿐만 아니라 python
, java
및 go
를 포함한 모든 프로세스에 적용됩니다. code>🎜 🎜rrreee🎜pidstat
를 사용하기 전에 먼저 프로세스의 pid
를 찾아야 합니다🎜🎜방법 노드 프로세스의 pid를 찾으세요🎜
🎜node
에서 process.pid
를 통해 프로세스의 pid
를 찾을 수 있습니다🎜 rrreee🎜>pid 코드를 작성하여 찾을 수 있지만 방해가 되고 그다지 실용적이지 않습니다. 그렇다면 비침습적 수단을 통해 pid
를 찾는 방법은 무엇일까요? 두 가지 방법이 있습니다🎜-
ps
와 결합된 중복 매개변수를 사용하여 프로세스를 찾습니다. -
lsof
와 결합된 포트 번호를 사용하여 프로세스 찾기
🎜pidstat를 사용하여 메모리 모니터링🎜🎜🎜
🎜🎜위 코드에서 알 수 있듯이 노드 서비스의 pid는 31796 code>, 메모리의 동적 변화를 관찰한 후 스트레스 테스트를 적용하기 위해🎜rrreeerrreee🎜출력 표시기의 의미는 다음과 같습니다🎜<ul>
<li>
<code>RSS
: 상주 세트 크기
, 메모리로 이해될 수 있는 상주 메모리 세트는 모니터링해야 하는 메모리 표시기입니다.
VSZ
: 가상 크기, 가상 메모리
top을 사용하여 메모리 모니터링🎜🎜pidstat
은 sysstat
에 있는 Linux 성능 도구이지만 Mac에서 메모리를 찾는 방법이 변경되었습니다. ? 🎜🎜이때 top/htop
을 사용하시면 됩니다🎜rrreee🎜
🎜생산 환경 메모리 모니터링🎜🎜현재 생산 환경의 대부분이 k8s
에 배포되어 있으므로 >,🎜so 프로덕션 환경에 의한 애플리케이션의 메모리 모니터링은 본질적으로 k8s에 의한 특정 워크로드/배포
의 메모리 모니터링입니다. 메모리 모니터링 metric
의 데이터 흐름입니다. 대략 다음과 같습니다: 🎜🎜k8s
-> k8s
에 배포되어 있으므로 >,🎜so 프로덕션 환경에 의한 애플리케이션의 메모리 모니터링은 본질적으로 k8s에 의한 특정 워크로드/배포
의 메모리 모니터링입니다. 메모리 모니터링 metric
의 데이터 흐름입니다. 대략 다음과 같습니다: 🎜🎜k8smetric server
-> prometheus
-> 🎜아키텍처 다이어그램은 다음과 같습니다.🎜🎜🎜🎜
grafana
에 수집할 수 있습니다. :🎜
이 부분은 디자인 내용이 너무 많아서 다음 장에서 소개하겠습니다
이것은 노드 서비스뿐만 아니라 모든 워크로드
에 적용됩니다workload
总结
本章介绍了关于 Node 服务的内存在本地环境及生产环境的监控
1、本地使用 htop/top
或者 pidstat
监控进程内存
2、生产环境使用 k8s/metric-server/prometheus/grafana
요약
htop/top
또는 pidstat
는 프로세스 메모리를 모니터링합니다2. 프로덕션 환경에서 k8s/metric-server/prometheus/grafana
를 사용하여 전체 노드 애플리케이션의 메모리를 모니터링합니다메모리 누수가 감지된 경우 특정 서비스에서 문제를 해결하는 방법은 무엇입니까? 따라서 다음 글에서는 1. 프로덕션 환경에서 전체 애플리케이션의 메모리를 모니터링하는 방법 2. 프로덕션 환경에서 OOM이 발생할 때 이를 빠르게 찾는 방법
3. 실제 제작 환경 🎜 🎜프로그래밍 관련 지식을 더 보려면 🎜프로그래밍 입문🎜을 방문하세요! ! 🎜위 내용은 Node 서비스에서 로컬 환경과 프로덕션 환경의 메모리 변화를 어떻게 모니터링하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











nvm을 사용하여 노드를 삭제하는 방법: 1. "nvm-setup.zip"을 다운로드하여 C 드라이브에 설치합니다. 2. "nvm -v" 명령을 통해 환경 변수를 구성하고 버전 번호를 확인합니다. install" 명령 노드 설치; 4. "nvm uninstall" 명령을 통해 설치된 노드를 삭제합니다.

파일 업로드를 처리하는 방법은 무엇입니까? 다음 글에서는 Express를 사용하여 노드 프로젝트에서 파일 업로드를 처리하는 방법을 소개하겠습니다. 도움이 되길 바랍니다.

이 기간 동안 저는 Tencent 문서의 모든 카테고리에 공통되는 HTML 동적 서비스를 개발 중입니다. 다양한 카테고리에 대한 액세스 생성 및 배포를 촉진하고 클라우드로 이동하는 추세에 부응하기 위해. Docker를 사용하여 서비스 콘텐츠를 수정하고 제품 버전을 균일하게 관리합니다. 이 글에서는 제가 Docker를 서비스하면서 쌓은 최적화 경험을 여러분의 참고용으로 공유하겠습니다.

이 기사에서는 Node의 프로세스 관리 도구인 "pm2"를 공유하고 pm2가 필요한 이유, pm2 설치 및 사용 방법에 대해 설명합니다. 모두에게 도움이 되기를 바랍니다!

Pinetwork 노드에 대한 자세한 설명 및 설치 안내서이 기사에서는 Pinetwork Ecosystem을 자세히 소개합니다. Pi 노드, Pinetwork 생태계의 주요 역할을 수행하고 설치 및 구성을위한 전체 단계를 제공합니다. Pinetwork 블록 체인 테스트 네트워크가 출시 된 후, PI 노드는 다가오는 주요 네트워크 릴리스를 준비하여 테스트에 적극적으로 참여하는 많은 개척자들의 중요한 부분이되었습니다. 아직 Pinetwork를 모른다면 Picoin이 무엇인지 참조하십시오. 리스팅 가격은 얼마입니까? PI 사용, 광업 및 보안 분석. Pinetwork 란 무엇입니까? Pinetwork 프로젝트는 2019 년에 시작되었으며 독점적 인 Cryptocurrency Pi Coin을 소유하고 있습니다. 이 프로젝트는 모든 사람이 참여할 수있는 사람을 만드는 것을 목표로합니다.

nodejs 실행 파일을 pkg로 패키징하는 방법은 무엇입니까? 다음 기사에서는 pkg를 사용하여 Node 프로젝트를 실행 파일로 패키징하는 방법을 소개합니다. 도움이 되기를 바랍니다.

"node-gyp.js"와 "Node.js"의 버전이 일치하지 않아 npm node gyp가 실패했습니다. 해결 방법: 1. "npm 캐시 clean -f"를 통해 노드 캐시를 지웁니다. 2. "npm install - g n" n 모듈을 설치합니다. 3. "n v12.21.0" 명령을 통해 "node v12.21.0" 버전을 설치합니다.

인증은 모든 웹 애플리케이션에서 가장 중요한 부분 중 하나입니다. 이 튜토리얼에서는 토큰 기반 인증 시스템과 기존 로그인 시스템과의 차이점에 대해 설명합니다. 이 튜토리얼이 끝나면 Angular와 Node.js로 작성된 완벽하게 작동하는 데모를 볼 수 있습니다. 기존 인증 시스템 토큰 기반 인증 시스템으로 넘어가기 전에 기존 인증 시스템을 살펴보겠습니다. 사용자는 로그인 양식에 사용자 이름과 비밀번호를 입력하고 로그인을 클릭합니다. 요청한 후 데이터베이스를 쿼리하여 백엔드에서 사용자를 인증합니다. 요청이 유효하면 데이터베이스에서 얻은 사용자 정보를 이용하여 세션을 생성하고, 세션 정보를 응답 헤더에 반환하여 브라우저에 세션 ID를 저장한다. 다음과 같은 애플리케이션에 대한 액세스를 제공합니다.
