nginx 로드밸런싱의 이해
nginx는 경량의 고성능 웹서버로 주로 다음 두 가지 작업을 수행할 수 있습니다.
요즘 nginx는 어디에서나 볼 수 있습니다. 다운타임이 지나면 웹페이지에 nginx라는 단어가 표시되는 것을 흔히 볼 수 있습니다. 이는 고성능, 간단한 사용성 및 장점으로 인해 점점 더 많은 사용자가 nginx를 사용하고 있음을 보여줍니다. 구성 및 오픈 소스가 허용되고 사용됩니다.
첫 번째는 들어오는 요청을 처리하기 위해 php-fpm 프로세스와 결합된 http 서버 역할을 합니다. nginx 자체는 PHP를 구문 분석하지 않으며 단지 클라이언트의 요청을 수락하는 서버 역할만 합니다. 요청은 PHP 프로세스로 전달되어 처리되며, PHP 처리가 완료된 후 결과가 클라이언트로 전송됩니다. 이는 매우 간단합니다. nginx+php-fpm을 설치한 후 해당 구성 파일을 구성하고 시작합니다. 작동 원리는 다음 단락에서 설명할 수 있습니다.
Nginx는 외부 프로그램의 직접 호출이나 구문 분석을 지원하지 않습니다. 모든 외부 프로그램(PHP 포함)은 FastCGI 인터페이스를 통해 호출해야 합니다. FastCGI 인터페이스는 Linux의 소켓입니다(이 소켓은 파일 소켓 또는 IP 소켓일 수 있습니다). CGI 프로그램을 호출하려면 FastCGI 래퍼도 필요합니다(래퍼는 다른 프로그램을 시작하는 데 사용되는 프로그램으로 이해될 수 있음). 이 래퍼는 포트나 파일 소켓과 같은 고정 소켓에 바인딩됩니다. Nginx가 이 소켓에 CGI 요청을 보내면 래퍼는 FastCGI 인터페이스를 통해 요청을 받은 다음 새 스레드를 생성합니다. 이 스레드는 인터프리터나 외부 프로그램을 호출하여 스크립트를 처리하고 반환 데이터를 읽습니다. 반환된 데이터는 고정 소켓을 따라 FastCGI 인터페이스를 통해 Nginx로 전달됩니다. 마지막으로 Nginx는 반환된 데이터를 클라이언트에 보냅니다. 아래 그림과 같이 Nginx+FastCGI의 전체 동작 과정입니다.
위 문단에서는 nginx+fastcgi의 작동 메커니즘을 설명합니다. 요청은 nginx 구성 파일에서 일치되고 그에 따라 처리됩니다. 예를 들어 오류 파일을 직접 반환합니다(이것과 위의 내용에는 약간의 차이가 있는 것으로 추정됩니다). nginx는 HTML과 같은 정적 파일을 내부적으로 구문 분석하고(위 그림과 유사) PHP 프로세스를 사용하여 PHP 요청을 처리할 수 있습니다(여기에는 여러 PHP 프로세스가 있을 수 있음).
두 번째는 역방향 프록시 로드 밸런싱을 사용하는 것입니다. 간단히 말해서 서버 그룹을 정의하고 요청을 일치시킨 다음 처리를 위해 요청을 서버 중 하나로 전달하여 로드를 줄이는 것입니다. 각 서버에서 서버에 압력을 가하려면 먼저 인터넷의 역방향 프록시 정의를 살펴보세요.
역방향 프록시 방식은 프록시 서버를 사용하여 인터넷상의 연결 요청을 수락한 후 내부 네트워크의 서버로 요청을 전달하고 서버에서 얻은 결과를 인터넷에서 연결을 요청한 사람에게 반환하는 것을 말합니다. .클라이언트, 이때 프록시 서버는 외부 세계에 역방향 프록시 서버로 나타납니다.
Reverse Proxy는 Forward Proxy(혹은 Proxy)의 반대말로 Proxy라는 말을 들어보셨을 겁니다. B라는 자원에 좀 더 편리하게 접근하기 위해서는 A라는 자원을 통해서 B라는 자원에 간접적으로 접근한다는 점입니다. 자신이 최종적으로 방문하게 될 웹사이트는 무엇인지 알 수 없으나, 리버스 프록시 사용자는 프록시 서버 뒤에서 어떤 처리가 이루어지는지 알 수 없습니다. 리버스 프록시 서비스의 실제 처리 서버는 인트라넷에 위치하며, 리버스 프록시 서버에만 접속할 수 있습니다. 보안도 크게 향상됩니다.
소프트웨어 설치
nginx 설치는 매우 간단합니다
1. nginx, pcre(재작성용), zlib(압축용), ssl 설치에 필요한 환경, 직접 다운로드, 컴파일, 설치도 가능합니다
yum -y zlib 설치;
yum –y install pcre;
yum –y install openssl;
2. nginx-*.tar.gz를 다운로드하고 설치합니다.
tar –zxvf nginx-1.2.8.tar.gz –C ./;
cd nginx-1.2.8;
./congigure --prefix=/usr/local/nginx;
만들고 설치하기;
3. 구성
여기서 구성할 때는 http{} 사이의 내용만 수정하면 됩니다. 가장 먼저 수정해야 할 부분은 서버 그룹을 설정하고 http 노드 사이에
을 추가하는 것입니다.업스트림 myServer{
서버 www.myapp2.com:80; #로드 밸런싱 1의 서버 주소입니다.
서버 www.myapp1.com:8080 #로드에 참여할 서버 주소입니다. 밸런싱 주소 2
}nginx의 업스트림은 폴링(기본적으로 모든 서버에 시간순으로 하나씩 액세스합니다. 서버가 다운되면 자동으로 제거됨), 가중치(서버의 위치 확률은 비례함)를 지원합니다. (가중치에 따라), 서버 구성이 고르지 않을 때 구성 가능), ip_hash (요청한 IP마다 해시를 계산하고 일정한 규칙에 따라 해당 서버를 할당), fair (각 서버의 응답 시간(rt)에 따라) ) 요청을 배포하고, rt는 우선순위 배포를 알고 있음), url_hash(접근한 URL의 해시 값에 따라 요청을 배포함), 여기서는 기본 회전 방법을 사용합니다.
myServer에 직접 요청
위치 / {
Proxy_pass http://myServer;
}전체 파일(댓글 삭제됨)은 다음과 같습니다.
worker_processes <span>1</span><span>; events { worker_connections </span><span>1024</span><span>; } http { include mime.types; default_type application</span>/octet-<span>stream; sendfile on; keepalive_timeout </span><span>65</span><span>; upstream myServer{ server www.myapp1.com:</span><span>80</span><span>; server www.myapp2.com:</span><span>8080</span><span>; } server { listen </span><span>80</span><span>; server_name my22; location </span>/<span> { proxy_pass http:</span><span>//</span><span>myServer;</span> <span> } } }</span>로그인 후 복사
역방향 프록시 백엔드를 두 서버 간의 로드 밸런서로 설정
이전 단계에서 www.myapp1.com:80과 www.myapp2.com:8080이라는 두 개의 서버 주소가 있는 것을 볼 수 있습니다. 저는 이 두 개의 서버를 가상 머신에 설치했습니다. 로컬 win8 시스템에서는 Apache의 가상 호스트를 사용하여 두 개의 도메인 이름이 설정되며 두 도메인 이름 아래의 코드는 서로 독립적이며 설정도 매우 간단합니다.
1. 아파치 구성 파일 설정
xampp 통합 환경을 사용하고 있는데 httpd.conf의 리스닝 포트에
를 추가해 주어야 합니다.8080 들어보세요
즉, 이곳은 두 개의 포트로 청취합니다
듣기 80
듣기 8080아래 문장이 열려 있는지 확인하세요. 그렇지 않다면 아래와 같이 열어보세요.
<span># Virtual hosts Include conf</span>/extra/httpd-vhosts.conf로그인 후 복사httpd-vhosts.conf에 다음 내용을 추가하세요.
<VirtualHost *:<span>80</span>><span> ServerName www.myapp1.com #对应的域名,负载均衡的服务器地址 DocumentRoot E:\soft\xampp\htdocs\www.myapp1.com #代码文件夹 </span></VirtualHost> <VirtualHost *:<span>8080</span>><span> ServerName www.myapp2.com DocumentRoot E:\soft\xampp\htdocs\www.myapp2.com </span></VirtualHost>로그인 후 복사Windows 호스트 파일을 수정하고 다음 내용을 추가하세요
<span>127.0</span>.<span>0.1</span><span> www.myapp1.com </span><span>127.0</span>.<span>0.1</span> www.myapp2.com로그인 후 복사Linux의 /etc/hosts 파일을 수정하고 다음 내용을 추가하세요
<span>192.168</span>.<span>1.12</span><span> www.myapp1.com #这里前面的地址对应我win8本机的ip地址 </span><span>192.168</span>.<span>1.12</span> www.myapp2.com로그인 후 복사
www.myapp1.com:80 [E:softxampphtdocswww.myapp1.comindex.php]에 index.php 파일을 넣었습니다
www.myapp2.com:8080 [E:softxampphtdocswww.myapp2.comindex.php]에도 index.php 파일이 있습니다.
파일의 내용은 기본적으로 동일합니다. 단, myapp2가 하나는 myapp1이고 다른 하나는 myapp2입니다.
win8 브라우저에 www.myapp1.com:80 및 www.myapp2.com:8080을 입력하면 다양한 효과를 볼 수 있습니다
그리고 centos(직접 꾸미신) 아래에 아래와 같은 결과가 보이면 설정이 성공한 것입니다
[root@bogon nginx]# curl www.myapp1.com:<span>80</span><span> I</span><span>'</span><span>m the myapp1<br>【view】1</span> [root@bogon nginx]# curl www.myapp2.com:<span>8080</span><span> I</span><span>'</span><span>m the myapp2<br>【view】1</span>로그인 후 복사
<?<span>php </span><span>session_save_path</span>("./"<span>); </span><span>session_start</span><span>(); </span><span>header</span>("Content-type:text/html;charset=utf-8"<span>); </span><span>if</span>(<span>isset</span>(<span>$_SESSION</span>['view'<span>])){ </span><span>$_SESSION</span>['view'] = <span>$_SESSION</span>['view'] + 1<span>; }</span><span>else</span><span>{ </span><span>$_SESSION</span>['view'] = 1<span>; } </span><span>echo</span> "I'm the myapp2<br>"<span>; </span><span>echo</span> "【view】{<span>$_SESSION</span>['view']}";로그인 후 복사
효과를 보세요
모든 것이 정상화되면 브라우저를 통해 액세스하여 효과를 확인할 수 있습니다
언급하는 것을 잊어버렸습니다. nginx 프록시 서버의 주소는 http://192.168.1.113입니다.
브라우저에 http://192.168.1.113/index.php를 입력한 후 새로고침을 하면
에 있는 것을 확인할 수 있습니다.나는 myapp2, 나는 myapp1이다
이 두 페이지를 앞뒤로 교환하면 두 번 새로 고침하지 않고 뷰가 한 번 추가됩니다. 이는 앞서 언급한 기본 방법이 회전 훈련이라는 것을 증명하지만 여기서는 또 다른 일반적인 문제가 있습니다. 사용자가 웹 사이트를 방문하면 세션이 처리되지 않고 다른 서버에 저장됩니다. 여기서는 두 개의 서버를 시뮬레이션하기 위해 두 개의 다른 폴더를 사용합니다. 다음 이 문서에서는 이 문제를 해결하는 방법을 설명합니다. , 실제로는 매우 간단합니다.
이 글의 저작권은 저자(luluyrt@163.com)에게 있습니다. 글을 재인쇄한 후, 저자와 원문 링크를 반드시 밝혀야 합니다. 기사 페이지의 명확한 위치에 제공되지 않으면 당사는 법적 책임 권리를 추구할 권리를 보유합니다.
위에서는 모든 측면을 포함하여 로드 밸런싱을 처음부터 구성하기 위해 centos+nginx를 도입했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.