Tomcat介绍、安装配置以及简单的实现Tomcat负载均衡
-----------------------------------------------------------------------------------------------------------------------------------------------
压测工具:JMeter
一、软件架构模式
1、分层架构:表现层,业务层,持久层,数据库层
2、事件驱动架构:分布式异构架构,高度解耦,大型应用场景
3、微内核架构:插件式架构,各种功能以插件形式对接到核心上
4、微服务架构:整体系统功能中每一项功能,只要功能能够单独调用,每个功能就做成一个单元。基于API REST-based,application REST-based,中心化消息
5、基于空间的架构:云架构
二、webapp容器
tomcat,jetty,resin
jboss
websphere,weblogic
三、Java相关
1、tomcat由java程序编写,是为了更好支持其它java而编写的,比如说jsp(java server page)
2、java编程语言,是一种企业级应用程序
JDK:java development kit,java的开发工具
JRE:java运行开发环境,JVM+标准库组成
JVM:java虚拟机
openjdk:开源社区版jdk
3、tomcat是只实现了java2EE的JSP和servlet,配置上的关键标识符是catalina
4、JDK 6就是JDK 1.6版,JDK 6u1就是JDK 1.6版本第一次升级
四、tomcat相关
1、端口使用
使用8080端口,http协议,tomcat user
使用8443端口,https协议
使用8009端口,ajp协议,在http做反向代理时候使用
ajp:apache jserv protocol
2、.do和.jsp文件传递给tomcat处理
3、动+静结合:LNMT或者LAMT
五、JDK的部署
1、tomcat的运行之前需要部署JDK
2、Oracle JDK的部署
oracle网站进入后下载
rpm -ivh jdk-8u191-linux-x64.rpm
解压缩后进入目录
default/bin/下有很多脚本,如果想使用这些脚本,需要添加环境变量
vim /etc/profile.d/java.sh
JAVA_HOME=/usr/java/latest
PATH=$JAVA_HOME/bin:$PATH
export JAVA_HOME PATH
完成后,java -version就可以显示
3、Open JDK的部署
yum info all java*
yum -y install java-1.8.0-openjdk-devel
4、alternatives,同一程序多版本并存时候选择默认版本
六、tomcat的安装
1、二进制安装
(1)wget http://URL或者下载
tar xf apache-tomcat-xxx.tar.gz -C /usr/local
cd /usr/local
ln -sv apache-tomcat-xxx tomcat
(2)配置文件:目录下/conf/server.xml
(3)配置启动过程
useradd tomcat -s /sbin/nologin
cd tomcat/
chown -R :tomcat ./*
chown -R tomcat logs/ temp/ work/
chmod g+rx conf/
vim /etc/profile.d/tomcat.sh
CATALINA_BASE=/usr/local/tomcat
PATH=$CATALINA_BASE/bin:$PATH
export CATALINA_BASE PATH
exec bash
catalina.sh start后启动
访问8080端口页面就出来了
2、第二种安装
yum -y install tomcat tomcat-docs-webapp tomcat-admin-webapps tomcat-webapps
安装好后systemctl start tomcat
注:后三个tomcat-docs-webapp tomcat-admin-webapps tomcat-webapps为应用程序,不需要可以不装
七、jsp相关
1、.jsp ->Jasper -> .java ->javac ->.class
.jsp通过Jasper翻译为.java,再编译为javac,最后转换成.class类文件
Test Page
<%language=java
...
%>
八、tomcat的目录结构
1、目录说明
bin:脚本,及启动时用到的类;
conf:配置文件目录;
lib:库文件,Java类库,jar;
logs:日志文件目录;
temp:临时文件目录;
webapps:webapp的默认目录;
work:工作目录;
2、rpm包安装的程序环境:
配置文件目录:/etc/tomcat
主配置文件:server.xml
工作目录webapps默认存放位置:/var/lib/tomcat/webapps/
examples
manager
host-manager
docs
Unit File:tomcat.service
环境配置文件:/etc/sysconfig/tomcat
当/var/lib/tomcat/webapps/ROOT/test/index.jsp,访问对应host:8080/test就是访问的该目录
3、tomcat的配置文件构成:
(1)server.xml:主配置文件;
(2)web.xml:每个webapp只有“部署”后才能被访问,它的部署方式通常由web.xml进行定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认部署相关的配置;
(3)context.xml:每个webapp都可以专用的配置文件,它通常由专用的配置文件context.xml来定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认配置;
(4)tomcat-users.xml:用户认证的账号和密码文件;
(5)catalina.policy:当使用-security选项启动tomcat时,用于为tomcat设置安全策略(除非有特别配置上的需要,否则不建议使用-security选项);
(6)catalina.properties:Java属性的定义文件,用于设定类加载器路径,以及一些与JVM调优相关参数;
(7)logging.properties:日志系统相关的配置; log4j
九、tomcat配置文件
1、tomcat配置结构
server {
service {
conntor { } ----》一个service中可以多个conntor对应一个engine
engine { ----》每个service只能有一个engine
host { } ----》engine中可以有多个host
host {
context { }
}
}
}
}
2、Tomcat的核心组件:server.xml
...
...
...
...
每一个组件都由一个Java“类”实现,这些组件大体可分为以下几个类型:
顶级组件:Server
服务类组件:Service
连接器组件:http, https, ajp(apache jserv protocol)
容器类:Engine, Host, Context
被嵌套类:valve(对用户的请求过滤), logger, realm, loader, manager, ...
集群类组件:listener, cluster, ...
九、WebApp的组织架构
1、JSP WebAPP的组织结构:
/: webapps的根目录
(1)index.jsp, index.html:主页;
(2)WEB-INF/:当前webapp的私有资源路径;通常用于存储当前webapp的web.xml和context.xml配置文件;
(3)META-INF/:类似于WEB-INF/;
(4)classes/:类文件,当前webapp所提供的类;
(5)lib/:类文件,当前webapp所提供的类,被打包为jar格式;
2、webapp归档格式:
.war:webapp
.jar:EJB的类打包文件;
.rar:资源适配器类打包文件;
.ear:企业级webapp;
3、部署(deploy)webapp的相关操作:
(1)deploy:将webapp的源文件放置于目标目录(网页程序文件存放目录),配置tomcat服务器能够基于web.xml和context.xml文件中定义的路径来访问此webapp;将其特有的类和依赖的类通过class loader装载至JVM;
(2)部署有两种方式:
自动部署:auto deploy
手动部署:
冷部署:把webapp复制到指定的位置,而后才启动tomcat;
热部署:在不停止tomcat的前提下进行部署;
部署工具:manager、ant脚本、tcd(tomcat client deployer)等;
undeploy:反部署,停止webapp,并从tomcat实例上卸载webapp;
start:启动处于停止状态的webapp;
stop:停止webapp,不再向用户提供服务;其类依然在jvm上;
redeploy:重新部署;
(3)手动提供一测试类应用,并冷部署:
# mkidr -pv /usr/local/tomcat/webapps/test/{classes,lib,WEB-INF}
创建文件/usr/local/tomcat/webapps/test/index.jsp
<%@ page language="java" %>
<%@ page import="java.util.*" %>
<% out.println("hello world");
%>
十、tomcat的两个管理应用:
manager:管理webapps应用程序
host-manager:管理虚拟主机
1、manager:管理webapps应用程序
如果登录这两个应用,需要去配置目录tomcat-users.xml里编辑
二进制目录在tomcat/conf/下
rpm包安装在/etc/tomcat/tomcat.conf
更改后重启tomcat,之后可以点击进入Manager App
2、host-manager:管理虚拟主机
十一、tomcat的常用组件配置:
1、Server:代表tomcat instance,即表现出的一个java进程;监听在8005端口,只接收“SHUTDOWN”。各server监听的端口不能相同,因此,在同一物理主机启动多个实例时,需要修改其监听端口为不同的端口;
注意:server.xml不要让其他用户有读权限,chmod o= /etc/tomcat/server.xml
2、Service:用于实现将一个或多个connector组件关联至一个engine组件;
3、Connector组件:端点,定义tomcat所监听的地址和端口,不属于任何host,而属于整个tomcat
负责接收请求,常见的有三类http/https/ajp;
进入tomcat的请求可分为两类:
(1)standalone : 请求来自于客户端浏览器;
(2)由其它的web server反代:来自前端的反代服务器;
nginx --> http connector --> tomcat
httpd(proxy_http_module) --> http connector --> tomcat
httpd(proxy_ajp_module) --> ajp connector --> tomcat
httpd(mod_jk) --> ajp connector --> tomcat
属性:
port="8080"
protocol="HTTP/1.1"
connectionTimeout="20000"
address:监听的IP地址;默认为本机所有可用地址;
maxThreads:最大并发连接数,默认为200;
enableLookups:是否启用DNS查询功能;
acceptCount:等待队列的最大长度;
secure:
sslProtocol:
4、Engine组件:Servlet实例,即servlet引擎,其内部可以一个或多个host组件来定义站点; 通常需要通过defaultHost属性来定义默认的虚拟主机;
属性:
name=
defaultHost="localhost"
jvmRoute=
5、Host组件:位于engine内部用于接收请求并进行相应处理的主机或虚拟主机,示例:
unpackWARs="true" autoDeploy="true">
Webapp ARchives
常用属性说明:
(1)appBase:此Host的webapps的默认存放目录,指存放非归档的web应用程序的目录或归档的WAR文件目录路径,类似于apache的/var/×××w/html;如果使用的是相对路径,则是相对于$CATALINA_BASE变量的相对路径;
(2)unpackWARs,是否自动解压
(3)autoDeploy:自动部署,在Tomcat处于运行状态时,将某webapp放置于appBase所定义的目录中时,是否自动将其部署至tomcat;,生产环境中不建议自动部署,关闭该功能
示例:部署tomcat
安装好openjdk、tomcat后,我们如果想要建立一个其它的工作目录来存放以后的项目,首先在配置文件server.xml中有
其次,手动建立目录
mkdir /app/webapps/ROOT/{classes,lib,WEB-INF}
mkdir /app/webapps/test-0.1/{classes,lib,WEB-INF}
vim /app/webapps/test-0.1/index.jsp
<%@ page language="java" %>
<%@ page import="java.util.*" %>
<% out.println("hello world");
%>
之后由你自己决定是否要虚拟主机的主页,如果要,拷贝默认目录下ROOT目录的内容到手建目录下ROOT。如果需要Manager App和Host Manager,还需要将host-manager和manager两个目录一并拷贝至此
为了便于做灰度发布,可以在工作目录/app/webapps为目录做软链接
ln -sv test-0.1 test
最后形成的tree形图为
结果图
灰度发布示例:
6、Context组件:
示例:
综合示例:
prefix="node1_access" suffix=".log" pattern="%h %l %u %t "%r" %s %b" /> prefix="node1_test_access_" suffix=".log" pattern="%h %l %u %t "%r" %s %b" /> 7、Valve组件: valve,阀门,控制组件 prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> https://tomcat.apache.org/tomcat-7.0-doc/api/org/apache/catalina/valves/AccessLogValve.html 访问下a.chen.com Valve存在多种类型: 定义访问日志:org.apache.catalina.valves.AccessLogValve 定义访问控制:org.apache.catalina.valves.RemoteAddrValve 举例:两种方式 注意:tomcat只支持基于主机名的虚拟主机,不支持IP地址 十一、App Manager 1、实例列表 2、图形界面热部署 十二、tomcat的反向代理 1、NT架构中,nginx将.jsp和.do格式代理给tomcat LNMT:Linux Nginx MySQL Tomcat Client (http) --> nginx (reverse proxy)(http) --> tomcat (http connector) location / { proxy_pass http://tc1.magedu.com:8080; } location ~* \.(jsp|do)$ { proxy_pass http://tc1.magedu.com:8080; } 这么写入后nginx反代不能进入Manager App或者Host Manager,需要更进一步的定义规则通过rewrite进入 2、AT架构 (1)LAMT:Linux Apache(httpd) MySQL Tomcat httpd的代理模块: proxy_module proxy_http_module:适配http协议客户端; proxy_ajp_module:适配ajp协议客户端; Client (http) --> httpd (proxy_http_module)(http) --> tomcat (http connector) Client (http) --> httpd (proxy_ajp_module)(ajp) --> tomcat (ajp connector) Client (http) --> httpd (mod_jk)(ajp) --> tomcat (ajp connector) (2)proxy_http_module代理配置示例: ServerName a.chen.com ProxyRequests Off ProxyVia On ProxyPreserveHost On Require all granted
ProxyPass / http://a.chen.com:8080/ ProxyPa***everse / http://a.chen.com:8080/ Require all granted
ProxyPass / http://a.chen.com:8080/
结果 http反代可以进入Manager App或者Host Manager (3)proxy_ajp_module代理配置示例: ServerName a.chen.com ProxyRequests Off ProxyVia On ProxyPreserveHost On Require all granted ProxyPass / ajp://a.chen.com:8009/ ProxyPa***everse / ajp://a.chen.com:8009/ Require all granted 同样可以进入Manager App或者Host Manager 十三、keepalived实现nginx对tomcat的负载均衡调度 1、准备nginx一主一从调度器,两台的/etc/nginx/nginx.conf都是这么写 配置这两台主机的keepalived.conf 2、准备两台tomcat主机 192.168.239.72和192.168.239.73 配置nginx.conf页面 3、测试