千家信息网

nginx+tomcat怎么使用redis session共享

发表于:2025-01-24 作者:千家信息网编辑
千家信息网最后更新 2025年01月24日,这篇文章主要讲解了"nginx+tomcat怎么使用redis session共享",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"nginx+tomca
千家信息网最后更新 2025年01月24日nginx+tomcat怎么使用redis session共享

这篇文章主要讲解了"nginx+tomcat怎么使用redis session共享",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"nginx+tomcat怎么使用redis session共享"吧!

环境准备

1、准备一台nginx服务器 ip192.168.1.133 端口81

安装过程:

#首先安装依赖:yum -y install gcc-c++ yum -y install pcre pcre-devel yum -y install zlib zlib-devel yum -y install openssl openssl-devel#注意 : 安装nginx必须使用 root 用户安装#创建一个nginx目录mkdir /usr/local/src/nginx#进入到nginx目录cd /usr/local/src/nginx#下载或上传安装包wget http://nginx.org/download/nginx.tar.gz 或 rz上传#解压安装包tar -xvf nginx.tar.gz#进入到解压后的目录cd nginx# 下面 才开始正式安装#把nginx安装到指定用户的目录mkdir -p /ucenter/soft/nginx#安装配置 prefix为安装目录 user为用户 group为 组./configure --prefix=/ucenter/soft/nginx --user=ucenter --group=ucenter#编译make #安装make install#在linux系统中由于非root用户不能占用80端口,所以需要使普通用户以root身份启动nginx。 cd /ucenter/soft/nginx/sbin#把soft文件下所有的文件所属者修改为ucener -r 表示递归chown ucenter:ucenter ./soft/ -r#修改 ./nginx 的所属为rootchown root nginx#让普通用户可以使用80端口,可以使用root权限启用nginxchmod u+s nginx#修改配置文件 在修改配置文件之前 ,要备份该文件cd conf/# 要注意nginx 的工作进程,一般根据cpu的核数去修改vim nginx.conf#关闭防火墙,打开80端口service iptables stop#启动nginx./nginx#重启nginx./nginx -s reload#关闭nginx./nginx -s stop

准备一台tomcat服务器,先准备java环境,安装jdk步骤省略

然后分别安装3个tomcat 服务器ip地址:192.168.1.143,tomcat1 8080端口,tomcat2 8081端口,tomcat3 8082端口。

apache-tomcat-7.0.64/conf/server.xml配置文件修改这三个地方,这样端口就不会冲突

修改tomcat root目录下index.jsp,分别增加每个tomcat的标识,以及在页面上显示session id

<%--licensed to the apache software foundation (asf) under one or morecontributor license agreements. see the notice file distributed withthis work for additional information regarding copyright ownership.the asf licenses this file to you under the apache license, version 2.0(the "license"); you may not use this file except in compliance withthe license. you may obtain a copy of the license at http://www.apache.org/licenses/license-2.0unless required by applicable law or agreed to in writing, softwaredistributed under the license is distributed on an "as is" basis,without warranties or conditions of any kind, either express or implied.see the license for the specific language governing permissions andlimitations under the license.--%><%@ page session="true" %><%java.text.simpledateformat sdf = new java.text.simpledateformat("yyyy");request.setattribute("year", sdf.format(new java.util.date()));request.setattribute("tomcaturl", "http://tomcat.apache.org/");request.setattribute("tomcatdocurl", "/docs/");request.setattribute("tomcatexamplesurl", "/examples/");%>   <%=request.getservletcontext().getserverinfo() %>          

${pagecontext.servletcontext.serverinfo}--8080

if you're seeing this, you've successfully installed tomcat. congratulations!


managing tomcat

for security, access to the manager webapp is restricted. users are defined in:

$catalina_home/conf/tomcat-users.xml

in tomcat 7.0 access to the manager application is split between different users. read more...


release notes

changelog

migration guide

security notices

documentation

tomcat 7.0 documentation

tomcat 7.0 configuration

tomcat wiki

find additional important configuration information in:

$catalina_home/running.txt

developers may be interested in:

getting help

faq and mailing lists

the following mailing lists are available:


copyright ©1999-${year} apache software foundation. all rights reserved

这时候 修改nginx配置文件nginx.conf,把三台tomcat的ip地址以及端口号加入进去,使用nginx做代理

#user nobody;worker_processes 1;#error_log logs/error.log;#error_log logs/error.log notice;#error_log logs/error.log info;#pid  logs/nginx.pid;events { worker_connections 1024;}http { include  mime.types; default_type application/octet-stream; #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' #     '$status $body_bytes_sent "$http_referer" ' #     '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile  on; #tcp_nopush  on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; upstream localhost1 {      #ip_hash;    server 192.168.1.143:8080;    server 192.168.1.143:8081;    server 192.168.1.143:8082;  }  server {  listen  81;  server_name localhost;  #charset koi8-r;  #access_log logs/host.access.log main;  location / {    proxy_connect_timeout 3;     proxy_send_timeout  30;     proxy_read_timeout  30;     proxy_pass http://localhost1;   }  #error_page 404    /404.html;  # redirect server error pages to the static page /50x.html  #  error_page 500 502 503 504 /50x.html;  location = /50x.html {   root html;  }  # proxy the php scripts to apache listening on 127.0.0.1:80  #  #location ~ \.php$ {  # proxy_pass http://127.0.0.1;  #}  # pass the php scripts to fastcgi server listening on 127.0.0.1:9000  #  #location ~ \.php$ {  # root   html;  # fastcgi_pass 127.0.0.1:9000;  # fastcgi_index index.php;  # fastcgi_param script_filename /scripts$fastcgi_script_name;  # include  fastcgi_params;  #}  # deny access to .htaccess files, if apache's document root  # concurs with nginx's one  #  #location ~ /\.ht {  # deny all;  #} } # another virtual host using mix of ip-, name-, and port-based configuration # #server { # listen  8000; # listen  somename:8080; # server_name somename alias another.alias; # location / { #  root html; #  index index.html index.htm; # } #} # https server # #server { # listen  443; # server_name localhost; # ssl     on; # ssl_certificate  cert.pem; # ssl_certificate_key cert.key; # ssl_session_timeout 5m; # ssl_protocols sslv2 sslv3 tlsv1; # ssl_ciphers high:!anull:!md5; # ssl_prefer_server_ciphers on; # location / { #  root html; #  index index.html index.htm; # } #}}

这时候,分别启动三台tomcat以及nginx,访问,这时候每次刷新页面,都会随机访问8080或者8081或者8082,而且页面上出现的session id也都是不一样的,我们应该如何让这三台tomcat共享session呢,我们使用redis来做。

这时候,在已经按照三台tomcat的服务器192.168.1.143上,安装redis,安装步骤如下:

$ wget http://download.redis.io/releases/redis-3.2.3.tar.gz$ tar xzf redis-3.2.3.tar.gz$ cd redis-3.2.3$ make malloc=libc#启动redis src前面是安装的路径$ src/redis-server &#关闭redissrc/redis-cli shutdown#使用redis 放入键值对 key value$ src/redis-cli127.0.0.1:6379> set foo barok127.0.0.1:6379> get foo"bar"$

安装完redis之后,在三个tomcat的lib文件夹内分别上传这五个所依赖的jar,分别是

commons-pool2-2.0.jar

jedis-2.5.2.jar

tomcat-redis-session-manager1.2.jar

tomcat-juli.jar

tomcat-juli-adapters.jar

所有jar在这里了,

然后分别修个三个tomcat的context.xml文件,增加如下的配置

  web-inf/web.xml      

这时候,分别重启三个tomcat以及nginx,查看tomcat日志之后,发现没有任何异常报错,说明我们成功了,接下来开始测试。

我们访问nginx服务器地址:

得到的是8080端口的 tomcat1 ,session id为1a0625767f27ba95ef4d5f061fe0568d

这时候按f5刷新页面,得到的是8081端口的 tomcat2 ,session id依旧是 1a0625767f27ba95ef4d5f061fe0568d

再次刷新页面,得到的是8082端口的 tomcat3,session id依旧是 1a0625767f27ba95ef4d5f061fe0568d。 、

这时候,说明我们搭建tomcat + nginx负载均衡 + redis session同步成功啦!

nginx帮助把我们的请求均匀的分发给三个tomcat --》tomcat1 、tomcat2以及tomcat3

redis帮助我们同步session,这样一来,我们的服务器性能就会提高许多,任何一台tomcat发生故障后,对整体的服务都不会有影响了。

感谢各位的阅读,以上就是"nginx+tomcat怎么使用redis session共享"的内容了,经过本文的学习后,相信大家对nginx+tomcat怎么使用redis session共享这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

端口 文件 服务 服务器 用户 目录 配置 三个 页面 三台 准备 地址 学习 普通 成功 内容 所属 步骤 环境 同步 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 杭州湖畔网络技术 收银机本地数据库打开错误 买一个网络技术公司 民航网络安全与信息化论坛材料 怎样解密网络安全准入助手 查看dns服务器地址 软件开发过程的分析过程不包括 路由器CSDP服务器 数据库指定文件的增长方式 网络安全等级保护测评资质 数据库会自动保存回车吗 计算机网络技术学考题目 给数据库导入data文件 大连市网络安全基地 棋牌软件开发学校 计算网络技术题库 机器学习服务器的优缺点 西藏软件开发品牌 计算机网络技术基础 徐红 为什么想进入软件开发销售行业 博途opc服务器接口的作用 服务器是否开启硬盘的缓存 深圳蓝谷网络技术公司 我国最新网络技术 网络安全态势感知需求 网络安全工程师需要四级证书吗 软件开发文档扫描证件 重庆蚁众驾软件开发有限公司 打印机服务器脱机啥意思 湖湘杯网络安全大赛初赛试题
0