>백엔드 개발 >PHP 튜토리얼 >NGinx 로드 밸런싱 전략

NGinx 로드 밸런싱 전략

WBOY
WBOY원래의
2016-07-29 09:05:491130검색

원문 복사: http://tomyz0223.iteye.com/blog/1046992

nginx의 업스트림은 현재 5가지 배포 방법을 지원합니다
1. (기본값)
각 요청은 시간순으로 하나씩 다른 백엔드 서버에 할당되며, 백엔드 서버가 다운되면 자동으로 제거될 수 있습니다.

upstream backserver {
server 192.168.0.14;
server 192.168.0.15;
}
2. Weight
Polling 확률을 지정하며, 가중치는 접속률에 비례하며 백엔드 서버 성능이 고르지 않을 때 사용됩니다.
upstream backserver {
server 192.168.0.14 weight=10;
server 192.168.0.15 weight=10;
}
3. ip_hash
각 요청은 접속 IP의 해시 결과에 따라 할당되므로 각 방문자는 백엔드에 대한 고정 접속을 갖습니다. 세션 질문 문제를 해결할 수 있는 서버입니다.
upstream backserver {
ip_hash;
server 192.168.0.14:88;
server 192.168.0.15:80;
}
4. fair(제3자)
백엔드 서버의 응답 시간에 따라 요청이 할당되며, 응답 시간이 짧은 요청이 우선적으로 처리됩니다.
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;
}
로드 밸런싱을 사용해야 하는 서버에
proxy_pass http://backserver/ ;
upstream backserver{
ip_hash;
server 127.0.0.1:9090 down; (down 表示单前的server暂时不参与负载)
server 127.0.0.1:8080 weight=2; (weight 默认为1.weight越大,负载的权重就越大)
server 127.0.0.1:6060;
server 127.0.0.1:7070 backup; (其它所有的非backup机器down或者忙的时候,请求backup机器)
}
max_fails를 추가합니다. 허용되는 요청 실패 횟수는 기본적으로 1입니다. 숫자가 초과되면, proxy_next_upstream 모듈에서 정의한 오류를 반환합니다.

위 내용은 다양한 측면을 포함하여 NGinx 로드 밸런싱 전략을 소개하고 있으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

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