NGINX 및 PM2를 사용하여 VPS 서버의 로드 밸런싱을 최적화하는 방법
소개:
현대 웹 애플리케이션에서 로드 밸런싱은 매우 중요한 기술입니다. 여러 서버에 트래픽을 분산시켜 애플리케이션 확장성과 안정성을 향상시킬 수 있습니다. 이 기사에서는 NGINX 및 PM2를 사용하여 VPS 서버의 로드 밸런싱을 최적화하는 방법을 소개합니다. 구체적인 코드 예제를 통해 각 단계를 자세히 설명하겠습니다.
1단계: NGINX 설치
먼저 고성능 웹 서버이자 역방향 프록시 서버인 NGINX를 설치해야 합니다. Ubuntu에 NGINX를 설치하는 특정 명령은 다음과 같습니다.
$ apt-get update $ apt-get install nginx
2단계: NGINX 구성
설치가 완료되면 NGINX의 일부 구성을 수행해야 합니다. 다음은 예제 구성 파일의 내용입니다.
http { upstream backend { server backend1.example.com; server backend2.example.com; } server { listen 80; location / { proxy_pass http://backend; } } }
위 예제에서는 backend1.example.com 및 backend2.example.com 두 개의 백엔드 서버가 포함된 backend라는 서버 클러스터를 설정했습니다. 그런 다음 포트 80에서 수신 대기하고 모든 트래픽을 백엔드 서버 클러스터로 프록시합니다.
3단계: PM2 설치
다음으로 PM2 프로세스 관리자를 설치해야 합니다. PM2는 서버에서 Node.js 애플리케이션을 시작하고 관리하는 데 도움이 될 수 있습니다. Ubuntu에 PM2를 설치하기 위한 특정 명령은 다음과 같습니다.
$ npm install pm2 -g
4단계: 백엔드 서버에 애플리케이션 배포
계속하기 전에 백엔드 서버에 간단한 Node.js 애플리케이션을 배포해야 합니다. 다음은 간단한 Express 애플리케이션의 샘플 코드입니다.
const express = require('express'); const app = express(); app.get('/', (req, res) => { res.send('Hello, World!'); }); app.listen(3000, () => { console.log('App is running on port 3000'); });
위 코드를 app.js로 저장하고 백엔드 서버에서 다음 명령을 실행하여 애플리케이션을 시작합니다.
$ node app.js
이제 애플리케이션은 http:/ 방문을 통해 작동해야 합니다. /backend1.example.com:3000에 액세스합니다.
5단계: PM2를 사용하여 백엔드 서버에서 애플리케이션 시작
PM2를 프로세스 관리에 사용하려면 애플리케이션이 있는 디렉터리를 입력하고 다음 명령을 사용하여 애플리케이션을 시작해야 합니다.
$ pm2 start app.js
The 위 명령은 애플리케이션을 백그라운드에서 실행되는 데몬으로 간주하여 애플리케이션 재시작, 로그 관리 등의 작업을 자동으로 처리합니다.
6단계: NGINX에서 로드 밸런싱 구성
이제 NGINX를 구성하고 백엔드 서버에서 Node.js 애플리케이션을 시작했습니다. 로드 밸런싱을 달성하려면 NGINX 구성 파일을 수정해야 합니다. 다음은 수정된 샘플 구성 파일의 내용입니다.
http { upstream backend { server backend1.example.com:3000; server backend2.example.com:3000; } server { listen 80; location / { proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } }
위 구성 파일에서 백엔드 서버의 포트를 80에서 3000으로 변경하고, 주요 HTTP 헤더 정보를 전달하기 위해 Proxy_set_header 지시문을 추가했습니다.
7단계: NGINX 및 PM2 서비스 다시 시작
로드 밸런싱 테스트를 수행하기 전에 변경 사항을 적용하려면 NGINX 및 PM2 서비스를 다시 시작해야 합니다. 재시작 명령은 다음과 같습니다.
$ service nginx restart $ pm2 restart all
8단계: 로드 밸런싱 테스트
이제 웹 브라우저나 컬 명령을 사용하여 로드 밸런싱이 제대로 작동하는지 테스트할 수 있습니다. http://yourdomain.com을 방문하면 "Hello, World!" 응답을 받을 수 있습니다. 페이지를 새로 고칠 때마다 백엔드 서버에 대해 다른 서버 이름이 표시되어야 하며 이는 로드 밸런싱이 적용되고 있음을 의미합니다.
결론:
NGINX와 PM2를 사용하면 VPS 서버에서 로드 밸런싱을 쉽게 달성할 수 있습니다. 로드 밸런싱은 애플리케이션의 확장성과 안정성을 향상시켜 사용자에게 더 나은 서비스를 제공할 수 있습니다. 이 문서에 제공된 특정 코드 예제와 단계가 독자가 서버 최적화 및 로드 밸런싱을 더 잘 수행하는 데 도움이 되기를 바랍니다.
위 내용은 NGINX 및 PM2를 사용하여 VPS 서버의 로드 밸런싱을 최적화하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

本篇文章给大家带来了关于nginx的相关知识,其中主要介绍了nginx拦截爬虫相关的,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。

高并发系统有三把利器:缓存、降级和限流;限流的目的是通过对并发访问/请求进行限速来保护系统,一旦达到限制速率则可以拒绝服务(定向到错误页)、排队等待(秒杀)、降级(返回兜底数据或默认数据);高并发系统常见的限流有:限制总并发数(数据库连接池)、限制瞬时并发数(如nginx的limit_conn模块,用来限制瞬时并发连接数)、限制时间窗口内的平均速率(nginx的limit_req模块,用来限制每秒的平均速率);另外还可以根据网络连接数、网络流量、cpu或内存负载等来限流。1.限流算法最简单粗暴的

nginx php403错误的解决办法:1、修改文件权限或开启selinux;2、修改php-fpm.conf,加入需要的文件扩展名;3、修改php.ini内容为“cgi.fix_pathinfo = 0”;4、重启php-fpm即可。

实验环境前端nginx:ip192.168.6.242,对后端的wordpress网站做反向代理实现复杂均衡后端nginx:ip192.168.6.36,192.168.6.205都部署wordpress,并使用相同的数据库1、在后端的两个wordpress上配置rsync+inotify,两服务器都开启rsync服务,并且通过inotify分别向对方同步数据下面配置192.168.6.205这台服务器vim/etc/rsyncd.confuid=nginxgid=nginxport=873ho

跨域是开发中经常会遇到的一个场景,也是面试中经常会讨论的一个问题。掌握常见的跨域解决方案及其背后的原理,不仅可以提高我们的开发效率,还能在面试中表现的更加

linux版本:64位centos6.4nginx版本:nginx1.8.0php版本:php5.5.28&php5.4.44注意假如php5.5是主版本已经安装在/usr/local/php目录下,那么再安装其他版本的php再指定不同安装目录即可。安装php#wgethttp://cn2.php.net/get/php-5.4.44.tar.gz/from/this/mirror#tarzxvfphp-5.4.44.tar.gz#cdphp-5.4.44#./configure--pr

nginx部署react刷新404的解决办法:1、修改Nginx配置为“server {listen 80;server_name https://www.xxx.com;location / {root xxx;index index.html index.htm;...}”;2、刷新路由,按当前路径去nginx加载页面即可。

nginx禁止访问php的方法:1、配置nginx,禁止解析指定目录下的指定程序;2、将“location ~^/images/.*\.(php|php5|sh|pl|py)${deny all...}”语句放置在server标签内即可。


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

Dreamweaver Mac版
시각적 웹 개발 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

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

뜨거운 주제



