Tomcat多实例和负载均衡我希望起身时,你会轻轻帮我弹掉衣服上不容易发现的灰尘我希望写字时,手边的可乐一直是我喜欢的温度

一、Tomcat多实例

1.1 Tomcat多实例的步骤(理论) 1.安装好 jdk 2.安装 tomcat   cd /opt tar zxvf apache-tomcat-9.0.16.tar.gz mkdir /usr/local/tomcat mv apache-tomcat-9.0.16 /usr/local/tomcat/tomcat1 cp -a /usr/local/tomcat/tomcat1 /usr/local/tomcat/tomcat2   3.配置 tomcat 环境变量   vim /etc/profile.d/tomcat.sh #tomcat1 export CATALINA_HOME1=/usr/local/tomcat/tomcat1 export CATALINA_BASE1=/usr/local/tomcat/tomcat1 export TOMCAT_HOME1=/usr/local/tomcat/tomcat1   #tomcat2 export CATALINA_HOME2=/usr/local/tomcat/tomcat2 export CATALINA_BASE2=/usr/local/tomcat/tomcat2 export TOMCAT_HOME2=/usr/local/tomcat/tomcat2   source /etc/profile.d/tomcat.sh   4.修改 tomcat2 中的 server.xml 文件,要求各 tomcat 实例配置不能有重复的端口号   vim /usr/local/tomcat/tomcat2/conf/server.xml   <Server port="8006" shutdown="SHUTDOWN"> #22行,修改Server prot,默认为8005 -> 修改为8006 <Connector port="8081" protocol="HTTP/1.1" #69行,修改Connector port,HTTP/1.1 默认为8080 -> 修改为8081 <Connector port="8010" protocol="AJP/1.3" redirectPort="8443" /> #116行,修改Connector port AJP/1.3,默认为8009 -> 修改为8010   5.修改各 tomcat 实例中的 startup.sh 和 shutdown.sh 文件,添加 tomcat 环境变量   vim /usr/local/tomcat/tomcat1/bin/startup.sh # ----------------------------------------------------------------------------- # Start Script for the CATALINA Server # ----------------------------------------------------------------------------- ##添加以下内容 export CATALINA_BASE=$CATALINA_BASE1 export CATALINA_HOME=$CATALINA_HOME1 export TOMCAT_HOME=$TOMCAT_HOME1   vim /usr/local/tomcat/tomcat1/bin/shutdown.sh # ----------------------------------------------------------------------------- # Stop script for the CATALINA Server # ----------------------------------------------------------------------------- export CATALINA_BASE=$CATALINA_BASE1 export CATALINA_HOME=$CATALINA_HOME1 export TOMCAT_HOME=$TOMCAT_HOME1   vim /usr/local/tomcat/tomcat2/bin/startup.sh # ----------------------------------------------------------------------------- # Start Script for the CATALINA Server # ----------------------------------------------------------------------------- export CATALINA_BASE=$CATALINA_BASE2 export CATALINA_HOME=$CATALINA_HOME2 export TOMCAT_HOME=$TOMCAT_HOME2   vim /usr/local/tomcat/tomcat2/bin/shutdown.sh # ----------------------------------------------------------------------------- # Stop script for the CATALINA Server # ----------------------------------------------------------------------------- export CATALINA_BASE=$CATALINA_BASE2 export CATALINA_HOME=$CATALINA_HOME2 export TOMCAT_HOME=$TOMCAT_HOME2   6.启动各 tomcat 中的 /bin/startup.sh   /usr/local/tomcat/tomcat1/bin/startup.sh /usr/local/tomcat/tomcat2/bin/startup.sh   netstat -natp | grep java   7.浏览器访问测试 http://192.168.80.10:8080 http://192.168.80.10:8081 1.2 Tomcat多实例的具体实验步骤(实操) 第一步:放入安装关闭防火墙和selinux

第二步:安装JDK并设置环境变量 1)安装JKD

2)编写java脚本设置JDK环境变量

3)运行脚本文件,然后查看jdk版本

第三步:安装tomcat 1)解压缩tomcat

2)创建tomcat多实例的目录,并移动复制文件

第四步:配置tomcat环境变量 1)编写脚本

运行脚本文件

第五步:修改 tomcat2 中的 server.xml 文件,要求各 tomcat 实例配置不能有重复的端口号 1)修改主配置文件,修改Server prot,默认为8005 -> 修改为8006

2)修改Connector port,HTTP/1.1 默认为8080 -> 修改为8081

3)修改Connector port AJP/1.3,默认为8009 -> 修改为8010

第六步:修改各 tomcat 实例中的 startup.sh 和 shutdown.sh 文件,添加 tomcat 环境变量 1)修改tomcat1的startup.sh

2)修改tomcat1的shutdown.sh

3)修改tomcat2的startup.sh

4)修改tomcat2的shutdown.sh

第七步:启动各 tomcat 中的 /bin/startup.sh

第八步:浏览器中访问测试

二、Nginx+Tomcat负载均衡、动静分离

2.1 Nginx+Tomcat负载均衡、动静分离的步骤(理论) Nginx 服务器:192.168.153.50:80 Tomcat服务器1:192.168.153.60:8080 Tomcat服务器2:192.168.153.40:8080 192.168.153.40:8081   1.部署Nginx 负载均衡器   systemctl stop firewalld setenforce 0   yum -y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make   useradd -M -s /sbin/nologin nginx   cd /opt tar zxvf nginx-1.12.0.tar.gz -C /opt/   cd nginx-1.12.0/   ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-file-aio --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module --with-stream   make && make install   ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/   vim /lib/systemd/system/nginx.service   [Unit] Description=nginx After=network.target [Service] Type=forking PIDFile=/usr/local/nginx/logs/nginx.pid ExecStart=/usr/local/nginx/sbin/nginx ExecrReload=/bin/kill -s HUP $MAINPID ExecrStop=/bin/kill -s QUIT $MAINPID PrivateTmp=true [Install] WantedBy=multi-user.target   chmod 754 /lib/systemd/system/nginx.service systemctl start nginx.service systemctl enable nginx.service   2.部署2台Tomcat 应用服务器   systemctl stop firewalld setenforce 0   tar zxvf jdk-8u91-linux-x64.tar.gz -C /usr/local/   vim /etc/profile   export JAVA_HOME=/usr/local/jdk1.8.0_91 export JRE_HOME=$JAVA_HOME/jre export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib export PATH=$JAVA_HOME/bin:$PATH   source /etc/profile   tar zxvf apache-tomcat-8.5.16.tar.gz   mv /opt/apache-tomcat-8.5.16/ /usr/local/tomcat   /usr/local/tomcat/bin/shutdown.sh /usr/local/tomcat/bin/startup.sh   netstat -ntap | grep 8080   3.动静分离配置 (1)Tomcat1 server 配置   mkdir /usr/local/tomcat/webapps/test vim /usr/local/tomcat/webapps/test/index.jsp   <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <html> <head> <title>JSP test1 page</title> #指定为 test1 页面 </head> <body> <% out.println("动态页面 1,http://www.test1.com");%> </body> </html>   vim /usr/local/tomcat/conf/server.xml     <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> <Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true"> </Context> </Host>   /usr/local/tomcat/bin/shutdown.sh /usr/local/tomcat/bin/startup.sh   (2)Tomcat2 server 配置   mkdir /usr/local/tomcat/tomcat1/webapps/test /usr/local/tomcat/tomcat2/webapps/test   vim /usr/local/tomcat/tomcat1/webapps/test/index.jsp   <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <html> <head> <title>JSP test2 page</title> #指定为 test2 页面 </head> <body> <% out.println("动态页面 2,http://www.test2.com");%> </body> </html>     vim /usr/local/tomcat/tomcat1/conf/server.xml   #删除前面的 HOST 配置   <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> <Context docBase="/usr/local/tomcat/tomcat1/webapps/test" path="" reloadable="true" /> </Host>   /usr/local/tomcat/tomcat1/bin/shutdown.sh /usr/local/tomcat/tomcat1/bin/startup.sh     vim /usr/local/tomcat/tomcat2/webapps/test/index.jsp   <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <html> <head> <title>JSP test3 page</title> #指定为 test3 页面 </head> <body> <% out.println("动态页面 3,http://www.test3.com");%> </body> </html>   vim /usr/local/tomcat/tomcat2/conf/server.xml   #删除前面的 HOST 配置   <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> <Context docBase="/usr/local/tomcat/tomcat2/webapps/test" path="" reloadable="true" /> </Host>   /usr/local/tomcat/tomcat2/bin/shutdown.sh /usr/local/tomcat/tomcat2/bin/startup.sh (3)Nginx server 配置 #准备静态页面和静态图片   echo '<html><body><h1>这是静态页面</h1></body></html>' > /usr/local/nginx/html/index.html mkdir /usr/local/nginx/html/img cp /root/game.jpg /usr/local/nginx/html/img   vim /usr/local/nginx/conf/nginx.conf   ...... http { ...... #gzip on;   #配置负载均衡的服务器列表,weight参数表示权重,权重越高,被分配到的概率越大 upstream tomcat_server { server 192.168.153.60:8080 weight=1; server 192.168.153.40:8080 weight=1; server 192.168.153.40:8081 weight=1; }   server { listen 80; server_name www.kgc.com;   charset utf-8;   #access_log logs/host.access.log main;   #配置Nginx处理动态页面请求,将 .jsp文件请求转发到Tomcat 服务器处理 location ~ .*\.jsp$ { proxy_pass http://tomcat_server; #设置后端的Web服务器可以获取远程客户端的真实IP ##设定后端的Web服务器接收到的请求访问的主机名(域名或IP、端口),默认HOST的值为proxy_pass指令设置的主机名。如果反向代理服务器不重写该请求头的话,那么后端真实服务器在处理时会认为所有的请求都来在反向代理服务器,如果后端有防攻击策略的话,那么机器就被封掉了。 proxy_set_header HOST $host; ##把$remote_addr赋值给X-Real-IP,来获取源IP proxy_set_header X-Real-IP $remote_addr; ##在nginx 作为代理服务器时,设置的IP列表,会把经过的机器ip,代理机器ip都记录下来 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; }   #配置Nginx处理静态图片请求 location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|css)$ { root /usr/local/nginx/html/img; expires 1d; }   location / { root html; index index.html index.htm; } ...... } ...... }     4.测试效果 测试静态页面效果 浏览器访问 http://192.168.80.10/ 浏览器访问 http://192.168.80.10/game.jpg   测试负载均衡效果,不断刷新浏览器测试 浏览器访问 http://192.168.80.10/index.jsp 2.2 Nginx+Tomcat负载均衡、动静分离的具体实验步骤(实操) 第一步:准备好Nginx服务器(192.168.153.50),具体步骤参考:互联网最受欢迎的开源Web服务器软件——Nginx的搭建

第二步:准备好tomcat服务器(192.168.153.60:8080),具体步骤参考:必须要掌握的开源Web应用服务器—Tomcat服务部署和优化

第三步:准备好tomcat服务器的两个实例(192.168.153.40:8080和192.168.153.40:8081),具体步骤参考本文第一段

第四步:动静分离Tomcat1 server 配置 1)配置Tomcat1的动态网页显示内容

2)添加新的host内容

3)重启服务

第五步:Tomcat2 server 配置(实例一) 1)创建Tomcat实例1和Tomcat实例2的网页测试目录test和测试网页文件

2)Tomcat1主配置删除前面的 HOST 配置,添加新的HOST配置

3)重启服务

第五步:Tomcat2 server 配置(实例二) 1)创建Tomcat实例2的测试网页文件

2)Tomcat2主配置删除前面的 HOST 配置,添加新的HOST配置

3)重启服务

第六步:Nginx server 配置(192.168.153.50) 1)准备网页显示相关内容

2)修改配置

3)添加新的HOST

4)重新服务

第七步:浏览器中进行测试,动态页面测试进行不断刷新即可 测试结果一:静态页面

测试结果一:图片

测试结果二:动态页面test1

测试结果二:动态页面test2

测试结果二:动态页面test3

补充: Nginx 负载均衡模式: ●rr 负载均衡模式: 每个请求按时间顺序逐一分配到不同的后端服务器,如果超过了最大失败次数后(max_fails,默认1),在失效时间内(fail_timeout,默认10秒),该节点失效权重变为0,超过失效时间后,则恢复正常,或者全部节点都为down后,那么将所有节点都恢复为有效继续探测,一般来说rr可以根据权重来进行均匀分配。   ●least_conn 最少连接: 优先将客户端请求调度到当前连接最少的服务器。   ●ip_hash 负载均衡模式: 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题,但是ip_hash会造成负载不均,有的服务请求接受多,有的服务请求接受少,所以不建议采用ip_hash模式,session 共享问题可用后端服务的 session 共享代替 nginx 的 ip_hash。   ●fair(第三方)负载均衡模式: 按后端服务器的响应时间来分配请求,响应时间短的优先分配。   ●url_hash(第三方)负载均衡模式: 和ip_hash算法类似,是对每个请求按url的hash结果分配,使每个URL定向到一个同 一个后端服务器,但是也会造成分配不均的问题,这种模式后端服务器为缓存时比较好   Nginx 四层代理配置:   和http同等级:所以一般只在http上面一段设置, stream { log_format main '$remote_addr $upstream_addr - [$time_local] $status $upstream_bytes_sent'; access_log /var/log/nginx/k8s-access.log main;   upstream appserver{ server 192.168.80.100:8080 weight=1; server 192.168.80.101:8080 weight=1; server 192.168.80.101:8081 weight=1; } server { listen 8080; proxy_pass appserver; } }   http { ......   注:配置4层代理,记得在Nginx中添加 --with-stream 模块

原文地址:https://www.cnblogs.com/qwert19990410/p/15154966.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


&lt;servlet&gt; &lt;servlet-name&gt;tomcatpooljsp&lt;/servlet-name&gt; &lt;jsp-file&gt;/WEB-INF/tomcatpool.jsp&lt;/jsp-file&gt; &lt;/servlet&gt; &lt;servlet-mapping&gt; &lt;servlet-name&gt;tomcatpooljsp&lt;/servlet-nam...
遵循Java Servlet 规范第4节中的建议 ,Apache Tomcat实现了系统地重新加载Java类的方法,以允许在不重新启动整个服务器的情况下更新应用程序的组件。 此功能对于开发非常重要,因为事实证明,随着服务器启动和重启时间的延长,这会严重浪费开发人员的时间。实际上,Java EE堆栈应用服务器的服务器重新启动时间很慢,这是Tomcat广泛用于个人和企业级项目的推动力之一。但是,即使Tomcat也无法 像运行时重新加载应用程序一样快地启动。通过仅重新加载隔离的应用程序的更改的类,开发人员..
JMX(Java管理扩展)是一项非常强大的技术,可让您管理,监视和配置Tomcat MBean。如果您是Tomcat管理员,那么您应该熟悉如何在tomcat中启用JMX来监视堆内存,线程,CPU使用率,类以及配置各种MBean。在本文中,我将讨论如何使用JConsole启用并连接到Tomcat。我假设您已经安装了Tomcat(如果没有);您可以参考安装指南。转到安装了Tomcat的路径 转到bin文件夹 将文件创建为“ setenv.sh” 使用vi编辑器修改文件并添加以下内容
总览介绍 建立 取得Java 获取TomCat 将TomCat安装为Windows服务 将TomCat设置为Linux服务(系统化) 使用Nginx作为反向代理 基本用法 手动启动和停止TomCat 验证TomCat服务器正在运行 服务静态文件 服务Java服务器页面(JSP) 修改设定 部署网络应用 使用管理网页界面 创建一个TomCat管理员用户 访问管理网络应用 管理网络应用 结论 参考链接介绍在最简单的概念中,To.
PSI Probe是Lambda Probe的社区驱动分支,使用相同的开源许可证(GPLv2)分发。它旨在替换和扩展Tomcat Manager,从而使管理和监视Apache Tomcat实例更加容易。与许多其他服务器监视工具不同,PSI Probe不需要对现有应用程序进行任何更改。它通过可访问Web的界面提供所有功能,只需将其部署到服务器即可使用。这些功能包括:请求:即使在每个应用程序的基础上,实时监视流量。 会话:浏览/搜索属性,查看上一个IP,到期,估计大小。 JSP:浏览,查看源代码,进
监视和管理Tomcat目录介绍 启用JMX远程 使用JMX远程Ant任务管理Tomcat JMXAccessorOpenTask-JMX打开连接任务 JMXAccessorGetTask:获取属性值Ant任务 JMXAccessorSetTask:设置属性值Ant任务 JMXAccessorInvokeTask:调用MBean操作Ant任务 JMXAccessorQueryTask:查询MBean Ant任务 JMXAccessorCreateTask:远程创建MBean Ant任
1.tomcat与jetty都是一种servlet引擎,他们都支持标准的servlet规范和javaEE规范
“The origin server did not find a current representation for the target resource...
Artifacts是maven中的一个概念,表示某个module要如何打包,例如war exploded、war、jar、ear等等这种打包形式;
使用 IDEA 编辑器开发项目十分便捷,这里介绍使用 IDEA 编辑器添加 Tomcat
这篇“servlet和tomcat的知识点有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅...
这篇文章主要讲解了“Tomcat管理平台实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Tomcat管理平...
本文小编为大家详细介绍“tomcat虚拟主机怎么配置”,内容详细,步骤清晰,细节处理妥当,希望这篇“tomcat虚拟主机怎么配置”文章能帮助大家解决疑惑,下面跟
今天小编给大家分享一下tomcat相关配置与eclipse集成的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家
这篇“Tomcat之web应用的目录组成结构是怎样的”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,
今天小编给大家分享一下tomcat目录映射的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大...
这篇“tomcat的环境怎么配置”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文...
环境:tomcat:apache-tomcat-7.0.35 cactiEZ:10.1系统:centos5.6_x64一、配置tomcat服务器1、添加账号vim tomcat-users.xml 重启tomcat2、安装snmp协议yum...
一、 软环下载地址软件链接地址https://files.cnblogs.com/files/jinrf/openssl-1.0.2-latest.tar.gzhttps://files.cnblogs.com/files/jinrf/apr-util-1.6...