로드 밸런싱이란
서버의 단위 시간당 방문 횟수가 많을수록 서버에 가해지는 부담이 커지므로 자체 용량을 초과하면 서버가 붕괴됩니다. 서버 충돌을 방지하고 사용자에게 더 나은 경험을 제공하기 위해 우리는 로드 밸런싱을 사용하여 서버 압력을 공유합니다.
아주 많은 서버를 구축하여 서버 클러스터를 구성할 수 있습니다. 사용자가 웹 사이트에 접속하면 먼저 중간 서버에 액세스한 다음 중간 서버가 서버 클러스터에서 부담이 적은 서버를 선택하게 한 다음 서버 클러스터를 도입합니다. 서버에 대한 액세스 요청입니다. 이러한 방식으로 사용자가 방문할 때마다 서버 클러스터에 있는 각 서버의 압력이 균형을 이루고 서버 압력을 공유하고 서버 충돌을 방지하는 경향이 있는지 확인합니다.
로드 밸런싱은 역방향 프록시 원리를 사용하여 구현됩니다.
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_fails
5.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가 로드 밸런싱을 달성하는 여러 가지 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!