nginx是一款轻量级的web服务器,常用的作用为服务器/反向代理服务器以及电子邮件(IMAP/POP3)代理服务器

1.为什么我们要使用Nginx?

  • 反向代理:

    反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。

  • 负载均衡:负载均衡,英文名称为Load Balance,是指建立在现有网络结构之上,并提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。其原理就是数据流量分摊到多个服务器上执行,减轻每台服务器的压力,多台服务器共同完成工作任务,从而提高了数据的吞吐量.
  • 动静分离:将静态的资源放到反向服务器,节省用户的访问时间.

2.如何使用nginx?

  • 在Windows上使用Nginx搭建Tomcat服务器

    • 在windows上使用nginx方法审视简单,下载windows的nginx解压,执行nginx.exe即可访问地址localhost
    • 在windows上搭建tomcat集群的软件准备 两个tomcat和一个nginx,注意修改tomcat1的端口和tomcat2的端口,否则端口冲突启动不了 这里我是修改为tomcat1为8080,tomcat2为8090
    • 启动  nginx 和 tomcat1 和tomcat2
    • 准备一个简单的javaweb项目testsession,内容只有一个index.jsp,内容如下
      <%@ page language="java" contentType="text/html; charset=UTF-8"
      pageEncoding="UTF-8"%>
      <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
      <html>
      <head>
      <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
      <title>Insert title here</title>
      </head>
      <body> tomcat1放在tomcat1下-----放在tomcat2下就是2(为了区分用) 此次请求的<%=request.getRequestedSessionId() %>
      </body>
      </html>
    • 将此项目放在tomcat1的webapps下和tomcat2的webapps下
    • 配置nginx  修改nginx下的conf文件夹中nginx.conf

      • 需要在http节点上添加一个

        upstream servlet_jimisun{
        server 127.0.0.1:8080;//后面端口是tomcat1的端口
        server 127.0.0.1:8090;//后面端口是tomcat2的端口
        }
      • 在location /节点下
        proxy_pass http://servlet_jimisun;
      • 访问地址localhost/testsession  (注意并没有访问tomcat的端口,而是访问的80端口,nginx将请求转发给tomcat1和tomcat2
      • windows上通过nginx部署tomcat集群完成......(有问题的)
      • 注意Session共享问题:SessionID是不一样的,每一次请求都会创建一个新的Session,这样显然不符合我们的要求

3.如何解决通过nginx部署tomcat集群的Session共享问题

  • 解决Session共享方法1(仅限于windows):

    • 修改tomcat的server.xml 支持共享

      将 引擎标签下的 
      
      <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
      注释去掉
    • 修改项目的web.xml    在web.xml中添加一个节点
      <distributable/>
    • 此时tomcat1的sessionid和tomcat2的sessionid是一样的 都会认为是一次请求
  • 解决Session共享方法2:将session的id放入redis中
  • 解决Session共享方法3:保证一个ip地址永远访问一台tomcat服务器,就不存在session共享问题了,在upstream中添加
    ip_hash;

    这样刷新多少次本ip只会访问由nginx通过ip_hash算出的tomcat2服务器,这样就不存在session共享问题了

 

当前:nginx有更高深的用法;还有tomcat集群有更多问题需要去解决,小生不才windows集群只能给大家讲到这里,如有问题,敬请指正!

nginx的简单使用和使用nginx在windows上搭建tomcat集群的更多相关文章

  1. 利用nginx搭建tomcat集群

    1.tomcat集群 利用nginx对请求进行分流,将请求平均的分给不同的tomcat去处理,减少单个tomcat的负载量,提高tomcat的响应速度. 2.创建多个tomcat服务器(同一个服务器上 ...

  2. linux搭建tomcat集群+nginx

    安装JDK 一.官方下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 下 ...

  3. Tengine(nginx) 搭建Tomcat集群

    好久没有更新学习的内容了,就是得强迫自己写点东西 记录自己的学习,才能更好的进步! Tengine是由淘宝网发起的Web服务器项目.它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和 ...

  4. 使用nginx搭建tomcat集群配置

    软件准备: (1)jdk-8u73-linux-x64.tar.gz (2)apache-tomcat-7.0.57.tar.gz (3)nginx-1.7.7.tar.gz 准备3台Linux机器, ...

  5. Docker如何使用nginx搭建tomcat集群

    首先创建tomcat的文件夹 , 为了方便docker的配置 我这里直接在根目录中创建 第一步:创建文件夹:发布文件夹 mkdir -p /docker/tomcat/webapp8081 mkdir ...

  6. docker+nginx搭建tomcat集群(附录)——nginx.conf文件

    附录:nginx.conf修改后的文件内容 user root;worker_processes 2; #error_log logs/error.log;#error_log logs/error. ...

  7. Docker+nginx搭建tomcat集群

    1.环境准备: a.宿主机CentOS7 b.连接工具FinalShell c.镜像nginx1.20.1,tomcat (镜像拉取:docker pull 镜像名称) 2.创建nginx文件夹,to ...

  8. tomcat集群搭建集成nginx负载均衡

    软件基础+版本: 1.3台centos7系统,其中都已经配置完成了jdk环境,jdk的版本为 [root@node03 bin]# java -version java version "1 ...

  9. Tomcat集群 Nginx负载均衡 shell脚本实时监控Nginx

    第一步,安装Tomcat 系统环境:Centos7 第1步:下载tomcat安装包 tomcat官网:https://tomcat.apache.org/ 第2步:安装包上传至linux中 第3步:下 ...

随机推荐

  1. 解决 scrapy 爬虫出现Forbidden by robots.txt

    我们在爬取网站的时候,scrapy  默认的是遵循  robots.txt 协议,怎么破解这个文件 操作很简单,找到setting 文件 直接改成

  2. 响应式布局框架 Pure-CSS 5.0 示例中文版-上

    0. Pure-CSS 介绍 Pure CSS 是雅虎出品的 CSS 框架, 依托于Normalize.CSS,在不适用任何JS代码情况下即可实现响应式布局的轻量级框架,无依赖,体积小. 1. CDN ...

  3. CWidgetMgr---H

    /************************************************************************/ //管理部件 //部件自动根据Z顺序调整消息的优先 ...

  4. js生成二维码的jquery组件–qrcode

    js生成二维码的jquery组件–qrcode 2015/01/30 / 2508 VIEWS / JAVASCRIPT, JQUERY 有一些耗cpu的计算,完全可以在客户端上计算,比如生成二维码. ...

  5. oracle 使用occi方式 批量插入多条数据

    if (vecInfo.empty()) { ; //数据为空,不上传,不上传标志设置为1,只有0表示上传成功 } std::string strUserName = userName; std::s ...

  6. 折腾kali linux2.0

    偶然的机会了解到了kali linux这个用于渗透测试的linux发行版,于是就从官网下了iso,但是制作启动盘老出错.网上查了下说在linux下用dd命令特别简单,于是转到ubuntu下制作启动盘, ...

  7. 一款纯css3实现的超炫3D表单

    今天要给大家分享一款纯css3实现的超炫3D表单.该特效页面的加载的时候3d四十五度倾斜,当鼠标经过的时候表单动画回正.效果非常炫,一起看下效果图: 在线预览   源码下载 实现的代码. html代码 ...

  8. string--C++ STL 学习

    C++STL提供了string基本字符系列容器来处理字符串,可以把string理解为字符串类,提供了添加删除\替换\查找和比较等丰富的方法. 使用string容器,需要包含头文件声明#include ...

  9. Android基础总结(二)布局,存储

    常见布局 相对布局 RelativeLayout 组件默认左对齐.顶部对齐 设置组件在指定组件的右边 android:layout_toRightOf="@id/tv1" 设置在指 ...

  10. 关于webRTC中video的使用实践

    此次demo使用chrome49调试测试 前端在操作视频输入,音频输入,输出上一直是比较弱的,或者说很难进行相关的操作,经过我最近的一些研究发现,在PC上实际上是可以实现这一系列的功能的,其实现原理主 ...