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