NGINX PM2 VPS: 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처 구축

WBOY
풀어 주다: 2023-09-27 08:09:39
원래의
1039명이 탐색했습니다.

NGINX PM2 VPS: 构建高可用和可扩展的应用服务架构

NGINX PM2 VPS: 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처 구축

인터넷 기술의 급속한 발전으로 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처 구축이 점점 더 중요해지고 있습니다. NGINX, PM2 및 VPS는 이 목표를 달성하는 데 도움이 될 수 있는 일반적으로 사용되는 도구입니다. 이 기사에서는 NGINX, PM2 및 VPS를 사용하여 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처를 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

1. NGINX: 고성능 역방향 프록시 서버

NGINX는 로드 밸런싱, 정적 리소스 캐싱, SSL 터미널 및 기타 기능에 사용할 수 있는 고성능 역방향 프록시 서버입니다. 다음은 모든 트래픽을 백엔드 애플리케이션 서버로 전달하기 위한 간단한 NGINX 구성 예입니다.

http {
    upstream backend {
        server backend1.example.com;
        server backend2.example.com;
    }

    server {
        listen 80;
        server_name example.com;

        location / {
            proxy_pass http://backend;
        }
    }
}
로그인 후 복사

위 구성에서는 여러 백엔드 애플리케이션 서버를 포함하는 backend라는 백엔드 서버 그룹을 정의했습니다. proxy_pass 지시문은 트래픽을 백엔드 서버 그룹으로 전달합니다. backend的后端服务器组,包含了多个后端应用服务器。proxy_pass指令将流量转发到后端服务器组。

2. PM2:进程管理工具

PM2是一个强大的进程管理工具,可以帮助我们管理和监控Node.js应用。以下是一个简单的PM2配置示例:

{
    "apps": [{
        "name": "my-app",
        "script": "app.js",
        "instances": "max",
        "exec_mode": "cluster",
        "error_file": "logs/error.log",
        "out_file": "logs/out.log",
        "log_date_format": "YYYY-MM-DD HH:mm:ss",
        "env": {
            "NODE_ENV": "production"
        }
    }]
}
로그인 후 복사

在上述配置中,我们定义了一个名为my-app的应用,并指定了应用的主文件app.jsinstances指定了应用的实例数,exec_mode指定了应用的执行模式。此外,我们还可以配置应用的日志文件、环境变量等。

3. VPS:虚拟专用服务器

VPS是一种虚拟化技术,可以将一台物理服务器划分为多个虚拟专用服务器。VPS提供了独立的资源,可以满足应用的需求。以下是一个简单的VPS配置示例:

{
    "name": "my-vps",
    "provider": "digitalocean",
    "region": "nyc3",
    "size": "s-1vcpu-1gb",
    "ssh_keys": ["my-public-key"],
    "backups": false
}
로그인 후 복사

在上述配置中,我们定义了一个名为my-vps

2. PM2: 프로세스 관리 도구

PM2는 Node.js 애플리케이션을 관리하고 모니터링하는 데 도움이 되는 강력한 프로세스 관리 도구입니다. 다음은 간단한 PM2 구성 예입니다.

          +---------+
          |   NGINX |
          +---------+
               |
          +---------+
          |   PM2   |
          +---------+
               |
          +---------+
          |   VPS   |
          +---------+
               |
          +---------+
          |   APP   |
          +---------+
로그인 후 복사

위 구성에서는 my-app이라는 애플리케이션을 정의하고 애플리케이션의 기본 파일 app.js를 지정합니다. instances는 애플리케이션의 인스턴스 수를 지정하고 exec_mode는 애플리케이션의 실행 모드를 지정합니다. 또한 애플리케이션의 로그 파일, 환경 변수 등을 구성할 수도 있습니다.

3. VPS: 가상 사설 서버

VPS는 물리적 서버를 여러 개의 가상 사설 서버로 분할할 수 있는 가상화 기술입니다. VPS는 애플리케이션의 요구 사항을 충족하기 위해 독립적인 리소스를 제공합니다. 다음은 간단한 VPS 구성 예입니다.

# 安装 NGINX
sudo apt-get install nginx

# 安装 PM2
sudo npm install -g pm2

# 创建 NGINX 配置文件
sudo nano /etc/nginx/conf.d/my-app.conf
로그인 후 복사

위 구성에서는 my-vps라는 VPS를 정의하고 VPS 공급자, 지역, 크기, SSH 비밀번호 키, 백업 및 기타 구성을 지정했습니다. .

4. 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처 구축

가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처를 구축하기 위해 NGINX, PM2 및 VPS를 결합할 수 있습니다. 다음은 간단한 애플리케이션 서비스 아키텍처 다이어그램입니다.

upstream backend {
    server 127.0.0.1:3000;
    server 127.0.0.1:3001;
}

server {
    listen 80;
    server_name my-app.com;

    location / {
        proxy_pass http://backend;
    }
}
로그인 후 복사

위 아키텍처에서 NGINX는 외부 요청을 수신하고 백엔드 PM2 클러스터로 트래픽을 전달하는 역할을 담당합니다. PM2는 Node.js 애플리케이션의 프로세스를 관리하고 모니터링하는 역할을 담당합니다. VPS는 애플리케이션 가용성과 확장성을 보장하기 위해 독립적인 리소스를 제공합니다.

5. 특정 코드 예제

다음은 NGINX, PM2 및 VPS를 사용하여 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처를 구축하는 방법을 보여주는 특정 코드 예제입니다.

먼저 VPS에 NGINX와 PM2를 설치하고 NGINX의 역방향 프록시를 구성합니다. 🎜
# 在 VPS 上克隆应用代码
git clone https://github.com/my-app.git

# 进入应用目录
cd my-app

# 安装应用依赖
npm install

# 启动应用
pm2 start app.js -i max
로그인 후 복사
🎜NGINX 구성 파일에 다음을 추가합니다. 🎜
sudo systemctl restart nginx
로그인 후 복사
🎜파일을 저장하고 종료합니다. 그런 다음 Node.js 애플리케이션을 VPS에 배포하고 PM2를 사용하여 애플리케이션 프로세스를 관리합니다. 🎜rrreee🎜파일을 저장하고 종료합니다. 마지막으로 NGINX 서버를 다시 시작합니다. 🎜rrreee🎜 이제 NGINX 도메인 이름을 통해 애플리케이션에 액세스할 수 있는 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처를 성공적으로 구축했습니다. 🎜🎜🎜결론🎜🎜🎜이 기사에서는 NGINX, PM2 및 VPS를 사용하여 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처를 구축하는 방법을 소개합니다. 이러한 도구를 적절하게 구성하고 관리함으로써 애플리케이션 가용성과 성능을 향상하고 빠른 확장을 달성할 수 있습니다. 이 코드 예제가 독자가 자신의 애플리케이션 서비스 아키텍처를 구축하는 데 도움이 되기를 바랍니다. 🎜

위 내용은 NGINX PM2 VPS: 가용성과 확장성이 뛰어난 애플리케이션 서비스 아키텍처 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿