当一个网站从小到大,访问量逐渐增大现有的服务器已经支撑不住,一般的解决方案就是缓存,加服务器、数据库读写分离,实行负载均衡分布式等等,本人对这些技术方案都没有在项目中具体的实践过,
但是一直听同事过说起,利用空闲时间自我学习了解下,
什么是负载均衡,就是当快要承受不住的时候,又给你一台服务器来分担压力,请求会分配到两台服务器上,两台服务器上部署相同的内容相当于一个分身,可以处理相同的事情,
Nginx作为负载均衡服务器,用户请求先到达Nginx,再由Nginx根据负载配置将请求转发至不同的Web服务器
, 1)从Nginx官网下载http://nginx.org/en/download.html
, 2),,,安装Nginx,并找到nginx.conf文件(C: \ Nginx \ conf \ nginx.conf);
,在http中加入配置:
,,加权轮询,按服务器的性能给予权重,本例是1:2分配
上游www.woizuqiu.com { 服务器192.168.1.1:8080重量=1; 服务器192.168.1.1:8090重量=2; }
ip_hash轮询方法,不可给服务器加权重,nginx会让相同的客户端ip请求相同的服务器
上游www.woizuqiu.com { 服务器192.168.1.1:8080; 服务器192.168.1.1:8090 max_fails=3 fail_timeout=30年代; ip_hash; }
根据服务器的本身的性能差别及职能,可以设置不同的参数控制。
下表示负载过重或者不参与负载
重权重过大代表承担的负载就越大
备份其它服务器时或下降时才会请求备份服务器
max_fails失败超过指定次数会暂停或请求转往其它服务器
fail_timeout失败超过指定次数后暂停时间
服务器配置如下:
服务器{ 听80; server_name www.woizuqiu.com; #字符集koi8-r; #/host.access access_log日志。日志主要; 位置/{ add_header backendIP upstream_addr美元;#被转发到的上游服务器地址 add_header backendCode upstream_status美元;#状态码 proxy_pass http://www.woizuqiu.com; proxy_set_header主机主机美元; proxy_set_header X-Real-IP remote_addr美元; proxy_set_header X-Forwarded-For proxy_add_x_forwarded_for美元; } }
<强> 1。查看Nginx版本:强>
C: \ nginx> nginx - v
<强> 2。启动Nginx: 强>
C: \ nginx>开始nginx
启动Nginx需要占用80端口,常见错误:bind() 0.0.0.0:8080失败(10013:是尝试访问套接字的方式禁止其访问权限),需要把系统的80端口关掉,
检查端口:netstat怡安|中:80,
<强> 3。判断Nginx是否启动:强>
tasklist/fi“imagename eq nginx.exe”
<>强4。停止:强>
C: \ nginx> nginx。exe - s停止
<强> 5。重新载入Nginx: 强>
C: \ nginx> nginx。exe - s重载
以上所述是小编给大家介绍的Nginx负载均衡配置简单配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留的言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!