>  기사  >  백엔드 개발  >  Nginx가 로드 밸런싱을 달성하는 여러 가지 방법

Nginx가 로드 밸런싱을 달성하는 여러 가지 방법

小云云
小云云원래의
2018-03-05 11:12:033101검색

로드 밸런싱이란

서버의 단위 시간당 방문 횟수가 많을수록 서버에 가해지는 부담이 커지므로 자체 용량을 초과하면 서버가 붕괴됩니다. 서버 충돌을 방지하고 사용자에게 더 나은 경험을 제공하기 위해 우리는 로드 밸런싱을 사용하여 서버 압력을 공유합니다.

아주 많은 서버를 구축하여 서버 클러스터를 구성할 수 있습니다. 사용자가 웹 사이트에 접속하면 먼저 중간 서버에 액세스한 다음 중간 서버가 서버 클러스터에서 부담이 적은 서버를 선택하게 한 다음 서버 클러스터를 도입합니다. 서버에 대한 액세스 요청입니다. 이러한 방식으로 사용자가 방문할 때마다 서버 클러스터에 있는 각 서버의 압력이 균형을 이루고 서버 압력을 공유하고 서버 충돌을 방지하는 경향이 있는지 확인합니다.

로드 밸런싱은 역방향 프록시 원리를 사용하여 구현됩니다.

몇 가지 일반적인 로드 밸런싱 방법

1. 폴링(기본값)
각 요청은 백엔드 서버가 시간순으로 하나씩 다운되면 자동으로 할당될 수 있습니다. 제거되었습니다.

upstream backserver {    server 192.168.0.14;    server 192.168.0.15;
}

2. Weight

폴링 확률을 지정하며, 가중치는 액세스 비율에 비례하며 백엔드 서버 성능이 고르지 않은
상황에 사용됩니다.

upstream backserver {    server 192.168.0.14 weight=3;    server 192.168.0.15 weight=7;
}

가중치가 높을수록 접속 확률은 높아집니다. 위 예시처럼 각각 30%, 70%입니다.

3. 위 방법에는 문제가 있습니다. 로드 밸런싱 시스템에서는 사용자가 특정 서버에 로그인한 후 두 번째 요청을 하면 각 요청은 특정 서버 클러스터를 반복적으로 찾으면 특정 서버에 로그인한 사용자가 다른 서버로 이동하게 되고 해당 사용자의 로그인 정보가 손실되므로 이는 명백히 부적절합니다.

ip_hash 명령을 사용하면 이 문제를 해결할 수 있습니다. 고객이 이미 특정 서버를 방문한 경우 사용자가 다시 방문하면 해시 알고리즘을 통해 요청이 자동으로 서버에 위치하게 됩니다.

각 요청은 액세스 IP의 해시 결과에 따라 할당되므로 각 방문자는 백엔드 서버에 대한 고정 액세스 권한을 갖게 되어 세션 문제를 해결할 수 있습니다.

upstream backserver {
    ip_hash;    server 192.168.0.14:88;    server 192.168.0.15:80;
}

4. fair (third party)

백엔드 서버의 응답 시간에 따라 요청이 할당되며, 응답 시간이 짧은 요청이 먼저 할당됩니다.

upstream backserver {    server server1;    server server2;
    fair;
}

5.url_hash(타사)

접근한 URL의 해시 결과에 따라 요청을 배포하여 각 URL이 동일한 백엔드 서버로 연결되도록 합니다. 백엔드 서버를 캐시할 때 더욱 효과적입니다.

upstream backserver {
    server squid1:3128;
    server squid2:3128;    hash $request_uri;    hash_method crc32;
}

각 장치의 상태는 다음과 같이 설정됩니다.

1.down은 이전 서버가 일시적으로 로드에 참여하지 않음을 의미합니다.

2.weight 기본값은 1입니다. 가중치가 클수록 부하의 무게도 커집니다. .
3.max_fails: 허용되는 요청 실패 횟수는 기본적으로 1회입니다. 최대 횟수를 초과하면 proxy_next_upstream 모듈 정의 오류
4.fail_timeout:max_fails 실패 후 시간을 일시 중지합니다. max_fails:允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream模块定义的错误 
4.fail_timeout:max_fails5.backup: 백업이 아닌 다른 머신이 모두 다운되거나 사용 중일 때 백업 머신을 요청하세요. 따라서 이 기계의 압력은 가장 낮습니다.

구성 예:

#user  nobody;worker_processes  4;
events {    # 最大并发数
    worker_connections  1024;
}
http{    # 待选服务器列表
    upstream myproject{        # ip_hash指令,将同一用户引入同一服务器。
        ip_hash;        server 125.219.42.4 fail_timeout=60s;        server 172.31.2.183;
        }    server{                # 监听端口
                listen 80;                # 根目录下
                location / {                    # 选择哪个服务器列表
                    proxy_pass http://myproject;
                }

            }
}

관련 권장 사항:

Nginx 역방향 프록시 및 로드 밸런싱 실습

nginx 4계층 로드 밸런싱 구성

Nginx 로드 밸런싱에 대한 자세한 설명

위 내용은 Nginx가 로드 밸런싱을 달성하는 여러 가지 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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