nginx反向代理,负载均衡
nginx介绍
nginx是一个高效的反向代理工具,可以很方便的实现服务的负载均衡
反向代理方式实际上就是一台负责转发的代理服务器,请求的时候不请求具体的服务器而已请求代理服务器nginx,
然后nginx负责请求真正的服务器,然后返回给客户端。
也就是请求先到达nginx然后在由nginx负责转发到不同的服务中去,就可以达到不同服务器负载的效果了。
当然由于中间加了一层,相比直接请求服务器其实效率是会受一些影响的。
启动nginx
下载后nginx后解压如图
可以双击nginx.exe运行也可以使用命令行运行
按住shift然后右键就可以看到:在此处打开命令窗口 快速的定位到nginx的解压位置
然后运行:start nginx
会一闪而过,如果在进程中找到说明启动成功了
如果在进程中没有找到说明报错了
可以找到错误日志查看,logs里边的error.log
几个常见的错误
1:10013: An attempt was made to access a socket in a way forbidden by its access permissions
这个是由于和nginx里边设置的端口冲突了,比如默认的就是80端口被占用了,我这里是和iis的80端口占用,把iis关闭的就好
2:1113: No mapping for the Unicode character exists in the target multi-byte code page
这个是因为中文目录问题,加入到英文目录中就好了
成功之后访问可以看到
新建两个WebApi模拟不同服务器
端口9000 返回value
端口9001 返回value2
配置nginx实现负载均衡
1:在http节点下,加入upstream节点
upstream 192.168.0.107 { server 192.168.0.108:8081; server 192.168.0.108:8080; }
2:在server节点中的location加入proxy_passp配置了,反向代理的地址
我们请求的地址就是这个
整体配置效果如下:
配置文件修改后使用命令nginx -s reload 重启一下服务
到此一个简单的负载均衡就实现了
我们请求的时候就不直接请求webapi的地址而是代理服务器的地址
除了负载均衡之外我们还可以配置每台服务器的权重比例
可以根据不同服务器的性能来配置权重
upstream 192.168.131.125 { server 192.168.131.125:9000 weight=1; server 192.168.131.125:9001 weight=2; }
权重越大访问次数就越多,比如这里端口9000的访问次数是1/3,端口9001访问次数是2/3
配置超时时间
location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $http_host; proxy_pass http://tnblog_phone; proxy_connect_timeout 6;#超时时间(秒) }
使用proxy_connect_timeout即可
此配置意思是,每个从Nginx分发的请求,连接到后台(服务器1)的连接如果超过6秒,则视为连接失败,Nginx会将此请求分发到另一台服务器。在一段时期内(默认应该是1分钟),后续的请求都不会再发送到(服务器1)了。过了一段时期后再送请求,又有可能把请求发送到(服务器1)。此时,只要超时一次,则在往后一段时间内不再往(服务器1)分发。
nginx 服务器重启命令,关闭
nginx -s stop : 关闭命令
nginx -s reopen :重新打开日志文件
nginx -t -c /path/to/nginx.conf 测试nginx配置文件是否正确
nginx -s reload :修改配置后重新加载生效
但是这样会存在一个单点故障,就是nginx服务器挂了后,集群都不能用了
可以使用dns和nginx配合的负载均衡,去掉单点故障,没有必要都要经过一个服务器转发,直接通过dns把请求转发到不同的服务器上
当然可以是一个nginx服务器
nginx配置负载均衡注意事项:http://www.tnblog.net/aojiancc2/article/details/141
niginx处理静态资源:http://www.tnblog.net/aojiancc2/article/details/2478