1 前言

1.1 目的

为了正确的部署“ngix+memcached”特编写此部署手册,使安装人员可以通过部署手册知道如何部署系统,也为需要安装该系统的安装人员正确、快速的部署本系统提供帮助。

1.2 总体架构图

当一个请求结束时,session会被送回Memcached进行备份。当下一次请求开始时,本地Session可用,直接服务,请求结束后,session又被送回Memcached备份。如果下一次请求会被路由到其他Tomcat上。负责处理此此请求的Tomcat并不清楚Session的信息。此时它会从Memcached查找该Session,更新该Session并将其保存在本机内容。此次请求结束,session被修改,送回Memcached备份。

1.2.1 术语1

1.2.2 术语2

2 安装环境要求

2.1 网络环境要求

网络带宽要求10M 到100M。

2.2 硬件环境要求

设备

主机名

配置

功能

1

PC服务器环境

CPU:2*8核(最小4C),内存:32GB(最小16GB)

应用服务器器A

2.3 软件环境要求

软件类型

软件名

版本号

相关说明

操作系统

Windows Server2008以上

Windows Server2008

64位

数据库

Oracle

11.0.2

中间件

Tomcat

8.0

JDK

JDK

1.8

3 基础软硬件系统安装

3.1 硬件拓扑

【编写提示:说明应用系统运行的硬件拓扑,应当包括硬件环境要求中列出的所有硬件设备。】

3.2 软件部署

主机名

操作系统

系统软件

部署的应用

Web应用服务器

Windows server 2008

Jdk1.8

Tomcat8.0

应用程序

数据库服务器

Windows server 2008

Oracle 11.0.2

数据库

4 安装部署过程

4.1 安装概述

1、安装Java

2、安装nginx

3、Nginx代理配置

4、安装memcached(可选)

5、配置tomcat

4.2 基于tomcat中间件的集群部署(Windows环境)

4.2.1 Memcached+tomcat+nginx

4.2.1.1 安装java

1)         点击jdk1.8.exe文件,进入安装界面,按照导航,一步步安装完毕

2)         配置环境变量

3)         验证jdk是否安装成功

CMD窗口输入java –version,如果出现上图,则表示jdk安装成功

4.2.1.2 Nginx的安装部署

1)         下载nginx,并解压

2)         启动nginx

在命令窗口进入到nginx的解压目录(路径不能包含中文),运行以下命令:

start niginx

启动成功后,可以通过nginx –t查看nginx是否启动成功

如果出现上述successful,则代表启动成功

3)         配置nginx.conf文件,增加以下代码段

upstream 127.0.0.1 {

#设定负载均衡的服务器列表

ip_hash;

#同一机器在多网情况下,路由切换,ip可能不同 #weigth参数表示权值,权值越高被分配到的几率越大

server 127.0.0.2:8080 weight=1 max_fails=20 fail_timeout=600s;

server 127.0.0.3:8080 weight=2 max_fails=20 fail_timeout=600s;

……

#此处省略server,有几个server,就添加几个

}

map $http_upgrade $connection_upgrade {

default upgrade;

'' close;

}

server {

listen 80;

server_name 127.0.0.1;

charset UTF-8;

#设定本虚拟主机的访问日志

access_log  logs/host.access.log  main;

#对 "/" 所有应用启用负载均衡

location / {

proxy_pass http://127.0.0.1;

#保留用户真实信息

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

proxy_http_version 1.1;

proxy_set_header Upgrade $http_upgrade;

proxy_set_header Connection "upgrade";

index  index.html index.htm index.aspx demo.jsp;

}

}

以上配置文件有5个地方需要修改,已用黄色进行标志

①   upstream 127.0.0.1                            设置upstream的名称

②   ip_hash;      设置是否进行ip映射,关闭则前面加#,设置后同一个session访问同一台服务器

③   server 127.0.0.2:8080             设置代理的服务器IP,可以为多个

④   server_name 127.0.0.1                    与①设置的名称要保持一致

⑤   proxy_pass http://127.0.0.1;                    设置访问的ip地址

index  index.html index.htm index.aspx demo.jsp    设置访问页地址

4.2.1.3 memcached的安装部署(选装)

安装前提:如果nginx的步骤ip_hash设置了,则此步骤可以不用安装。

在此解释下为什么ip_hash设置后,不用安装memcached了,因为nginx做ip_hash之后,同一个session的请求会发往同一台服务器。假如不设置,则会发往不同的应用服务器,造成session不同步。

1) 安装memcached

下载memcached,并解压,右键以管理员身份打开cmd命令,进入解压目录,并运行以下启动命令:

memcached.exe –d install

2) 启动memcached

进入到memcached解压目录,运行以下命令:

memcached.exe –p 11211 –d start

其中11211为memcached的默认端口,启动成功后,在任务管理器中可以查看到,也可以在服务中查看到该服务,如下图:

4.2.1.4 TOMCAT的集群部署(memcached部署可选,步骤1和2为memcached安装启动后操作,若未安装,则不用执行步骤1和2)

1) 将session共享需要的依赖包放到tomcat的lib文件夹下

2) 配置TOMCAT的memcached的关联

3) 应用服务器部署tomcat

在大于等于2台的应用服务器部署tomcat,启动tomcat

4) 执行nginx的刷新命令

进入nginx的解压路径,执行nginx –s reload

5) 在浏览器输入网址:

http://nginx服务器地址/首页地址

4.2.1.5 测试是否正确安装

1、修改完后,重新reload  nginx:nginx -s reload

2、添加测试jsp:demo.jsp

3、启动所有的tomcat

4、打开web浏览器,测试

 注意:因某些限制,最新源代码和后续通用配置实现数据抽取 已放置在笔者公众号上,请关注微信公众号: 大喇叭学数据库, 回复关键字:【nginx】,获取本例安装程序


nginx和tomcat 反向代理 部署实例 直接运行的更多相关文章

  1. Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点

    上一篇分享了 Nginx + Tomcat 反向代理 负载均衡 集群 部署指南,感觉还是相当实用型的,但是一般集群部署是基于大访问量的,可能有的企业用不到,类似一些企业官网,访问量并不是很大,基于这个 ...

  2. nginx反向代理部署vue项目(history模式)的方法

    前言: 根据标题我们要区分出两个信息 1. history 模式部署 ( vue的路由模式如果使用history,刷新会报404错误.) 2. Nginx 做反向代理 问题1思考: vue-route ...

  3. Nginx之搭建反向代理实现tomcat分布式集群

    参考博文: Nginx反向代理实现Tomcat分布式集群 1. jdk 安装 jdk 下载网址: http://www.oracle.com/technetwork/java/javase/downl ...

  4. nginx反向代理部署springboot项目报404无法加载静态资源

    问题:nginx反向代理部署springboot项目报404无法加载静态资源(css,js,jpg,png...) springboot默认启动端口为8080,如果需要通过域名(不加端口号)直接访问s ...

  5. 五、Nginx多Server反向代理配置

    Nginx强大的正则表达式支持,可以使server_name的配置变得很灵活,如果你要做多用户博客,那么每个用户拥有自己的二级域名也就很容易实现了. server_name的匹配顺序 Nginx中的s ...

  6. Nginx 之六: Nginx服务器的反向代理功能

    一:Nginx作为正向代理服务器: 1.正向代理:代理(proxy)服务也可以称为是正向代理,指的是将服务器部署在公司的网关,代理公司内部员工上外网的请求,可以起到一定的安全作用和管理限制作用,正向代 ...

  7. nginx 为什么要反向代理 影藏后端 高效连接(给nginx,他自己返回) 端口冲突解决 多个服务

    nginx 为什么要反向代理  影藏后端   高效连接(给nginx,他自己返回)  端口冲突解决  多个服务 单机使用反向代理可以根据不同url匹配到不同站点   rsync 的工作原理和应用实例 ...

  8. Nginx介绍与反向代理

    Nginx的产生 没有听过Nginx?那么一定听过它的"同行"Apache吧!Nginx同Apache一样都是一种WEB服务器.基于REST架构风格,以统一资源描述符(Unifor ...

  9. 【转】Nginx服务器的反向代理proxy_pass配置方法讲解

    [转]Nginx服务器的反向代理proxy_pass配置方法讲解 转自:http://www.jb51.net/article/78746.htm 就普通的反向代理来讲Nginx的配置还是比较简单的, ...

  10. nginx是一个反向代理的软件

    nginx只是一个反向代理的软件,和语言无关,理论上支持任何Web平台,当然http://Asp.net也不例外,http://51aspx.com就是http://Asp.net开发的,前端暴漏的是 ...

随机推荐

  1. 手撕红黑树 | 变色+旋转你真的明白了吗?【超用心超详细图文解释 | 一篇学会Red_Black_Tree】

    说在前面 我们也很久没有更新数据结构系列了,半年前博主重新深入学习了红黑树这个数据结构,一直想更新呈现给大家,最近也一直没有时间,今天红黑树它来了! 博主为了这篇博客,做了很多准备,试了很多画图软件, ...

  2. 目录:CH57x/CH58x/CH59x/CH32V208低功耗蓝牙应用

    外设相关: CH59x 系统16位PWM使用 - 小舟从此逝_1 - 博客园 (cnblogs.com) CH59X/CH58X/CH57X PWM使用 - 小舟从此逝_1 - 博客园 (cnblog ...

  3. Linux NFS挂载报错wrong fs type, bad option, bad superblock

    1.故障现象 2.解决方案 1.故障现象 我的测试环境有一个NAS,之前配置都是按照测试需求在/etc/fstab里添加配置挂载选项: vi /etc/fstab 192.168.1.2:/mnt/H ...

  4. delphi TThread.WaitFor 用法

    在 Delphi 中,TThread.WaitFor 方法用于等待一个线程完成执行.当你创建一个线程并希望主线程(或其他线程)等待这个线程结束时,你可以使用这个方法. 以下是 TThread.Wait ...

  5. JS leetcode 寻找数组的中心索引 题解分析

    壹 ❀ 引 今天是的题目来自leetcode的724. 寻找数组的中心索引,做完之后我感觉自己像个憨憨,题目描述如下: 给定一个整数类型的数组 nums,请编写一个能够返回数组"中心索引&q ...

  6. NC22494 选点

    题目链接 题目 题目描述 有一棵n个节点的二叉树,1为根节点,每个节点有一个值wi.现在要选出尽量多的点. 对于任意一棵子树,都要满足: 如果选了根节点的话,在这棵子树内选的其他的点都要比根节点的值大 ...

  7. NC24608 [USACO 2011 Ope S]Learning Languages

    题目链接 题目 题目描述 Farmer John's N (2 <= N <= 10,000) cows, conveniently numbered 1..N, are fluent i ...

  8. 轻松玩转Makefile | 企业项目级Makefile实例

    前言 本文展示了一个比较完整的企业项目级别的Makefile文件,包括了:文件调用,源文件.头文件.库文件指定,软件版本号.宏定义,编译时间,自动目录等内容. 1.目录架构 本文中所采用的目录架构,在 ...

  9. 【Unity3D】分离路面导航

    1 前言 ​ 导航系统中介绍了导航的基本用法,但是不能解决分离路面导航问题.如下图,胶囊体需要导航到立方体位置,但是路面不连续,烘焙(Bake)导航网格后,断开处也没有导航网格,因此,胶囊体导航到分离 ...

  10. mysql存储过程实战

    今天科比离去,今天肺炎病毒持续肆虐... 意识到生命的脆弱,今天我继续前行,比以往更加坚定和紧迫,这辈子不活好自己就算白来一趟. 最近需要用到mysql存储过程去处理一些表数据,然后利用java po ...