>백엔드 개발 >PHP 튜토리얼 >Nginx 로드밸런싱 서버 진입 사례

Nginx 로드밸런싱 서버 진입 사례

不言
不言원래의
2018-04-04 15:00:171415검색


최근에 nginx 공부하는 시간을 갖고 간단한 입문 사례를 만들어 봤습니다.

소개:

Nginx(엔진 x) 는 가벼운 서버, 역방향 프록시 서버 및 이메일(IMAP/POP3) 프록시 서버입니다.

일반 클라이언트가 서버에 액세스하는 모드는 직접 액세스입니다. nginx 서버를 사용하면 동일한 애플리케이션을 다른 서버에 배포할 수 있습니다. 액세스 모드는 다음과 같습니다. 서버. 성능이 향상되었습니다. + 서버:

Apache

에 비해
Nginx

는 더 적은 리소스를 사용하고 더 많은 동시 연결을 지원하며 더 높은 효율성을 반영합니다. 이로 인해

Nginx

는 특히 가상 호스팅 제공업체에서 인기가 높습니다.

epoll 및 kqueue

를 개발 모델로

.

선택한 Nginx 덕분에 최대 50,000 개의 동시 연결 응답을 지원할 수 있습니다. 로드 밸런싱 서버: Nginx 는 내부적으로 Rails PHP를 직접 지원할 뿐만 아니라 HTTP 프록시 서버로 외부 서비스도 지원할 수 있습니다. Nginx C

에서

로 작성되었습니다.

시스템 리소스 오버헤드나 CPU 사용 효율성은 Perlbal 보다 훨씬 낫습니다. 메일 프록시 서버로서 : Nginx 는 또한 매우 우수한 메일 ​​프록시 서버입니다(이 제품을 개발하는 초기 목적 중 하나는 메일 프록시 서버이기도 합니다). Last.fm 에서는 다음과 같이 설명합니다. 성공과 멋진 경험. Nginx 설치는 매우 간단하고 구성 파일은 매우 간결합니다(perlsyntax도 지원할 수 있음). Bugs매우 적은 수의 서버

: Nginx

시작이 특히 쉽습니다. , 그리고 거의

7*24 무중단 운영을 달성하며, 몇 달 동안 실행하더라도 다시 시작할 필요가 없습니다. 서비스를 중단하지 않고 소프트웨어 버전을 업그레이드할 수도 있습니다.

설치:

에는 Linuxwindows 버전이 있으며 기본적으로 해당 버전을 설치해야 합니다. windows를 예로 들어 보겠습니다.

설치 패키지 다운로드http://nginx.org/en/download.html

압축을 풀고 nginx.exe실행을 클릭하여 서비스를 시작합니다. , 브라우저에 localhost(기본 ​​수신 127.0.0.1:80)을 입력하여 다음 페이지를 입력하면 nginx 서버가 성공적으로 시작되었음을 의미합니다.


Demo:

저는 springboot라는 간단한 프로젝트를 빌드하고 이를 다른 포트에 배포했습니다(다른 서버에 배포할 수 있음). 테스트를 용이하게 하기 위해 출력 내용에서 간단하게 구분했습니다.


구성 세부 정보:

참고: conf / nginx.conf nginx입니다. 기본 구성 파일. nginx -c 를 사용하여 구성 파일을

#运行用户
#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 서버를 다시 시작하고 localhost를 방문하세요.

다시 시작 명령: nginx -s re 부하

은 여전히 ​​nginx(localhost) 서버에 액세스하고 있지만 실제로는 배포된 springbootproject(localhost:8899)에 액세스하고 있습니다. . 몇 번 더 새로 고치면 아래 그림이 표시되어 두 포트에 배포된 서비스에 액세스했음을 나타냅니다.


참고: 두 서비스에서 할당하는 가중치 값이 다르기 때문에 hello world b!!!(actual accesslocalhost:8899)일 가능성이 높습니다. hello world a!!!(실제 localhost:8888)에 액세스할 가능성은 낮습니다. 권한 값을 직접 수정하고 몇 번 더 테스트할 수 있습니다!

요약:

Nginx일반 명령:



관련 권장 사항:

Nginx를 사용하여 Ajax 도메인 간 요청을 방지하세요

nginx 역방향 프록시 메커니즘으로 프런트엔드 문제 해결 도메인 간 문제 질문


위 내용은 Nginx 로드밸런싱 서버 진입 사례의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.