nginx三大功能(之二负载均衡)

什么是负载均衡??html

负载均衡是指N台服务器平均分担负载,不会由于某台服务器负载高而使得某台闲置的状况。java

负载均衡要求的是即有两台服务器以上便可。nginx

测试环境服务器

因为没有服务器,因此本次测试直接使用host设置域名,使用VMware虚拟机来完成:负载均衡

测试域名:www.javaDevelopment.com测试

A 服务器IP(192.168.17.33)server

主服务器 B服务器IP (192.169.17.34)htm

C服务器IP(192.168.17.35)rem

将A服务器做为主服务器,域名直接解析到A服务器上,用A服务器分别来负载B服务器和C服务器 域名解析在本机配置host文件 配置完成后为确保万无一失,使用ping命令测试一下虚拟机

配置主服务的配置文件(nginx.conf)

打开nginx.conf,

该文件位置为nginx安装目录下的conf目录下

在http段加入如下代码:

upstream javaDevelopment.com {

server 192.168.17.34:80;

server 192.168.5.35:80;

}

server{

listen 80;

server_name javaDevelopment.com;

location / {

proxy_pass http://www.javaDevelopment.com;

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

B、C服务器配置nginx.conf配置文件

在nginx.conf http段中加入以下代码:

server{

listen 80;

server_name javaDevelopment.com;

index index.html;

root /data0/htdocs/www;

}

保存重启nginx

测试在地址栏中输入www.javaDevelopment.com网址进行访问,看是否分配到了不一样的服务器。

使用主机提供负载均衡服务:

就用以上例子来实现

A 服务器IP(192.168.17.33)主服务器

B服务器IP (192.168.17.34)

C服务器IP(192.168.17.35)

以前是将域名解析到主服务上(A服务器),而A服务器的功能只是至关于一个转发功能,其实也可让A服务器做为站点服务。

若是添加主服务器到upstream中,那么可能会有如下两种状况发生:

(1)主服务器转发到其余IP上,其余IP服务器会正常处理;

(2)主服务转发到本身的IP上,而后又进到主服务IP分配上,假如一直分配不到IP地址,则会形成一个死循环;

由于在此以前已经使用80做为监听负载均衡的端口了,那么此时来处理的时候就不能使用80端口来处理了,须要从新换一个端口去处理。

在nginx.conf http段中加入如下配置

server{

listen 8090;

server_name javaDevelopment.com;

index index.html;

root /data0/htdocs/www;

}

保存重启nginx 在地址栏中输入wwww.javaDevelopment.com,看是否能正常访问;

以后在upstream javaDeelopment.com{

server 192.168.17.34:80;

server 192.168.17.35:80;

server 192.168.17.33:8080; 或 server 127.0.0.0.1:8080;

}

重启nginx

/usr/local/sbin/nginx & 或 cd /usr/local/sbin/nginx ./nginx -s reload

相关文章
相关标签/搜索