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.*" %>

    

        Test Page

    

    

        <% 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.*" %>

    

        Test Page

    

    

        <% 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、测试