1、下载
下载地址为:http://nginx.org/en/download.html
这里我们下载1.13.7版本,具体版本自己把握。(1.13之后支持websocket)
2、启动
下载的压缩包解压之后如图所示:
nginx解压目录
这里conf文件夹里面主要存放的一些配置文件,logs文件夹里面主要存放日志文件,刚开始主要使用这两个文件夹里面的东西。
可以看到一个可执行文件nginx.exe。双击之后就能启动nginx了。也可以使用命令start nginx启动,重启命令:nginx -s reload
nginx的默认端口是80,我们在浏览器窗口输入localhost查看是否出现如下界面:
我这里已经修改了端口为8080,所以访问的是localhost:8080
出现如上界面,则说明nginx已经启动成功了。
3、简单的负载均衡
这里使用最简单的启动两个tomcat来实现负载均衡。首先我们启动两个toncat,并且为了区分在主页上做了一些修改,如下图所示:
第一个tomcat,标注the first toncat
第二个tomcat,标注the second toncat
然后我们用编辑器打开conf文件夹下的nginx.conf文件
首先我们在http的上下文中配置一个upstream,
#负载的server
upstream tomcat_server{
server 127.0.0.1:8081 ;
server 127.0.0.1:8082 ;
}
分别表示负载的两个tomcat。然后在server的上下文中配置一个location:
server {
listen 80;
location /tomcat/ {
proxy_passhttp://tomcat_server/;
}
}
proxy_pass配置为上面upstream的名字。
这个时候我们访问http://localhost/tomcat/,会发现交替出现两个tomcat,说明负载均衡已经起作用。如下图:
第一次访问
第二次访问
到此为止,一个最简单的负载两个tomcat的demo已经完成。
4、负载均衡的实现方式
4.1、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
4.2、weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
4.3、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
4.4、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
4.5、url_hash(第三方)
按访问url的hash结果来分配请求,使同样的url定向到同一个后端服务器,后端服务器为缓存时比较有效
5、其他的一些配置
首先我们来看一个配置文件:
max_fails=1 fail_timeout=600s表示失败1次后就认为在之后的10分钟中该server已经down掉;还可以配置backup,则设置该server为备份服务器,当其他的server都down的时候,才会访问这台服务器。
接下里我们看一个完整的server上下文:
稍微完整的server上下文配置
上图中的proxy_next_upstream这个配置表示为发生后面的错误后直接请求下一个sever(注意这里读请求的时候没有问题,但可能在写请求的时候容易出问题)这里本来还有一个配置项timeout,如果配置了timeout一旦出现了超时,去访问下一个server的,有多少个server就访问多少次,这就回造成一直访问失败,超时。
在模拟一台服务器down的时候,迅速切换另一台的时候,刚开始总是很慢,后来才发现是proxy_connect_timeout这个配置的问题,配置1秒则是连接1秒没有响应就切换到另一台服务,proxy_read_timeout和proxy_send_timeout则是连接成功后读和写的超时时间。
使用中还发现负载均衡时websocke无法连接,一直返回400错误。后来发现需要配置几个配置项,在负载均衡中要使用websocket必须加配置才可以,就是如上图中的三行配置。
6.session问题
使用负载均衡的时候会出现session不同步的问题,导致无法登陆等一系列操作。我们使用redis来保存session,
如何使用redis(windows环境下),把图一中的三个配置文件覆盖到图二的同名字的配置文件,然后点击图三的start.bat文件启动redis
图一
图二
图三
然后在项目配置文件中配置如下:
7、附上一份详细的配置文件(以下三张图转载自https://www.coderknock.com/blog/2016/04/28/nginx.conf.html)