5.20 TOMCAT

需要安装JDK JAVA Development Kit //JAVA 2 SE 的接口

 
 

TOMCAT 的安装:

  • yum 安装

    #yum install -y java-1.8.0-openjdk-devel

    如下界面出现的话就是安装OK

    5.20 TOMCAT

    注意:安装完成后,要配置JAVA_HOME环境变量,指向java的安装路径;

    OpenJDK:

    JAVA_HOME=/usr

    Oracle JDK:

    JAVA_HOME=/usr/java/jdk_VERSION

     
     

    设定JAVAHOME 变量

    cat /etc/profile.d/java.sh

    export JAVA_HOME=/usr

    • java 2 EE

      servlet :web app 类库

      JSP:JAVA Server Page //将JAVA代码嵌入到html文件中

       
       

      .jsp –>jasper–> .java –> javac –> .class –> jvm

      注意:基于jasper将静态输出的数据转为java代码进行输出,结果为servlet规范的代码;

      JSP Container:

      JSP + Servlet Container

       
       

      Java Web Server:JWS

      ASF:JServ

       
       

      Tomcat 3.x

      Tomcat 4.x

      Catalina

      TOMCAT 就是java 2 EE 的一种

      能解析的协议:

      http、jsp

       
       

  • TOMCAT 的应用:

    安装tomcat

    • #yum install tomcat tomcat-webapps tomcat-admin-webapps

      systemctl start tomcat

      绿色安装

      #wget ftp://172.18.0.1/pub/Sources/6.x86_64/tomcat/apache-tomcat-8.0.23.tar.gz

      #tar xf apache-tomcat-8.0.23.tar.gz -C /usr/local/

      #ln apache-tomcat-8.0.23 tomcat -s

      #useradd -r tomcat

      #chown -R :tomcat * //为填加tomcat的可读权限;权限不能设置太大

      #chown -R tomcat logs work temp conf //某些特定的文件夹

      [48.62root@localhost tomcat]35#cat > /etc/profile.d/tomcat.sh << EOF

      > export CATALINA_HOME=/usr/local/tomcat

      > export PATH=$catalina_HOME/bin:$PATH

      > EOF

      # su – tomcat -c ‘/usr/local/tomcat/bin/catalina.sh start’ //注意要以tomcat用户启动

     
     

     
     

    配置tomcat : /etc/tomcat

    server.xml : 主配置文件

    web.xml:每个webapp只有”部署”后才能被访问,它的部署方式通常由web.xml进行定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认配置;

    context.xml:每个web都可以专用的配置文件,它通常由专用的配置文件context.xml来定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认配置;

    tomcat-users.xml:用户认证的账号和密码文件;

    catalina.policy:当使用-security选项启动tomcat时,用于为tomcat设置安全策略;

    catalina.properties:Java属性的定义文件,用于设定类加载器路径,以及一些与JVM调优相关参数;

    logging.properties:日志系统相关的配置

     
     

    主配基本内容:

    示例:

    <Server port=”8005″ shutdown=”SHUTDOWN”> // 关闭tomcat的控制端口和命令,注意修改

    5.20 TOMCAT

     
     

    5.20 TOMCAT

    defaulthost 默认的虚拟主机

    host 相当于之前虚拟主机

    5.20 TOMCAT

    <Host name=”localhost”

    appBase=”webapps”   //相当于网页根目录

    unpackWARs=”true” //是否解包

    autoDeploy=”true”> //自动部署

     
     

    <Valve className=”org.apache.catalina.valves.AccessLogValve” //类名,指定的,名字逆序书写

    directory=”logs”

    prefix=”localhost_access_log” suffix=”.txt”

    pattern=”%h %l %u %t &quot;%r&quot; %s %b” />

     
     

    组件大概构成:

    每一个组件都由一个Java”“实现,这些组件大体可分为以下几个类型:

    顶级组件:Server

    服务类组件:Service

    连接器组件:http, https, ajp

    容器类:Engine, Host, Context

    被嵌套类:valve, logger, realm, loader, manager, …

    集群类组件:listener, cluster, …

    tomcat的目录结构 //

    bin:脚本,及启动时用到的类;

    conf:配置文件目录;

    lib:库文件,Java类库,jar;

    logs:日志文件目录;

    temp:临时文件目录;

    webapps:webapp的默认目录;

    work:工作目录;//

    5.20 TOMCAT

    ROOT:相当于主页根目录;主页根目录的映射

     
     

     
     

    JSP WebAPP的组织结构:应用程序基本都遵循这个目录结构

    /: webapps的根目录;每个应用程序都有一个该目录

    index.jsp:主页;

    WEB-INF/:当前webapp的私有资源路径;通常用于存储当前webapp的web.xml和context.xml配置文件;

    META-INF/:类似于WEB-INF/;不会被用户访问到

    classes/:类文件,当前webapp所提供的类;

    lib/:类文件,当前webapp所提供的类,被打包为jar格式;

    webapp归档格式:

    .war:webapp

    .jar:EJB的类打包文件;

    .rar:资源适配器类打包文件;

    .ear:企业级webapp;

    部署 //:应用程序依赖到的类必须被加载到JVM(JAVA虚拟机)中才能运行

    deploy:将webapp的源文件放置于目标目录(网页程序文件存放目录),配置tomcat服务器能够基于web.xml和context.xml文件中定义的路径来访问此webapp;将其特有的类和依赖的类通过class loader装载至JVM

    5.20 TOMCAT

    自动部署://不建议用,通过测试可以

    hi6u&%Xw6FL0^)^Hv#

    部署有两种方式:

    自动部署:auto deploy

    手动部署:

    冷部署:把webapp复制到指定的位置,而后才启动tomcat;

    热部署:在不停止tomcat的前提下进行部署;

    部署工具:manager、ant脚本、tcd(tomcat client deployer)等;                                        

    undeploy:反部署,停止webapp,并从tomcat实例上卸载webapp;

    start:启动处于停止状态的webapp;

    stop:停止webapp,不再向用户提供服务;其类依然在jvm上;

    redeploy:重新部署;

    实验一 部署简单网页

    [48.62root@localhost test]16#mkdir ./{lib,classes,WEB-INF,META-INF} -v

    [48.62root@localhost test]19#vim index.jsp

    5.20 TOMCAT

     
     

     
     

    5.20 TOMCAT

    tomcat管理界面用户认证:// 以Yum安装的为例

    5.20 TOMCAT

    cd /etc/tomcat/

    # vim tomcat-user.xml

    5.20 TOMCAT

     
     

    重启服务 并链接实验

    5.20 TOMCAT

     
     

    配置用于管理hostmanager //参照配置文件底层示例

    5.20 TOMCAT

     
     

     
     

    常用配置:

    Server:代表tomcat instance,即表现出的一个java进程;监听在8005端口,只接收”SHUTDOWN”。各server监听的端口不能相同,因此,在同一物理主机启动多个实例时,需要修改其监听端口为不同的端口;

     
     

    Service:用于实现将一个或多个connector组件关联至一个engine组件;

    ·

    Connector组件:

    负责接收请求,常见的有三类http/https/ajp

    tomcat的请求分类:

    1.直接来自客户端

    2.来自前端反代:

    nginx –> http connector –> tomcat

    httpd(proxy_http_module) –> http connector –> tomcat

    httpd(proxy_ajp_module) –> ajp connector –> tomcat

    属性:

    port=”8080″

    protocol=”HTTP/1.1″

    connectionTimeout=”20000″

     
     

    address:监听的IP地址;默认为本机所有可用地址;

    maxThreads:最大并发连接数,默认为200;

    enableLookups:是否启用DNS查询功能;

    acceptCount:等待队列的最大长度; //相当于backlog

    secure:

    sslProtocol:

    实验示例://定义connector

    /etc/tomcat/server.xml内容

    5.20 TOMCAT

    链接实验:

    5.20 TOMCAT

     
     

    engine :

    jvmRoute=”jvm1″ //用于集群中会话绑定

    <Engine name=”Catalina” defaultHost=”localhost”>

     
     

    host :// 相当于虚拟主机

    Host组件:位于engine内部用于接收请求并进行相应处理的主机或虚拟主机,示例:

    <Host name=”localhost” appBase=”webapps”

    unpackWARs=”true” autoDeploy=”true”>

    </Host>

     
     

    常用属性说明:

    (1) appBase:此Host的webapps的默认存放目录,指存放非归档的web应用程序的目录或归档的WAR文件目录路径;可以使用基于$CATALINA_BASE变量所定义的路径的相对路径;

    (2) autoDeploy:在Tomcat处于运行状态时,将某webapp放置于appBase所定义的目录中时,是否自动将其部署至tomcat;

    实验示例:

    5.20 TOMCAT

     
     

    5.20 TOMCAT

     
     

    Context组件: //内嵌到虚拟主机host中

    示例:

    <Context path=”/PATH” docBase=”/PATH/TO/SOMEDIR” reloadable=””/>

    context path : uri 路径

    实验示例:

    5.20 TOMCAT

     
     

    #cp -a /usr/share/tomcat/webapps/ROOT /app/tomcat/test

    重启链接实验:

    5.20 TOMCAT

5.20 TOMCAT

 
 

5.20 TOMCAT5.20 TOMCAT

 
 

5.20 TOMCAT

 
 

VALVE : 控制模块

Valve组件:

<Valve className=”org.apache.catalina.valves.AccessLogValve” directory=”logs”

prefix=”localhost_access_log” suffix=”.txt”

pattern=”%h %l %u %t &quot;%r&quot; %s %b” />

 
 

Valve存在多种类型:

定义访问日志:org.apache.catalina.valves.AccessLogValve

定义访问控制:org.apache.catalina.valves.RemoteAddrValve

访问控制也可以用iptables 管控

 
 

TOMCAT 的集群组合实验:

nginx+tomcat // 本机实验;centos7

 
 

5.20 TOMCAT

 
 

开启服务并链接:

5.20 TOMCAT

 
 

nginx+tomcat //本机实验;代理虚拟主机名

5.20 TOMCAT

重新启动并链接实验

5.20 TOMCAT

 
 

nginx+tomcat // 实习那动静分离;这里仅仅实验。

5.20 TOMCAT

 
 

重启链接测试

5.20 TOMCAT

 
 

额外参考: rewrite 规则:

5.20 TOMCAT

 
 

apache+tomcat:// 利用proxy_http_module

在/etc/httpd/conf.d/ 新建 tomcat.conf

5.20 TOMCAT

启动服务并测试链接

5.20 TOMCAT

 
 

apache+tomcat:// 利用proxy_ajp_module;重点是ajp

5.20 TOMCAT

重启并链接测验:

5.20 TOMCAT

 
 

负载均衡时的session的保持:

session sticky:

nginx: Ip_hash

haproxy:source

lvs:sh

cookie:

nginx:hash

haproxy:cookie

session cluster:delta session manager

session server:redis(store)

memcached(cache)

 
 

实验负载均衡 :nginx+tomcat+memcached

 
 

在tomcat 48.71 创建目录:

5.20 TOMCAT

修改index.html内容

5.20 TOMCAT

 
 

启动tomcat服务并测试:

5.20 TOMCAT

 
 

48.72 同样配置

 
 

ip 48.64 安装 并配置 nginx /etc/nginx/nginx.conf

 
 

在 http 字段中填加 如下字段

5.20 TOMCAT

在/etc/nginx/conf.d/default.conf 填加转发规则

5.20 TOMCAT

重启服务并测试链接

5.20 TOMCAT

 
 

现在填加会话保持: // memcached server 来实现

安装memcached 并开启服务

# yum install memcached -y

systemctl start memcached

 
 

额外: //配置文件的内容。

5.20 TOMCAT

配置tomcat文件设定

a.首先架起tomcat与memcached 的桥梁;放置到下图目录中

5.20 TOMCAT

5.20 TOMCAT

5.20 TOMCAT

b.配置tomcat server.xml 文件 ;填加如下内容到指定 Host 配置段中//注意类文件目录和IP地址

<Context path=”/test” docBase=”/usr/share/tomcat/webapps/test” reloadable=”true”>

<Manager className=”de.javakaffee.web.msm.MemcachedBackupSessionManager”

memcachedNodes=”n1:172.18.48.71:11211,n2:172.18.48.72:11211″

failoverNodes=”n1″

requestUriIgnorePattern=”.*.(ico|png|gif|jpg|css|js)$”

transcoderFactoryClass=”de.javakaffee.web.msm.serializer.javolution.JavolutionTranscod erFactory” />

</Context>

重启tomcat 服务并测验//多次刷新 session ID 保持不变

5.20 TOMCAT

 
 

5.20 TOMCAT

 
 

 
 

tomcat 调优相关: //依据JVM 特性进行设置

JVM 内存区的结构

公共区

方法区(method area) //加载class 常量 静态变量和编译后的代码

堆内存 (JAVA heap) //所有的对象和数组、

私有区

线程栈 (JAVA Stack) //私有数据,线程调用进入和返回栈的操作。

PC寄存器 (program covnter register) //每个线程自己的计数寄存器,用来存储当前线程存储字节码的地址。

本地方法栈 (native stack ) //为调用本地方法服务(类似与JAVA STACK)

JAVA 代码运行:

创建对象–>运行对象–>销毁对象

 
 

内存中的结构

5.20 TOMCAT


eden –>from–>to–>old–>perm (每一次筛选,计数非0 的对象状态流程)

 
 

调优相关

5.20 TOMCAT

 
 

5.20 TOMCAT

 
 

 
 

5.20 TOMCAT

5.20 TOMCAT

原创文章,作者:zhoulz,如若转载,请注明出处:http://www.178linux.com/79614

(0)
zhoulzzhoulz
上一篇 2017-07-09
下一篇 2017-07-09

相关推荐

  • 马哥教育网络班21期第8周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥也叫桥接器,是连接两个局域网的一种存储/转发设备,用来连接不同网段。 集线器称为“Hub”,主要功能是对接收到的信号进行再生整形放大,以扩大网络的传输距离,同时把所有节点集中在以它为中心的节点上。 二层交换机工作于OSI模型的第2层(数据链路层),可识别数据包中的MAC地址信…

    Linux干货 2016-09-19
  • 博客作业网络班22期+第5周(9.5-9.11)

    1、显示当前系统上root、fedora或user1用户的默认shell [root@MyCloudServer wjb]# egrep '^(root|fedora|user1)\>' /etc/passwd | cut -d: -f7/bin/bash 2、找出/etc/rc.d/init.d/functions文件中某单词后面…

    Linux干货 2016-09-15
  • Linux基础知识之用户和组管理

    系统环境:    该博文以CentOS6.8_x86_64和CentOS7.2_x86_64系统为基础,Xshell5远程登录CentOS6.8和CentOS7.2系统,分别以root身份和sjsir用户身份登录系统。 学习的重要问题: 一、为什么要学习用户和组?    首先Linux区别于其他的系统的最重要的特性就是…

    Linux干货 2016-08-02
  • vim编辑器使用详解

    1.vi (virtual interface)文本编辑器     文本编辑种类:     行编辑器:sed     全屏编辑器:nano vi     vim vi-improved  &…

    Linux干货 2016-08-15
  • Linux网络属性管理

      ifconfig命令 ifconfig [interface] # ifconfig -a # ifconfig IFACE [up|down] ifconfig interface [aftype] options | address … # ifconfig IFACE IP/mask [up] # ifconfig IFACE…

    Linux干货 2015-09-26
  • KVM虚拟化平台部署及管理

    前言 KVM即Kernel Virtual Machine,最初是由以色列公司Qumranet开发。2007年2月被导入Linux 2.6.20核心中,成为内核源代码的一部分。2008年9月4日,Redhat收购了Qumranet,至此Redhat拥有了自己的虚拟化解决方案,之后便舍弃Xen开始全面扶持KVM,从RHEL6开始KVM便被默认内置于内核中。本文…

    Linux干货 2015-07-19