최근에 nginx 공부하는 시간을 갖고 간단한 입문 사례를 만들어 봤습니다.
Nginx(엔진 x) 는 가벼운 웹 서버, 역방향 프록시 서버 및 이메일(IMAP/POP3) 프록시 서버입니다.
일반 클라이언트가 서버에 액세스하는 모드는 직접 액세스입니다. nginx 서버를 사용하면 동일한 애플리케이션을 다른 서버에 배포할 수 있습니다. 액세스 모드는 다음과 같습니다. 서버. 성능이 향상되었습니다. + 서버:
Apache
에 비해
Nginx
는 더 적은 리소스를 사용하고 더 많은 동시 연결을 지원하며 더 높은 효율성을 반영합니다. 이로 인해
는 특히 가상 호스팅 제공업체에서 인기가 높습니다.
epoll 및 kqueue를 개발 모델로
.
선택한 Nginx 덕분에 최대 50,000 개의 동시 연결 응답을 지원할 수 있습니다. 로드 밸런싱 서버: Nginx 는 내부적으로 Rails 및 PHP를 직접 지원할 뿐만 아니라 HTTP 프록시 서버로 외부 서비스도 지원할 수 있습니다. Nginx 는 C
에서 로 작성되었습니다.시스템 리소스 오버헤드나 CPU 사용 효율성은 Perlbal 보다 훨씬 낫습니다. 메일 프록시 서버로서 : Nginx 는 또한 매우 우수한 메일 프록시 서버입니다(이 제품을 개발하는 초기 목적 중 하나는 메일 프록시 서버이기도 합니다). Last.fm 에서는 다음과 같이 설명합니다. 성공과 멋진 경험. Nginx 설치는 매우 간단하고 구성 파일은 매우 간결합니다(perlsyntax도 지원할 수 있음). Bugs매우 적은 수의 서버
: Nginx 시작이 특히 쉽습니다. , 그리고 거의7*24 무중단 운영을 달성하며, 몇 달 동안 실행하더라도 다시 시작할 필요가 없습니다. 서비스를 중단하지 않고 소프트웨어 버전을 업그레이드할 수도 있습니다. 에는 Linux 및 windows 버전이 있으며 기본적으로 해당 버전을 설치해야 합니다. windows를 예로 들어 보겠습니다. 설치 패키지 다운로드http://nginx.org/en/download.html 압축을 풀고 nginx.exe실행을 클릭하여 서비스를 시작합니다. , 브라우저에 localhost(기본 수신 127.0.0.1:80)을 입력하여 다음 페이지를 입력하면 nginx 서버가 성공적으로 시작되었음을 의미합니다. 저는 springboot라는 간단한 프로젝트를 빌드하고 이를 다른 포트에 배포했습니다(다른 서버에 배포할 수 있음). 테스트를 용이하게 하기 위해 출력 내용에서 간단하게 구분했습니다.
참고: conf / nginx.conf 는 nginx입니다. 기본 구성 파일. nginx -c 를 사용하여 구성 파일을 지정할 수도 있습니다. 구성 후 nginx 서버를 다시 시작하고 localhost를 방문하세요. 다시 시작 명령: nginx -s re 부하
은 여전히 nginx(localhost) 서버에 액세스하고 있지만 실제로는 배포된 springbootproject(localhost:8899)에 액세스하고 있습니다. . 몇 번 더 새로 고치면 아래 그림이 표시되어 두 포트에 배포된 서비스에 액세스했음을 나타냅니다. 참고: 두 서비스에서 할당하는 가중치 값이 다르기 때문에 hello world b!!!(actual accesslocalhost:8899)일 가능성이 높습니다. hello world a!!!(실제 localhost:8888)에 액세스할 가능성은 낮습니다. 권한 값을 직접 수정하고 몇 번 더 테스트할 수 있습니다! Nginx일반 명령: Nginx를 사용하여 Ajax 도메인 간 요청을 방지하세요 nginx 역방향 프록시 메커니즘으로 프런트엔드 문제 해결 도메인 간 문제 질문 설치:
Demo:
구성 세부 정보:
#运行用户
#user nobody;
#启动进程,通常设置成和cpu的数量相等
worker_processes 1;
#全局错误日志
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#PID文件,记录当前启动的nginx的进程ID
#pid logs/nginx.pid;
#工作模式及连接数上限
events {
worker_connections 1024;
}
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
#设定mime类型(邮件支持类型),类型由mime.types文件定义
include mime.types;
default_type application/octet-stream;
#设定日志
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
#必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
sendfile on;
#tcp_nopush on;
#连接超时时间
keepalive_timeout 65;
#gzip压缩开关
#gzip on;
#设定负载均衡的服务器列表(或者一个反向代理服务器,一个的话不需要分配权重)
upstream hello_server {
#weigth参数表示权值,权值越高被分配到的几率越大
server 127.0.0.1:8888 weight=1;
server 127.0.0.1:8899 weight=3;
}
server {
#监听80端口,80端口是知名端口号,用于HTTP协议
listen 80;
#定义使用localhost访问
server_name localhost;
#编码格式
charset utf-8;
#access_log logs/host.access.log main;
#反向代理的路径,location 后面设置映射的路径
#对所有请求进行负载均衡请求(和upstream绑定)
location / {
root /root; #定义服务器的默认网站根目录位置
index index.html index.htm; #定义首页索引文件的名称
proxy_pass http://hello_server; #请求转向hello_server 定义的服务器列表
#以下是一些反向代理的配置(可选择性配置)
#proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
#后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
proxy_set_header X-Forwarded-For $remote_addr;
proxy_connect_timeout 90; #nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 90; #后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传
client_max_body_size 10m; #允许客户端请求的最大单文件字节数
client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数
}
}
요약:
관련 권장 사항:
위 내용은 Nginx 로드밸런싱 서버 진입 사례의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!