Nginx除了可以用作web服务器外,他还可以用来做高性能的反向代理服务器,它能提供稳定高效的负载均衡解决方案。nginx可以用轮询、IP哈希、URL哈希等方式调度后端服务器,同时也能提供健康检查功能。目前有众多公司均已经部署使用nginx实现基于七层的负载均衡功能。
1)Nginx负载均衡 为了实现Nginx的反向代理以及负载均衡功能,应用中需要用到两个模块,HttpProxyModule和HttpUpstreamModule模块;其中HttpProxyModule模块的作用是将用户的数据请求转发到其他服务器上,HttpUpstreamModule模块是提供负载均衡技术。
Nginx目前提供的负载均衡算法: a)ngx_http_upstream_round_robin:加权轮询,可均分请求,是默认算法,集成在框架中。 b)ngx_http_upstream_ip_hash_module:IP哈希,可保持会话。 c)ngx_http_upstream_least_conn_module:最少连接数,可均分连接。 d)ngx_http_upstream_hash_module:一致性哈希,可减少缓存数据的失效。
nginx的upstream负载均衡目前支持的几种方式: 1)轮询(默认) 默认选项,当weight不指定时,各服务器weight相同, 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)weight 指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。如果后端服务器down掉,能自动剔除。 比如下面配置,则1.11服务器的访问量为1.10服务器的两倍(后端节点中配置高的服务器可以适当将weight设置大点)。
3)ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session不能跨服务器的问题,实现session共享。如果后端服务器down掉,要手工处理。
4)fair(第三方插件) 按后端服务器的响应时间来分配请求,响应时间短的优先分配。
5)url_hash(第三方插件) 按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存服务器时比较有效。 在upstream中加入hash语句,hash_method是使用的hash算法。
设备的状态: down 表示单前的server暂时不参与负载 weight 权重,默认为1。 weight越大,负载的权重就越大。 max_fails 允许请求失败的次数默认为1。当超过最大次数时,返回proxy_next_upstream 模块定义的错误 fail_timeout max_fails次失败后,暂停的时间。 backup 备用服务器, 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。
下面是负载均衡实现原理拓扑图(多层负载)
Nginx反向代理模块配置方法示例说明:
Nginx负载均衡模块配置方法示例说明:
2)Nginx负载均衡案例解析 服务器名称 网路配置 nginx.test.com eth0:111.122.155.133 eth1:192.168.1.2 web1.test.com eht0:192.168.1.3 web2.test.com eth0:192.168.1.4 web3.test.com eth0:192.168.1.5
3台web机器配置:
在web1 web2 web3上安装httpd并配置网卡。操作步骤如下:(下面是web1的操作,web2和web3的操作步骤类似。注意修改红色部分的参数) # vim /etc/sysconfig/network-scripts/ifcfg-eth0
接着执行下面命令:
nginx代理服务器配置
# vim /etc/sysconfig/network-scripts/ifcfg-eth0
# vim /etc/sysconfig/network-scripts/ifcfg-eth1
接着执行下面命令:
接着修改nginx配置文件 # vim /usr/local/nginx/conf/nginx.conf
配置完成执行:
最后浏览器访问http://192.168.1.2 或者http://111.122.155.133 刷新将分别得到不同的web页面信息
3)Nginx rewrite规则 nginx的rewrite语法格式和apache非常相似,rewrite regex replacement [flag],其中flag可以被设置为last结束当前指令并重新搜索location匹配、break结束当前rewrite指令、redirect临时重定向302、permanent永久重定向301。
rewrite地址重写及return应用的语法解析: 根据浏览器标识,访问资源重定向到指定文件目录,下面用IE浏览器示例:
将移动客户端的请求重定向到其他服务器:
用户使用POST方式请求数据时候,返回405:
访问admin时候重定向到admin目录:
——————————————-下面详细说下nginx的rewrite重写指令用法——————————————- nginx通过ngx_http_rewrite_module模块支持url重写、支持if条件判断,但不支持else。 该模块需要PCRE支持,因此应在编译nginx时指定PCRE源码目录, nginx安装方法。
1)Nginx Rewrite 基本标记 (flags)
2)正则表达式匹配,其中:
3)文件及目录匹配,其中:
4)Nginx的一些可用的全局变量,可用做条件判断:
nginx的rewrite指令执行顺序:
break指令 语法:break; 默认值:无 作用域:server,location,if
停止执行当前虚拟主机的后续rewrite指令集。 break指令实例:
if指令 语法:if(condition){…} 默认值:无 作用域:server,location 对给定的条件condition进行判断。如果为真,大括号内的rewrite指令将被执行。 if条件(conditon)可以是如下任何内容:
if指令实例:
return指令
rewrite指令
rewrite实例说明:
如果这些rewrite放到 “/download/” location如下所示, 那么应使用break而不是last , 使用last将循环10次匹配,然后返回500错误:
对于重写后的URL(replacement)包含原请求的请求参数,原URL的?后的内容。如果不想带原请求的参数 , 可以在replacement后加一个问号。如下,我们加了一个自定义的参数user=$1,然后在结尾处放了一个问号?, 把原请的参数去掉。
如果正则表达regex式中包含 “}” 或 “;”, 那么整个表达式需要用双引号或单引号包围.
rewrite_log指令
nginx打开rewrite log的配置:
set指令
uninitialized_variable_warn指令
根据文件类型expires
—————————————-Nginx多Server反向代理配置—————————————- Nginx强大的正则表达式支持可以使server_name的配置变得很灵活。比如说想要做多用户博客,那么每个用户都会拥有自己的二级域名,这样的话,可以灵活利用server_name配置也是很容易就实现的。
Nginx将按照上面1),2),3),4)的顺序对server name进行匹配,只要有一项匹配以后就会停止搜索,所以在使用这个指令的时候一定要分清楚它的匹配顺序(类似于location指令)。 server_name指令一项很实用的功能便是可以在使用正则表达式的捕获功能,这样可以尽量精简配置文件,毕竟太长的配置文件日常维护也很不方便。
下面是2个具体的应用:
1)在一个server块中配置多个站点:
2)在一个server块中为一个站点配置多个二级域名 。 实际网站目录结构中通常会为站点的二级域名独立创建一个目录,同样可以使用正则的捕获来实现在一个server块中配置多个二级域名:
多个正则表达式 如果你在server_name中用了正则,而下面的location字段又使用了正则匹配,这样将无法使用$1,$2这样的引用,解决方法是通过set指令将其赋值给一个命名的变量:
Nginx不同域名反向代理到另一台服务器 proxy_pass和$host 想让一个VPS专门做另一个VPS的前端,后端VPS每添加一个域名,前端VPS就要同时添加一个域名来反向代理,作为前端的VPS如果一个一个的添加后端VPS的域名,那么这个事情特别麻烦,能不能让其自动反向代理后端VPS呢,用到proxy_pass和$host就可以轻松实现。 以下例子为了省事,以lnmp为安装环境进行设置,修改前端VPS的nginx.conf文件,修改成以下内容:
接着修改其他部分
这样就可以实现了前端VPS可以反向代理任意域名到后端VPS,只要将域名解析到前端VPS,后端VPS进行域名绑定,那么就可以直接访问到了。
一台nginx带多个域名多个tomcat情况的配置 多个域名,其中2个域名需支持泛域名解析: 1)www.abc.com 2)www.bcd.com 3)*.efg.com 4)*.hij.com 其中1),2),3)为一台tomcat,4)为独立tomcat。前端一台nginx,通过配置多个虚拟主机来实现该部署。 进入/usr/local/nginx/conf/vhost目录,所有虚拟主机的配置文件都在该目录下存放。
配置支持泛域名
Nginx 多域名配置 nginx绑定多个域名可又把多个域名规则写一个配置文件里,也可又分别建立多个域名配置文件,我一般为了管理方便,每个域名建一个文件,有些同类域名也可又写在一个总的配置文件里。
原文链接:https://cloud.tencent.com/developer/article/1027118