> 운영 및 유지보수 > 엔진스 > nginx+iis가 간단한 로드 밸런싱을 구현하는 방법

nginx+iis가 간단한 로드 밸런싱을 구현하는 방법

WBOY
풀어 주다: 2023-05-20 09:43:05
앞으로
986명이 탐색했습니다.

1. nginx 설치

nginx는 경량 웹 서버/역방향 프록시 서버 및 이메일(imap/pop3) 프록시 서버이며 bsd와 유사한 프로토콜로 출시됩니다. 이는 러시아 프로그래머 Igor Sysoev가 개발했으며 러시아의 대규모 포털 웹사이트 및 검색 엔진인 Rambler(러시아어: рамблер)에서 사용됩니다. Nginx의 특징은 더 적은 메모리를 차지하고 강력한 동시성 기능을 갖추고 있다는 것입니다. 실제로 nginx의 동시성 기능은 동일한 유형의 웹 서버에서 더 나은 성능을 발휘합니다. 중국 본토의 nginx 웹사이트 사용자로는 Baidu, Sina, NetEase, Tencent 등이 있습니다.

최신 버전의 nginx는 1.9.3입니다. 제가 다운로드한 것은 윈도우 버전입니다. 일반적으로 리눅스 시스템에 설치하는 것이 일반적이므로, 여기서는 소개하지 않겠습니다. . 공식 다운로드 주소:. 다운로드가 완료된 후 nginx.exe의 압축을 풀고 실행하여 nginx를 시작하면 프로세스에 nginx가 표시됩니다.

nginx+iis가 간단한 로드 밸런싱을 구현하는 방법

로드 밸런싱을 수행하려면 conf/nginx.conf의 구성 정보를 수정해야 합니다. 구성 정보를 수정한 후 nginx -s reload 명령을 통해 수행할 수 있습니다. 여기서는 개미가 제공하는 일괄 프로세스를 사용하여 작동합니다.

nginx+iis가 간단한 로드 밸런싱을 구현하는 방법

nginx.bat 파일을 nginx.exe와 같은 폴더에 넣고 바로 실행해보세요. 이 기사에 사용된 모든 파일은 기사 마지막 부분에 제공됩니다.

nginx+iis가 간단한 로드 밸런싱을 구현하는 방법

2. 사이트 구축 및 구성

1. 두 개의 iis 사이트 구축

사이트 아래에는 현재 서버 정보를 출력하는 간단한 인덱스 페이지만 있습니다. 두 대의 컴퓨터가 없기 때문에 두 사이트를 이 컴퓨터에 배포하고 각각 포트 8082와 9000을 바인딩했습니다.

 protected void page_load(object sender, eventargs e)
 {
  label0.text = "请求开始时间:"+datetime.now.tostring("yyyy-mm-dd hh:mm:ss");
  label1.text = "服务器名称:" + server.machinename;//服务器名称 
  label2.text = "服务器ip地址:" + request.servervariables["local_addr"];//服务器ip地址 
  label3.text = "http访问端口:" + request.servervariables["server_port"];//http访问端口"
  label4.text = ".net解释引擎版本:" + ".net clr" + environment.version.major + "." + environment.version.minor + "." + environment.version.build + "." + environment.version.revision;//.net解释引擎版本 
  label5.text = "服务器操作系统版本:" + environment.osversion.tostring();//服务器操作系统版本 
  label6.text = "服务器iis版本:" + request.servervariables["server_software"];//服务器iis版本 
  label7.text = "服务器域名:" + request.servervariables["server_name"];//服务器域名 
  label8.text = "虚拟目录的绝对路径:" + request.servervariables["appl_rhysical_path"];//虚拟目录的绝对路径 
  label9.text = "执行文件的绝对路径:" + request.servervariables["path_translated"];//执行文件的绝对路径 
  label10.text = "虚拟目录session总数:" + session.contents.count.tostring();//虚拟目录session总数 
  label11.text = "虚拟目录application总数:" + application.contents.count.tostring();//虚拟目录application总数 
  label12.text = "域名主机:" + request.servervariables["http_host"];//域名主机 
  label13.text = "服务器区域语言:" + request.servervariables["http_accept_language"];//服务器区域语言 
  label14.text = "用户信息:" + request.servervariables["http_user_agent"];
  label14.text = "cpu个数:" + environment.getenvironmentvariable("number_of_processors");//cpu个数 
  label15.text = "cpu类型:" + environment.getenvironmentvariable("processor_identifier");//cpu类型 
  label16.text = "请求来源地址:" + request.headers["x-real-ip"];
 }
로그인 후 복사

2. nginx 구성 정보 수정

nginx 수신 포트를 수정하고 http 서버 아래의 수신 노드 값을 수정합니다. 이 머신의 포트 80이 이미 사용 중이므로 포트 8083을 수신하도록 변경했습니다.

Listen 8083;

http 노드 아래에 업스트림(서버 클러스터)을 추가합니다. 서버 설정은 클러스터 서버 정보입니다. 여기에 두 개의 사이트를 구축하고 두 가지 정보를 구성했습니다.

 #服务器集群名称为jq_one
 upstream jq_one {
   server 127.0.0.1:9000; 
   server 127.0.0.1:8082; 
 }
로그인 후 복사

http 노드 아래 위치 노드를 찾아 수정합니다.

location / {
  root html;
  index index.aspx index.html index.htm; #修改主页为index.aspx
 #其中jq_one 对应着upstream设置的集群名称
 proxy_pass  http://jq_one; 
 #设置主机头和客户端真实地址,以便服务器获取客户端真实ip
 proxy_set_header host  $host; 
 proxy_set_header x-real-ip $remote_addr; 
 proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
 }
로그인 후 복사

구성 파일을 수정한 후 nginx 서비스를 다시 시작해야 합니다. 최종 전체 구성 파일 정보는 다음과 같습니다.

3. http:/를 방문합니다. /127.0.0.1:8083/index.aspx 를 몇번 보시고, 빨간색으로 표시된 부분에 집중해보세요.

nginx+iis가 간단한 로드 밸런싱을 구현하는 방법

nginx+iis가 간단한 로드 밸런싱을 구현하는 방법 우리의 요청이 8082 사이트와 9000 사이트로 분산되어 있는 것을 볼 수 있으며, 첫 번째는 8082 사이트이고 두 번째는 9000입니다. 이러한 결과는 로드 밸런싱 설정이 성공했음을 증명합니다. 9000개의 사이트를 닫은 다음 페이지를 새로 고치고 출력 http 포트가 항상 8082인지 확인합니다. 이는 사이트 중 하나가 여전히 양호한 사이트인 한 계속 서비스를 제공할 수 있음을 의미합니다.

4. 문제 분석

로드 밸런싱 사이트를 구축했지만 여전히 다음과 같은 문제가 있습니다.

1. 사이트에서 세션을 사용하고 요청이 두 사이트에 균등하게 분배되는 경우 세션 공유 문제가 있는 것 같습니다. 어떻게 해결하나요?

세션 정보를 저장하려면 데이터베이스를 사용하세요.

nginx를 사용하여 동일한 IP의 요청을 고정 서버에 할당하려면 다음과 같이 수정하세요. ip_hash는 해당 IP에 해당하는 해시 값을 계산한 다음 이를 고정 서버에 할당합니다


  upstream jq_one{
   server 127.0.0.1:8082 ;
    server 127.0.0.1:9000 ;
   ip_hash;
  }
로그인 후 복사

Redis 서버를 구축하고 Redis 서버에서 세션을 읽습니다. 다음 글에서는 분산 캐시 Redis의 사용 방법을 소개합니다.

2. 관리자는 어떻게 사이트 파일을 업데이트합니까? 현재 서버가 2개뿐입니다. 서버가 10개라면 수동으로 업데이트할 수 있습니다. . 절대 불가능합니다


다중 서버 사이트 업데이트는 파일 수정 및 새로운 추가 사항을 자동으로 감지한 다음 이를 다른 서버와 동기화하는 goodsync 파일 동기화 프로그램을 사용할 수 있습니다. Linux

에서 rsync를 사용할 수 있습니다. 3. 사이트의 파일 업로드 기능은 파일을 다른 서버에 배포합니다. 파일 공유 문제를 해결하는 방법.


파일 서버를 사용하여 모든 파일을 이 서버에 저장하고, 파일 작업, 읽기, 쓰기가 모두 이 서버에 있습니다. 여기에도 문제가 있습니다. 파일 서버에는 읽기 및 쓰기 상한선이 있습니다.

4. 로드가 다른 서버는 구성이 다릅니다. 구성이 높은 서버가 더 많은 요청을 처리할 수 있습니까? 여기서는 로드 밸런싱을 위한 여러 가지 알고리즘이 있습니다. 최소 연결 방법, 최소 누락 방법, 가장 빠른 응답 방법, 가중치 방법. 여기서는 가중치 부여 방법을 사용하여 요청을 분산할 수 있습니다.


 upstream jq_one{
   server 127.0.0.1:8082 weight=4;
    server 127.0.0.1:9000 weight=1;
  }
로그인 후 복사

通过weight设置每台服务器分配请求站的权重,值越高分配的越多。

5.由于请求是经过nginx转发过来的,可以在代码里面获取到用户请求的实际ip地址吗?

答案是肯定的,在localtion节点设置如下请求头信息

 #设置主机头和客户端真实地址,以便服务器获取客户端真实ip
 proxy_set_header host  $host; 
 proxy_set_header x-real-ip $remote_addr; 
 proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
로그인 후 복사

代码里面通过request.headers["x-real-ip"],就能获取到真实ip

6.nginx实现静态文件(image,js,css)缓存

在server节点下添加新的localtion

 #静态资源缓存设置
 location ~ \.(jpg|png|jpeg|bmp|gif|swf|css)$
 { 
  expires 30d;
  root /nginx-1.9.3/html;#root: #静态文件存在地址,这里设置在/nginx-1.9.3/html下
  break;
 }
로그인 후 복사

    这是index页面的代码

  • nginx+iis가 간단한 로드 밸런싱을 구현하는 방법
  • 위 내용은 nginx+iis가 간단한 로드 밸런싱을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    관련 라벨:
    원천:yisu.com
    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
    인기 튜토리얼
    더>
    최신 다운로드
    더>
    웹 효과
    웹사이트 소스 코드
    웹사이트 자료
    프론트엔드 템플릿