Mall电商项目总结(二)——nginx负载均衡配置和策略
1. nginx配置文件
用户在浏览器上输入,http://www.xwld.site/ 实际上是在访问服务器80端口,nginx 监听80端口,将用户的请求转发到8080和9080端口
. upstream www.xwld.site{
. server www.xwld.site:;
. server www.xwld.site:;
. }
. server {
. listen ;
. autoindex on;
. server_name www.xwld.site xwld.site;
. access_log /usr/local/nginx/logs/access.log combined;
. index index.html index.htm index.jsp index.php;
. if ( $query_string ~* ".*[\;'\<\>].*" ){
. return ;
. }
. location = / {
. root /product/front/mmall_fe/dist/view;
. index index.html;
. }
.
. location ~ .*\.html$ {
. root /product/front/mmall_fe/dist/view;
. index index.html;
. }
. location / {
. proxy_pass http://www.xwld.site/;
. }
. location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ {
. proxy_pass http://www.xwld.site;
. expires 30d;
. }
. location ~ .*\.(js|css)?$ {
. proxy_pass http://www.xwld.site;
. expires 7d;
. }
. }
nginx 配置负载均衡的时候,可以修改上面的配置文件,新增多个服务器ip,也可以指定客户端请求到服务器的对应策略
2. Nginx负载均衡配置策略
常见的策略有轮询、权重、ip_hash、fair等
2.1 轮询
默认就是轮询的方式,轮询的方式,每个请求会按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
优点
实现简单,不要配置
缺点
不考虑每台服务器处理能力。
示例:
upstream www.xwld.site{
server www.xwld.site:;
server www.xwld.site:;
}
2.2 权重(weight)
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况,在实际生产环境中用的最多。
优点
考虑的每台服务器处理能力的不同
如果,我们有两条linux服务器,有一台,配置比较高,那么这台高配置的服务器,应当要负担更多的请求。
示例:
upstream www.xwld.site{
server www.xwld.site: weight=;
server www.xwld.site: weight=;
}
上面的配置表示,访问8080端口的服务器的概率是访问9080端口的1.5倍。
2.3 ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
缺点是,ip_hash不一定平均,可能会造成某一台服务器的压力过大。
示例:
upstream www.xwld.site{
ip_hash;
server www.xwld.site:;
server www.xwld.site:;
}
2.4 least_conn(最少连接)
least_conn这种负载均衡策略,能把请求转发给连接数较少的后端服务器,适合请求处理时间长短不一造成服务器过载的情况。
有时候会出现这种情况,有些接口请求占用的时间很长,会导致其所在的后端服务负载过高。这种情况下,least_conn这种方式就可以达到更好的负载均衡效果。
示例:
upstream www.xwld.site{
least_conn;
server www.xwld.site:;
server www.xwld.site:;
}
2.5 fair(公平)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
fair属于第三方的负载均衡策略的实现,要使用这种策略,需要安装第三方插件。
示例:
upstream www.xwld.site{
server www.xwld.site:;
server www.xwld.site:;
fair;
}
2.6 url_hash
使用url_hash,可以使得同一个url(也就是同一个资源请求)会到达同一台服务器,一旦缓存住了资源,再此收到请求,就可以从缓存中读取
示例:
upstream www.xwld.site{
server www.xwld.site:;
server www.xwld.site:;
hash $request_uri;
}
Mall电商项目总结(二)——nginx负载均衡配置和策略的更多相关文章
- Nginx 负载均衡配置和策略
Nginx 的 HttpUpstreamModule 提供对后端(backend)server的简单负载均衡.一个最简单的 upstream 写法例如以下: upstream backend { se ...
- Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群
Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群 >>>>>>>>>>>> ...
- nginx高性能WEB服务器系列之六--nginx负载均衡配置+健康检查
nginx系列友情链接:nginx高性能WEB服务器系列之一简介及安装https://www.cnblogs.com/maxtgood/p/9597596.htmlnginx高性能WEB服务器系列之二 ...
- Tomcat服务部署与Nginx负载均衡配置
一.中间键产品介绍 目前来说IBM的WebSphere,Oracle的Weblogic占据了市场上java语言Web站点的部分份额,该两种软件都是商业化的软件,由于性能优越,可靠性高等优点应用于大型互 ...
- Nginx负载均衡配置简单配置方法
http://www.jb51.net/article/121235.htm Nginx作为负载均衡服务器,用户请求先到达nginx,再由nginx根据负载配置将请求转发至不同的Web服务器.下面通过 ...
- Docker 安装 Nginx 负载均衡配置
Docker 安装 # 1)安装依赖包 yum install -y yum-utils device-mapper-persistent-data lvm2 # 2)添加Docker软件包源(否则d ...
- Mall电商项目总结(一)——项目概述
项目概述 此电商项目为本人学习项目,后端 使用nginx实现负载均衡转发请求到多台tomcat服务器,使用多台 redis服务器分布式 缓存用户登录信息. 项目已经部署到阿里云服务器,从阿里云linu ...
- Nginx负载均衡配置实例详解
负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 负载均衡 先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可 ...
- Nginx负载均衡配置实例详解(转)
负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 负载均衡 先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可 ...
随机推荐
- Windows Phone 8 与 windows 8 开发技术概览
目前来说Windows phone 8的开发者 大家都是走战斗在在技术朋友,相信大家在做Windows Phone 8开发的同时也在关注Windows 8,我相信很多开发者一定是在 Windows 8 ...
- python中执行shell命令的几个方法
1.os.system() a=os.system("df -hT | awk 'NR==3{print $(NF-1)}'") 该命令会在页面上打印输出结果,但变量不会保留结果, ...
- android添加桌面悬浮窗
1. 添加权限 <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/> 2. ...
- jQuery使用on()绑定动态生成元素的事件无效
jquery on()方法是jquery1.7+后才使用的 由于需求:动态添加了以下代码 <tr class="pj" data-val="no"> ...
- [Android] 环境配置之Android Studio开发NDK
分类:Android环境搭建 (14351) (20) ========================================================作者:qiujuer博客:bl ...
- [反汇编练习] 160个CrackMe之032
[反汇编练习] 160个CrackMe之032. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...
- C#中异常处理和Java的区别
捕获异常,同样是try...catch...,这个完全一样: 抛出异常,同样是throw,这个完全一样: 函数抛出怎样的异常,Java中可以用throws定义,而C#中不用定义,相当于throws E ...
- LinearLayout具体解释三:LayoutInflater创建View过程分析
上次讲到以下这么一段代码,这段代码的作用就是解析xml文件成为view并显示到屏幕上的. @Override //设置contentview,也就是activity或fragment载入视图,即vie ...
- 今日BBC
1.随身英语 Brain training 怎样训练大脑? link 2.地道英语 In good nick 品质好.没有损坏(主要是指古老的东西,比方古董) link 3.今日新闻 -------- ...
- Linux问题,磁盘分区打不开了
Metadata kept in Windows cache, refused to mount. chkdsk /f http://www.bubuko.com/infodetail-1184937 ...