nginx常见应用实例
1、nginx 中 location 应用实例
location 是 nginx 的精华,nginx 就是通过拦截到的请求去对配置好的 location 块(location block)进行请求代理的,location 就是用来具体配置代理路径的。
2、nginx反向代理应用实例
1>环境说明:centos7.4
192.168.129.128 proxy-server(nginx)
192.168.129.129 web-server(httpd)
2>准备测试web服务器环境
web-server安装httpd
[root@web-server ~]# yum install -y httpd
3>提供web测试页面
[root@web-server ~]# echo "<h1>web.test.com</h1>" > /var/www/html/index.html
[root@web-server ~]# vim /etc/httpd/conf/httpd.conf
ServerName www.example.com: //去掉该行注释
4>启动httpd服务
[root@web-server1 ~]# systemctl start httpd
[root@web-server2 ~]# systemctl start httpd
5>访问测试web-server服务器
6>配置 http 反向代理
[root@proxy-server ~]# vim /apps/nginx/conf/www.proxy.com.conf //该文件间接include指向/etc/nginx/nginx.conf中的httpd模块
server {
listen ;
server_name www.proxy.com;
location / {
proxy_pass http://192.168.129.129;
}
}
[root@proxy-server ~]# systemctl restart nginx
7>配置本地域名解析,访问测试

3、 nginx负载均衡配置实例
由于前面,nginx 只代理了后端一台服务器,但由于我们网站名气大涨访问的人越来越多一台服务器实在是顶不住,于是我们加了多台服务器,那么多台服务器又怎么配置代理呢,我们这里以两台服务器为案例,来配置 nginx 负载均衡。
1>环境说明:centos7.4
192.168.129.128 balanced-server(nginx)
192.168.129.129 web-server1(httpd)
192.168.129.130 web-server2(httpd)
2>准备web测试环境,提供测试页面,启动服务
web-server1、web-server2分别安装httpd
[root@web-server1 ~]# yum install -y httpd
[root@web-server1 ~]# echo "<h1>web1.test.com</h1>" > /var/www/html/index.html
[root@web-server1 ~]# vim /etc/httpd/conf/httpd.conf
ServerName www.example.com:80 //去掉该行注释
[root@web-server1 ~]# systemctl start httpd
[root@web-server2 ~]# yum install -y httpd
[root@web-server2 ~]# echo "<h1>web2.test.com</h1>" > /var/www/html/index.html
[root@web-server2 ~]# vim /etc/httpd/conf/httpd.conf
ServerName www.example.com: //去掉该行注释
[root@web-server1 ~]# systemctl start httpd
3>访问测试web-server服务器


4>配置nginx负载均衡
[root@balanced-server ~]# vim /apps/nginx/conf/www.balanced.com.conf //该文件间接include指向/etc/nginx/nginx.conf中的httpd模块
#设定负载均衡的服务器列表
upstream test.net {
ip_hash;
server 192.168.129.129:;
server 192.168.129.130:;
}
server {
listen ;
server_name www.balanced;
location / {
proxy_pass http://test.net;
}
}
[root@balanced-server ~]# systemctl restart nginx
注意请先停掉配置的其他server虚拟主机,以防产生冲突;
upstream 是 Nginx 的 HTTP Upstream 模块,这个模块通过一个简单的调度算法来实现客户端 IP 到后端服务器的负载均衡。在上面的设定中,通过 upstream 指令指定了一个负载均衡器的名称 test.net。这个名称可以任意指定,在后面需要用到的地方直接调用即可。
5>配置本地域名解析,访问测试

停掉web-server1,再进行访问测试
[root@web-server1 ~]# systemctl stop httpd

6>拓展:upstream 支持的负载均衡算法
nginx 的负载均衡模块目前支持 4 种调度算法,下面进行分别介绍,其中后两项属于第三方调度算法。
(1)轮询(默认),每个请求按时间顺序逐一分配到不同的后端服务器,如果后端某台服务器宕机,故障系统被自动剔除,使用户访问不受影响。Weight 指定轮询权值,Weight 值越大,分配到的访问机率越高,主要用于后端每个服务器性能不均的情况下。
upstream test.net {
......;
server 192.168.129.129: weight=; //该server有1/3的访问概率
server 192.168.129.130: weight=; //该server有2/3的访问概率
}
(2)ip_hash,每个请求按访问 IP 的 hash 结果分配,这样来自同一个 IP 的访客固定访问一个后端服务器,有效解决了动态网页存在的 session 共享问题。
(3)fair,这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。Nginx 本身是不支持 fair 的,如果需要使用这种调度算法,必须下载 Nginx 的upstream_fair 模块。
(4)url_hash,此方法按访问 url 的 hash 结果来分配请求,使每个 url 定向到同一个后端服务器,可以进一步提高后端缓存服务器的效率。Nginx 本身是不支持 url_hash 的,如果需要使用这种调度算法,必须安装 Nginx 的 hash 软件包。
7>upstream 支持的状态参数
在 HTTP Upstream 模块中,可以通过 server 指令指定后端服务器的 IP 地址和端口,同时还可以设定每个后端服务器在负载均衡调度中的状态。
常用的状态有:
down,表示当前的 server 暂时不参与负载均衡。
backup,预留的备份机器。当其他所有的非 backup 机器出现故障或者忙的时候,才会请求backup 机器,因此这台机器的压力最轻。
max_fails,允许请求失败的次数,默认为 1。当超过最大次数时,返回 proxy_next_upstream模块定义的错误。
fail_timeout,在经历了 max_fails 次失败后,暂停服务的时间。max_fails 可以和 fail_timeout一起使用。
max_fails,允许请求失败的次数,默认为 1。当超过最大次数时,返回 proxy_next_upstream模块定义的错误;fail_timeout,在经历了 max_fails 次失败后,暂停服务的时间。max_fails 可以和 fail_timeout一起使用,进行健康状态检查。再配置一个backup,防止所有的服务器都不能提供服务。
注意:当负载调度算法为 ip_hash 时,后端服务器在负载均衡调度中的状态不能是 weight和backup。
nginx常见应用实例的更多相关文章
- php中的curl使用入门教程和常见用法实例
摘要: [目录] php中的curl使用入门教程和常见用法实例 一.curl的优势 二.curl的简单使用步骤 三.错误处理 四.获取curl请求的具体信息 五.使用curl发送post请求 六.文件 ...
- Nginx详解二十五:Nginx架构篇之Nginx常见的问题
Nginx常见的问题 1.相同server_name多个虚拟主机优先级访问,是按读取文件的优先级来排序 在/opt/app/下准备3个code文件夹,下面放入3个html文件,里面的内容分别是code ...
- Nginx常见错误与问题之解决方法技术指南
Nginx常见错误与问题之解决方法技术指南. 安装环境: 系统环境:redhat enterprise 6.5 64bit 1.Nginx 常见启动错误 有的时候初次安装nginx的时候会报这样的 ...
- 轻量级HTTP服务器Nginx(常用配置实例)
轻量级HTTP服务器Nginx(常用配置实例) 文章来源于南非蚂蚁 Nginx作为一个HTTP服务器,在功能实现方面和性能方面都表现得非常卓越,完全可以与Apache相媲美,几乎可以实现Apa ...
- Nginx 负载均衡实例redis
Nginx 负载均衡实例redis 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
- Nginx常见的安装方式
Nginx常见的安装方式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Nginx概述 Nginx的安装版本分为开发版.稳定版和过期版, Nginx安装可以使用yum或源码安装 ...
- 【python库模块】Python subprocess模块功能与常见用法实例详解
前言 这篇文章主要介绍了Python subprocess模块功能与常见用法,结合实例形式详细分析了subprocess模块功能.常用函数相关使用技巧. 参考 1. Python subprocess ...
- Nginx+Tomcat多实例及负载均衡配置
Nginx+Tomcat多实例及负载均衡配置 采用nginx的反向代理负载均衡功能,配合后端的tomcat多实例来实现tomcat WEB服务的负载均衡 01 安装nginx服务 安装所需的pcre库 ...
- Keepalived+Nginx高可用实例
Keepalived+Nginx高可用实例 注意事项: 1.VIP不需要在服务器网络配置文件中配置. 2.nginx主不可用时,需要kill掉nginx主的keepalived服务,这样才可以实现VI ...
随机推荐
- 30 HashSet
/* * 使用HashSet存储字符串并遍历 * * Set的特点: * 无序(存储和读取的顺序可能不一样) * 不允许重复 * 没有整数索引 于List正好相反 */ public class Ha ...
- iOS 头条一面 面试题
1.如何高效的切圆角? 切圆角共有以下三种方案: cornerRadius + masksToBounds:适用于单个视图或视图不在列表上且量级较小的情况,会导致离屏渲染. CAShapeLayer+ ...
- 【Java】抽象类、接口
什么是抽象类? 特点: - 抽象类几乎普通类一样,除了不能实例化 - 不能实例化不代表没有构造器,依然可以声明构造器,便于子类实例化调用 - 具有抽象方法的类,一定是抽象类 abstract 抽象的 ...
- 选择IT行业的自我心得,希望能帮助到各位!(六)
在这个社会,想做大事的人很多,但是很多事情也挺难做的,为什么说复杂的事情简单做,简单的事情重复做,这样一个人才能获得更多的优越品质,为啥说改变,人还是挺难过的,都知道本性难移,想改挺难得.在这个社会千 ...
- 【three.js第二课】页面自适应
1.在[three.js第一课]的基础上加入以下代码,改变窗口大小时,页面内容会自适应 //加入事件监听器,窗口自适应 window.addEventListener('resize', functi ...
- 惊呆了,Servlet Filter和Spring MVC Interceptor的实现居然这么简单
前言 创建型:单例模式,工厂模式,建造者模式,原型模式 结构型:桥接模式,代理模式,装饰器模式,适配器模式,门面模式,组合模式,享元模式 行为型:观察者模式,模板模式,策略模式,责任链模式,状态模式, ...
- 并查集判树 poj 1308
例题: poj 1308 题目大意比较简单,对任意两个点,有且仅有一条道路,也就是一棵树. 题解:一棵树中,肯定是不能有环的,而且只能由一个根节点.(没认真读题,只知道在那里判环....),所以这个题 ...
- ATcoder D - Handstand 2
题目大意: 给一个数N,在小于N的所有数中,找到(A,B)的数量,其中A的第一个数字要等于B的最后的一个数字,A的最后一个数字要等于B的第一个数字. 题解:对从1到N的所有数x,用一个二维数组保存dp ...
- 华为鲲鹏服务器安装 k3s+rancher
华为鲲鹏服务器安装 k3s+rancher 华为鲲鹏服务器 华为鲲鹏服务器采用华为自研cpu ARMv8架构,提供 Windows 和多个Linux 系统,作为服务器使用我一直使用Centos系统(不 ...
- http的长连接与端连接
长连接的定义: HTTP1.1规定了默认保持长连接(HTTP persistent connection ,也有翻译为持久连接),数据传输完成了保持TCP连接不断开(不发RST包.不四次握手),等待 ...