nginx-tomcat负载均衡redis-session共享。静态资源分离

基本环境:

redis-2.8

apache-tomcat-6.0.41

nginx1.6.2

1。redis配置

1,配置redis訪问password

到redis的文件夹下找的redis.conf,解开requirepass凝视(此属性用于设置password)。

如:

requirepass root

2,启动redis

到redis的文件夹以后台执行的方式启动redis

redis-server /root/redis-2.8.9/redis.conf &

2,tomcat准备工作

1,准备tomcat应用server

部署一个应用到tomcat,将里面的须要静态处理的文件,比如img。单独存放在一个文件夹下,如static以下。

将用户产生的媒体文件存放到一个共用的文件夹下,如/data/media下。后面用nginx配置处理。

2。加入tomcat和redis做session共享的jar包

在tomcat自己的lib下加入session共享所需的jar包,须要注意tomcat的版本号相应。

commons-pool-1.6.jar

jedis-2.1.0.jar

tomcat-redis-session-manager-1.2-tomcat-6.jar

3,改动tomcat的context.xml配置

到tomcat的conf文件夹下找到context.xml配置文件,在标签<Context>下加入:

  1. <!-- 利用redis 进行session 共享 -->
  2. <Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve" />
  3. <Manager className="com.radiadesign.catalina.session.RedisSessionManager"
  4. host="127.0.0.1"
  5. port="6379"
  6. password="root"
  7. database="0"
  8. maxInactiveInterval="3600"/>

提供的配置中默认没有password属性。我们能够查看tomcat-redis-session-manager-1.2-tomcat-6.jar的源代码,能够在RedisSessionManager.class中找的password属性。

4。复制tomcat改动各个tomcat的port

配置完了tomcat和redis共享的配置之后,我们就能够将此tomcat复制多份,然后改动tomcat的port。如:

tomcat1:Server port="8005",Connector port="8080"。ajp Connector port="8009"

tomcat2:Server port="8006"。Connector port="8081",ajp Connector port="8010"

tomcat3:Server port="8007",Connector port="8082",ajp Connector port="8011"

3。nginx配置

1,凝视默认訪问

在ngix的nginx/conf.d/下有个default.conf。将里面的listen 80 default_server改为:

listen 80;

2,在加入须要负载的应用server

在ngix的nginx/conf.d/的创建一个conf,如test.conf。在里面加入upstream pool配置段。将各个须要负载server的地址填到以下:

  1. upstream pool{
  2. server 127.0.0.1:8080;
  3. server 127.0.0.1:8081;
  4. server 127.0.0.1:8082;
  5. }

3,配置訪问域名

继续在test.conf中加入:

  1. server {
  2. listen 80 default_server;
  3. server_name www.test.cn;
  4. gzip on;
  5. gzip_min_length  1k;
  6. gzip_buffers     4 16k;
  7. gzip_http_version 1.0;
  8. gzip_comp_level 2;
  9. gzip_types  text/plain application/x-javascript text/css application/xml;
  10. gzip_vary on;
  11. location / {
  12. proxy_set_header Host $host;
  13. proxy_set_header X-Forwarded-For $remote_addr;
  14. proxy_connect_timeout   3;
  15. proxy_send_timeout      30;
  16. proxy_read_timeout      30;
  17. proxy_pass http://pool;
  18. }
  19. error_page 500 502 503 504 /50x.html;
  20. location = /50x.html{
  21. root /home/workspace/server/apache-tomcat-6.0.41-8080/webapps/test;
  22. }
  23. if ($host != 'www.test.cn' ){
  24. rewrite ^/(.*)$ http://www.test.cn/$1 permanent;
  25. }
  26. }

4,配置静态资源訪问

  1. server {
  2. listen 80;
  3. server_name static.test.cn;
  4. location /static {
  5. root /home/workspace/server/apache-tomcat-6.0.41-8080/webapps/test;
  6. }
  7. location /media {
  8. root /home/workspace/file;
  9. }
  10. }

5,改动请求体的大小

在http {}里添加 client_max_body_size属性。此属性会影响非常多的地方,比如上传。

client_max_body_size 100m;

4。启动nginx和tomcat,測试

測试负载均衡:

启动nginx和全部tomcat。然后到网页登录,然后启动还有一个tomcat,关闭上一个。查看是否还能訪问。开启全部tomcat用工具发起大量请求,查看请求是否被分发到各个tomcat。

測试session共享:

启动nginx和一个tomcat。然后到网页登录,然后启动还有一个tomcat,关闭上一个。查看是否还在登录状态。

nginx-tomcat负载均衡redis-session共享,静态资源分离的更多相关文章

  1. nginx+tomcat负载均衡和session复制

    本文介绍下传统的tomcat负载均衡和session复制. session复制是基于JVM内存的,当然在当今的互联网大数据时代,有更好的替代方案,如将session数据保存在Redis中. 1.安装n ...

  2. 使用nginx做负载均衡的session共享问题

    查了一些资料,看了一些别人写的文档,总结如下,实现nginx session的共享PHP服务器有多台,用nginx做负载均衡,这样同一个IP访问同一个页面会被分配到不同的服务器上,如果session不 ...

  3. Nginx和Tomcat负载均衡实现session共享(转)

    以前的项目使用Nginx作为反向代理实现了多个Tomcat的负载均衡,为了实现多个Tomcat之间的session共享,使用了开源的Memcached-Session-Manager框架. 此框架的优 ...

  4. Nginx和Tomcat负载均衡实现session共享

    以前的项目使用Nginx作为反向代理实现了多个Tomcat的负载均衡,为了实现多个Tomcat之间的session共享,使用了开源的Memcached-Session-Manager框架. 此框架的优 ...

  5. linux+nginx+tomcat负载均衡,实现session同步

    第一部分:nginx反向代理tomcat 一.软件及环境 软件 系统 角色 用途 安装的软件 ip地址 Centos6.5x86_64 nginx 反向代理用户请求 nginx 172.16.249. ...

  6. Tomcat 负载均衡 及Session共享

    原文:https://www.sunjianhua.cn/archives/tomcat-high-availability.html 一.安装java环境 二.安装tomcat(apache-tom ...

  7. nginx+tomcat+redis负载均衡及session共享

    概述 本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.o ...

  8. keepalived+nginx+tomcat+redis实现负载均衡和session共享(原创)

    keepalived+nginx+tomcat+redis实现负载均衡和session共享 直接上链接,码了一天,就不再重写了,希望能帮到大家,有问题欢迎留言交流.

  9. nginx tomcat负载均衡 使用redis session共享

    环境准备 1.准备一台nginx服务器 ip192.168.1.133 端口81 安装过程: #首先安装依赖: yum -y install gcc-c++ yum -y install pcre p ...

  10. haproxy+tomcat实现负载均衡以及session共享(linux centos7环境)

    一.安装HAProxy 1.进入home目录,下载最新haproxy安装包. cd /home wget http://haproxy.1wt.eu/download/1.4/src/haproxy- ...

随机推荐

  1. micropython陀螺仪控制舵机

    2018-03-1220:14:00 import pyb import time from pyb import Pin xlights = (pyb.LED(2),pyb.LED(3)) MO = ...

  2. mongo 3.4分片集群系列之六:详解配置数据库

    这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...

  3. 动态代理在WEB与JDBC开发中的应用

    WEB案例 目前有一个2005年开始,基于Struts1的Web项目A,其验证部分依赖于主站的SSO(单点登录).在请求站点A的时候,用户会被强制带去做SSO验证,通过身份验证后后,主站会自动地把请求 ...

  4. Java———较大二进制文件的读、写

    由于项目需要,需要对二进制文件进行读写.转换. 文件说明:由其他程序得到的二进制文件,文件内容为:包含23543个三角形.13270个顶点的三角网所对应的721组流速矢量(u.v)文件,通俗些说,一条 ...

  5. Windows提高_2.1第一部分:线程

    第一部分:线程 什么是线程? 线程其实可以理解为一段正在执行中的代码,它最少由一个线程内核对象和一个栈组成. 线程之间是没有从属关系的,同一进程下的所有线程都可以访问进程内的所有内容. 主线程其实是创 ...

  6. 梦想MxWeb3D协同设计平台 2019.01.24更新

    SDK开发包下载地址:http://www.mxdraw.com/ndetail_10124.html1.  编写快速入门教程2.  重构前端代码,支持一个页面多个三维控件同时加载,或二维和三维同时加 ...

  7. 04C语言输入输出

    C语言输入输出 输入字符getchar() #include <stdio.h> int main(){ putchar(getchar()); putchar(getchar()); ; ...

  8. 07Java Server Pages

    Java Server Pages JSP是一种Java servlet,主要用于实现Java web应用程序的用户界面部分. JSP全称Java Server Pages,是一种动态网页开发技术.它 ...

  9. CSDN怎么转载别人的博客

    在参考"如何快速转载CSDN中的博客"后,由于自己不懂html以及markdown相关知识,所以花了一些时间来弄明白怎么转载博客,以下为转载CSDN博客步骤和一些知识小笔记. 参考 ...

  10. [USACO] 打井 Watering Hole

    题目描述 Farmer John has decided to bring water to his N (1 <= N <= 300) pastures which are conven ...