1.为什么要用nginx做负载均衡?

首先我们要知道用单机tomcat做的网站,比较理想的状态下能够承受的并发访问在150到200,

按照并发访问量占总用户数的5%到10%技术,单点tomcat的用户人数在1500到4000左右。这样显

然是不够的,为了解决这个问题我们就可以采用负载均衡的方法。

    1.1为什么采用nginx?

成本低,不同于硬负载,成本基本为0。

nginx能够支持高达50000个并发连接数的响应

2.什么是反向代理?反向代理与正向代理的区别

这里不多赘述了,比较简单,大家可以参考文章:

https://blog.csdn.net/m13666368773/article/details/8060481

3.nginx如何实现反向代理?

3.1正确安装nginx,比较简单,不做过多赘述,下面是正确安装后的目录结构

首先双击执行nginx,执行后在任务管理器中查看进程,如果有如下两个进程说明ngnix服务器已正常启动

访问localhost:80,可以看到如下界面:

3.2 进行反向代理配置

在conf目录中找到nginx.conf文件。用记事本打开,可以看到如下配置:

      我们之所有直接通过localhost:80能访问到页面就是因为这段配置

很明显listen代表的是nginx监听的端口,server_name代表ip或者域名,location / {..}这段配

置代表默认主页,最后一段配置代表的是错误页面。

然后介绍下反向代理的配置(以配置tomcat的反向代理为例),如下:

配置完成后我们会发现,现在直接访问localhost:80时显示的不是之前的页面了,而是tomcat的主

页,这样我们就完成了反向代理,当用户访问时,我们通过nginx从tomcat取得数据并返回给用户,

这就是通过nginx完成反向代理。

4.怎么用nginx实现负载均衡

如果理解了反向代理的配置,这个配置就很简单了。具体配置如下:

可以看到其他的配置都没有变,只不过在之前反向代理的列表中多加了一个tomcat的访问路径。

在测试的时候发现nginx服务器一直无法启动,然后在错误日志中查了下发现:

实际上上面的配置  weigth后应该有个等号,修改后如下:

这样一来,每当客户访问localhost:80(nginx服务器时),nginx服务器会随机将请求分发给列表中的

tomcat进行处理,这样我们就完成了对基于nginx负载均衡的配置

5.但是完成负载均衡后,问题又来了,session怎么办?我们总不能每分配

一次服务器就让用户登陆一次吧?这个就是session共享问题

其实解决session共享问题的方案很多,我这里只给出一种,就是使用redis实现session共享,核心思想就是:

将每个tomcat独立管理的session统一存储到redis中管理.大致原理图如下:

步骤如下:

1.下载nginx+tomcat集群+redis实现session共享工具包,下载地址

https://github.com/jcoleman/tomcat-redis-session-manager/downloads

2.其他需要的依赖

将以上四个包copy到tomcat的lib目录下(集群中的所有Tomcat都需要有这四个jar)

3.在tomcat/conf/context.xml文件中添加配置(集群中的所有Tomcat都需要配置)

注意:

1.按照如上配置,使用redis数据库,放入session中的对象必须要实现java.io.Serializable接口,使用memcache的可以不用实现Serializable接口

原因是:因为tomcat里使用的将session放置redis使用的工具类,是使用的jdk序列化模式存储的,这一点也是很容易理解的,session.setAttribute(String key, Object value),存储Object类型

object放入redis中又要能取出来,只能是序列化进行存储了,然后取出的时候进行反序列化。

所以我们在session中存储的任何对象,都必须实现序列化接口。

2.按照如上配置,使用redis做session存储空间时,web应用的session-time的时间单位会变成[秒],而不是原本的[分]

原因是:因为tomcat里使用的将session放置redis使用的工具类,在存储时为对tomcat容器时间做转换,

在redis中设置过期时间是使用秒作为单位的,有个命令叫expire可以设置redis键值过期时间,所以在context.xml配置文件中我们需要制定session过期时间(默认是60秒,配成1800即30分钟),这一点很重要。

nginx反向代理做负载均衡以及使用redis实现session共享配置详解的更多相关文章

  1. nginx反向代理、负载均衡以及分布式下的session保持

    [前言]部署服务器用到了nginx,相比较于apache并发能力更强,优点也比其多得多.虽然我的项目可能用不到这么多性能,还是部署一个流行的服务器吧! 此篇博文主要学习nginx(ingine x)的 ...

  2. Nginx反向代理,负载均衡,redis session共享,keepalived高可用

    相关知识自行搜索,直接上干货... 使用的资源: nginx主服务器一台,nginx备服务器一台,使用keepalived进行宕机切换. tomcat服务器两台,由nginx进行反向代理和负载均衡,此 ...

  3. 【转】Nginx反向代理和负载均衡

    原文链接:http://www.cnblogs.com/shuoer/p/7820899.html Nginx反向代理和负载均衡 环境说明 由于我使用的是windows系统,所以我用虚拟机虚拟出来了3 ...

  4. 谁说前端不需要懂-Nginx反向代理与负载均衡

    转:https://juejin.im/post/5b01336af265da0b8a67e5c9 学到老活到老 前端圈一直很新,一直要不停的学习,而且在进入大厂的路上,还要求熟悉一门后台语言等等.用 ...

  5. 基于Nginx反向代理及负载均衡

    基于Nginx反向代理及负载均衡 参考:http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass 只要没有被启用,默认就是 ...

  6. (二)Nginx反向代理与负载均衡的实现

    引言:nginx正向代理与反向代理在上一篇文章中已经谈论过,这里狗尾草主要告诉大家Nginx对前端的小伙伴来说在工作中如何简单的使用. 1.0什么是反向代理 当我们有一个服务器集群,并且服务器集群中的 ...

  7. Nginx反向代理与负载均衡应用实践(二)

    Nginx反向代理与负载均衡应用实践(二) 链接:https://pan.baidu.com/s/1xB20bnuanh0Avs4kwRpSXQ 提取码:migq 复制这段内容后打开百度网盘手机App ...

  8. Nginx反向代理与负载均衡应用实践(一)

    Nginx反向代理与负载均衡应用实践(一) 链接:https://pan.baidu.com/s/1xB20bnuanh0Avs4kwRpSXQ 提取码:migq 复制这段内容后打开百度网盘手机App ...

  9. Nginx反向代理实现负载均衡配置图解

    Nginx反向代理实现负载均衡配置图解 [导读] 负载均衡配置是超大型机器需要考虑的一些问题,同时也是数据安全的一种做法,下面我来介绍在nginx中反向代理 负载均衡配置图解,大家可参考本文章来操作. ...

随机推荐

  1. cxGrid增加一栏显示checkBox的设置方法

    鉴于本人首次设定cxGrid的CheckBox的时候费了很大劲,发现很多人都会碰到这个问题,现在总结一下,以供各位互相学习借鉴. 步骤如下(不分先后): 1. cxGrid添加完自己所需的所有字段后, ...

  2. python从零开始基础入门——开发环境搭建:Visual Studio Code

    前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:山海皆可平z PS:如有需要Python学习资料的小伙伴可以加点击下方 ...

  3. stand up meeting 12/21/2015

    part 组员                工作              工作耗时/h 明日计划 工作耗时/h    UI 冯晓云  完成PDF UI主页面的页面切换功能,待完善    4  完善 ...

  4. redis: 其他数据类型(八)

    1.geospatial 地理位置 有效的经度从-180度到180度 有效的纬度从-85.05112878度到85.05112878度 当坐标位置超出上述指定范围时,该命令将会返回一个错误 底层实现原 ...

  5. python web的进化历程

    对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. 阶段1 socket服务端和客户端都自己编写 实现访问8080端口,返回一个'hello wo ...

  6. 百度paddlepaddle学习体会

    一个偶然从微信公众号中刷到了<python小白逆袭A1大神>的文章,让我不经意的邂逅了飞桨(paddlepaddle),通过加入飞桨训练营一周的学习.实践,对飞桨有了很多的了解(飞桨官网: ...

  7. 2019-2020-1 20199329《Linux内核原理与分析》第五周作业

    <Linux内核原理与分析>第五周作业 一.上周问题总结: 虚拟机将c文件汇编成汇编文件时忘记添加include<stdio.h> gdb跟踪汇编过程不熟练 二.本周学习内容: ...

  8. 2019-2020-1 20199329 第二周测试(环境:ubuntu64位)

    2019-2020-1 20199329 第二周测试(环境:ubuntu64位) 实验一 0.每个.c一个文件,每个.h一个文件,文件名中最好有自己的学号 1.用Vi输入图中代码,并用gcc编译通过 ...

  9. Taro 2.2 全面插件化,支持拓展和定制个性化功能

    自 2.2 开始,Taro 引入了插件化机制,允许开发者通过编写插件的方式来为 Taro 拓展更多功能或者为自身业务定制个性化功能,欢迎大家进行尝试,共同讨论~ 当前版本 2.2.1 官方插件 Tar ...

  10. 如何在Spring boot中修改默认端口

    文章目录 介绍 使用Property文件 在程序中指定 使用命令行参数 值生效的顺序 如何在Spring boot中修改默认端口 介绍 Spring boot为应用程序提供了很多属性的默认值.但是有时 ...