티스토리 뷰

반응형

Node.js 서비스 배포 PM2 사용하여 server 성능 향상(멀티스레드)

 

Node.js는 기본적으로 싱글 스레드로 동작하는데, 이는 Node.js의 이벤트 기반 아키텍처 때문입니다. 하지만 이는 대규모 애플리케이션의 경우 한계가 있기 때문에 멀티스레딩을 사용하여 성능을 높이는 것이 필요합니다. 이번에는 PM2를 이용하여 Node.js에서 멀티스레딩을 사용하는 방법에 대해 알아보겠습니다.

PM2란 무엇인가?
PM2는 Node.js 애플리케이션의 프로세스 관리자로, Node.js 애플리케이션을 데몬으로 실행하고 모니터링할 수 있습니다. 이를 이용하면 Node.js 애플리케이션을 쉽게 배포하고 관리할 수 있습니다.


PM2에서 멀티스레딩 사용하기
PM2를 사용하여 Node.js에서 멀티스레딩을 사용하려면 PM2를 설치하고 설정 파일을 만들어야 합니다.


1. PM2 설치하기
PM2는 npm을 이용하여 설치할 수 있습니다. 다음 명령어를 사용하여 PM2를 설치합니다.

npm install pm2 -g



2. Node.js 애플리케이션 작성
멀티스레딩을 사용하기 위해서는 cluster 모듈을 이용하여 워커 프로세스를 생성해야 합니다. 다음은 간단한 Node.js 애플리케이션 예시입니다.

const http = require('http');
const cluster = require('cluster');
const numCPUs = require('os').cpus().length;

if (cluster.isMaster) {
  console.log(`Master ${process.pid} is running`);

  for (let i = 0; i < numCPUs; i++) {
    cluster.fork();
  }

  cluster.on('exit', (worker, code, signal) => {
    console.log(`worker ${worker.process.pid} died`);
    cluster.fork();
  });
} else {
  http.createServer((req, res) => {
    res.writeHead(200);
    res.end('Hello World\n');
  }).listen(8000);

  console.log(`Worker ${process.pid} started`);
}



위 코드에서 cluster 모듈을 사용하여 워커 프로세스를 생성하고, 각 워커 프로세스가 HTTP 서버를 생성합니다. numCPUs 변수는 CPU 코어 수를 반환하므로, 이를 이용하여 워커 프로세스 수를 결정합니다.

 

3. PM2로 실행하기
PM2를 이용하여 애플리케이션을 실행하려면 다음과 같이 입력합니다.

pm2 start app.js -i max


-i max 옵션은 CPU 코어 수에 맞게 워커 프로세스를 생성하도록 합니다. 이렇게 실행된 애플리케이션은 cluster 모드로 실행되며, CPU 코어 수에 맞게 워커 프로세스가 생성됩니다. PM2는 각 워커 프로세스를 모니터링하고, 워커 프로세스 중 하나가 죽을 경우 해당 워커 프로세스를 재시작합니다.


4. PM2로 관리하기
PM2를 이용하면 Node.js 애플리케이션을 쉽게 관리할 수 있습니다. 다음은 PM2 명령어의 몇 가지 예시입니다.

pm2 list: 현재 실행 중인 애플리케이션 목록을 확인합니다.
pm2 stop [app-name]: 지정한 애플리케이션을 중지합니다.
pm2 restart [app-name]: 지정한 애플리케이션을 재시작합니다.
pm2 logs [app-name]: 지정한 애플리케이션의 로그를 확인합니다.


5. 버시스 배포하기
PM2를 이용하여 Node.js 애플리케이션을 멀티스레드 방식으로 실행하고 관리하는 방법을 알아보았습니다. 이제 이 애플리케이션을 버시스에 배포해 보겠습니다.

1) 먼저, Node.js 애플리케이션 코드를 작성합니다.
2) 애플리케이션 코드를 GitHub 또는 GitLab 등의 코드 저장소에 업로드합니다.
3) 버시스에서 새로운 애플리케이션을 만들고, Git 저장소와 연결합니다.
4) 애플리케이션 설정을 변경하여 PM2를 사용하도록 설정합니다.
5) 애플리케이션을 배포합니다.
6) 다음은 버시스에서 Node.js 애플리케이션을 배포하는 방법입니다.
7) 버시스에 로그인합니다.
8) apps:create 명령어를 이용하여 새로운 애플리케이션을 생성합니다.


$ vcli apps:create myapp
9) git:remote 명령어를 이용하여 Git 저장소와 연결합니다.


$ vcli git:remote myapp
10) config:set 명령어를 이용하여 PM2를 사용하도록 설정합니다.


$ vcli config:set myapp PM2_STARTUP_COMMAND="pm2 start app.js -i max"
이 명령어는 PM2_STARTUP_COMMAND 환경 변수를 설정하며, 이 값은 PM2를 실행하는 명령어입니다. 위 예시에서는 app.js 파일을 -i max 옵션과 함께 실행하는 명령어입니다.

11) 애플리케이션을 배포합니다.

$ vcli deploy myapp

12) 이 명령어는 Git 저장소에서 코드를 가져와서 배포합니다. 이후 PM2가 자동으로 실행됩니다.

이제 Node.js 애플리케이션을 멀티스레드 방식으로 실행하고, PM2를 이용하여 애플리케이션을 관리하며, 버시스를 이용하여 애플리케이션을 배포하는 방법을 알아보았습니다. 이제 애플리케이션을 실행하고, PM2를 이용하여 애플리케이션을 관리할 수 있습니다.

6. 결론
Node.js를 이용하여 개발한 애플리케이션은 PM2를 이용하여 멀티스레드 방식으로 실행할 수 있습니다. PM2는 애플리케이션 실행과 관리를 쉽게 할 수 있는 도구입니다. 버시스와 함께 사용하면 애플리케이션을 쉽게 배포할 수 있습니다.

이번에는 Node.js와 PM2, 버시스를 이용하여 멀티스레드 애플리케이션을 만들고 배포하는 방법에 대해 알아보았습니다. 이제 여러분은 Node.js를 이용하여 멀티스레드 애플리케이션을 만들어 볼 수 있습니다.



반응형
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함