[ 一日30分 인생승리의 학습법]node - pm2로 node.js 프로세스 관리하기 - 기본 명령어, 실행하기

 

최근 node.js 기반의 백엔드 서비스를 설계 + 제작 + 운영을 해야 할 일이 생겼고 

 

Node.js + express 기반의  실 운용 서버 운영에 대한 고려를 하게 되었다. 

 

기존에 supervisord를 사용한 supervisord에 대한 경험도 있었고 그에따라 프로세스 매니저가 필요하게 되었다. 

이러한 프로세스 매니저는 실제 운영중인 서버에서 어..? (서버에러 멈춰!!) 소리가 나올 확률을 엄청나게 줄여준다.

 

 

supervisord의 흐름 

 

 

 

Node에서 대표적으로 많이 사용하는 프로세스 매니저가 PM2였고 이에 따라 공부를 진행하기로 하였다. 

 

pm2의 역할

  • 프로세스가 종료되면 다시 실행 해 줄 수 있다.
  • 파일을 수정 했을 때 자동으로 프로세스를 껐다가 켜준다
  • 기존의 싱글스레드 기반 Nodejs를 cluster 기능을 통해 최대 16개(하이퍼 스레딩의 경우) 의 프로세스로 분할해서 동시에 사용 가능하게 진행해준다.
  • (worker_threads 를 사용하면 멀티스레딩 방식으로 사용 가능하다)
    공식 홈페이지에 명시된 수많은 기능들( https://pm2.keymetrics.io/ )

pm2 기본 명령어 

 

pm2 start example.js

pm2를 실행하는 명령, 서버 메인 파일을 기동할 때 사용한다. 

  • --watch 
    해당 프로젝트의 변경사항을 감지해서 서버를 자동으로 리로딩 해주는 hot reload 모드
    (nodemon과 유사하다, 주로 개발단계에서 즉시 반영되므로 매우 편리하게 사용 할 수 있다.)
  • -i max or (코어개수)
    싱글 스레드로 돌아가는 node.js를 보완하기 위한 클러스터 모드
    자체 클러스터를 지원해주기 때문에 편리하게 사용 가능하다.
    max 라고 작성하면 최대 코어개수로 클러스터링 진행하며 코어 개수를 입력 해도 된다. 
    최대 max 옵션으로 사용한 모습(코드 변경시에 자동으로 재시작한다)
  • -o <path>
    output에 대한 log 파일 위치를 정할 수 있다.
    (console.log등의 output이 조회 가능하다 )
     
  • -e <path>
    error에 대한 log 파일 위치를 정할 수 있다. 
     
  • -l [path]
    output 과 error 에 대한 log 파일 위치를 정할 수 있다. 

pm2 reload

수정한 사항을 프로세스에 반영하고 싶을 경우 프로세스를 재시작해준다. 

 

pm2 kill

실행중인 pm2 daemon을 종료시킨다.

 

pm2 list 

 

실행중인 pm2의 리스트들을 조회 할 수 있다. 

 

 

 

pm2 stop <name | id | namespace | script | all | json | stdin...>

특정 프로세스를 중단 할 때 사용한다.

 

 

프로세스 id 6 이 stopped로 변경되었다. 

 

 

pm2 delete <name | id | namespace | script | all | json | stdin...>

 

특정 프로세스를 제거할 때 사용한다

 

프로세스 id 6이 사라졌다

 

pm2 log

실행중인 PM2 Daemon의 log를 확인하는 명령어 

 

 

 

pm2 monit

pm2로 실행한 서버들의 상황을 한눈에 확인 할 수 있는 명령어

 

 

 

 

 

pm2 scale <app_name> <number> 

클러스터의 개수를 조정 할 수 있는 명령어 

 

pm2로 운영중에 스케일 in / out을 진행할 수 있다.

 

 

 

 

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

 

pm2 실 적용하기 

 

pm2를 활용해보기 위해 기본적인 

패키지를 설치해준다.

npm init
npm install pm2 -g
npm i express

 

설치가 잘 되었나 확인 하기 위해서 명령어를 입력한다. 

pm2 examples

 

 

 

pm2 examples 실행 

 

 

express 의 아주 기초적인 뼈대를 구축해준다.

 

index.js

const express =require('express')
const PORT = 8080;
const app = express();

app.use(express.json());
app.use(express.urlencoded({extended:false}));


app.get("/", (req,res) => {
    return res.json({hello: "world"});
})

app.listen(PORT, () => console.log(`this server listening on ${PORT}`))

 

이제 해당 index를 pm2를 활용해서 실행해준다.

 

pm2 start index.js

 

정상적으로 pm2가 활성화 되었다. 

 

 

 

이제 해당 pm2를 종료하고 

--watch 속성을 준다. 

pm2 kill

pm2 start index.js --watch

 

변경시마다 재 기동을 진행한다.

 

이제 클러스터링을 적용하기위해 -i 옵션을 줘 봤다.

pm2 kill

pm2 start index.js --watch -i max

 

 

최대 max 옵션으로 사용한 모습(코드 변경시에 자동으로 재시작한다)

 

 

 

 

 

위와같이 정상 동작하는것 을 알 수 있다. 

 

 

다음 포스팅에는 

pm2 + winston.js 를 활용한 에러 로깅 시스템

위 시스템을 Docker로 묶기까지 진행할 예정이다. 

 

 

참고 블로그

https://hellominchan.tistory.com/11 , https://jybaek.tistory.com/716https://engineering.linecorp.com/ko/blog/pm2-nodejs/#PM2%EB%A5%BC%ED%99%9C%EC%9A%A9%ED%95%9CNode.js%EB%AC%B4%EC%A4%91%EB%8B%A8%EC%84%9C%EB%B9%84%EC%8A%A4%ED%95%98%EA%B8%B0-%EC%84%9C%EB%B9%84%EC%8A%A4%EC%9A%B4%EC%98%81%ED%95%98%EA%B8%B0

[출처] https://loy124.tistory.com/379

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
1191 ePub 의 개요 [전자책 표준] 가을의 곰을... 2009.09.03 30229
1190 ubuntu에서 tcl/tk 설치 가을의 곰을... 2010.08.08 25231
1189 ProGuard - 자바 역컴파일 방지 [1] 가을의 곰을... 2010.01.14 22719
1188 안드로이드 구조분석 wiki file 가을의 곰을... 2010.01.10 22130
1187 C Programming Links 가을의 곰을... 2009.09.02 21174
1186 자바에서 x86 어셈블리로 프로그래밍: x86 Assembly Programming in Java Platform 가을의 곰을... 2011.11.15 20535
1185 ubuntu에서 wxPython 설치하기 가을의 곰을... 2010.08.08 19730
1184 Programatically retrieving data from a website into a database file 졸리운_곰 2017.02.26 18828
1183 ▣ Emacs 사용법 ver 3.0 [1] 가을의 곰을... 2010.01.02 18685
1182 GOF 디자인패턴 file 가을의 곰을... 2009.12.05 17690
1181 emacs 사용법 file 가을의 곰을... 2010.01.03 17418
1180 미래 네트워크 연구 동향 file 가을의 곰을... 2009.12.13 17234
1179 소스인사이트 단축키 (2) 가을의 곰을... 2010.10.11 17003
1178 Android 빌드하여 AVD 생성 및 시뮬에 올리기 file 가을의 곰을... 2010.08.15 16946
1177 기계학습 (머신러닝:Machine Learning) 참고자료 링크 : 머신러닝 : 기계 학습 프로그래밍 자료 졸리운_곰 2014.11.29 16075
1176 Overview of MS Fortran Compiler 가을의 곰을... 2009.09.04 15743
1175 Java GUI 프로그래밍 가을의 곰을... 2011.06.05 15694
1174 < 목표성취의 7단계 > 가을의 곰을... 2009.08.17 15465
1173 JQuery의 힘으로 제작된 17 가지 오픈소스 웹 게임들 가을의 곰을... 2013.01.02 15343
1172 Spring 3 MVC Hello World Example file 가을의 곰을... 2011.11.01 14983
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED