• Tomcat 介绍


    Tomcat 介绍

    三大基础软件:操作系统、数据库、中间件。
    中间件位于客户机/ 服务器的操作系统之上,管理计算机资源和网络通讯。是连接两个独立应用程序或独立系统的软件。相连接的系统,即使它们具有不同的接口,但通过中间件相互之间仍能交换信息。执行中间件的一个关键途径是信息传递。通过中间件,应用程序可以工作于多平台或OS环境。
            1.主机就是普通的PC或者是服务器
            2.数据库通俗点说就是存储数据的地方,比较常见的有Oracle,SqlServer,DB2等
            3.中间件就是运行项目的服务器,常见的有tomcat,weblogic,websphere等   
            4.存储 ,存储是比较抽象的概念,不是具体的硬件
    比如一个web项目,首先将数据库以及中间件安装在服务器上,首先启动中间件,让项目开始运行,当浏览器访问项目的时候,将数据存储在数据库中
    Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。
    Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。
    Tomcat和Nginx、Apache(httpd)、lighttpd等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Nginx/Apache服务器。
    Tomcat与Apache服务器的关系?
    1.Apache是web服务器,Tomcat是应用(java)服务器,它只是一个servlet容器,是Apache的扩展。
    2.Apache和Tomcat都可以做为独立的web服务器来运行,但是Apache不能解释java程序(jsp,serverlet)。
    3.Apache是普通服务器,本身只支持html即普通网页。不过可以通过插件支持php,还可以与Tomcat连通(单向Apache连接Tomcat,就是说通过Apache可以访问Tomcat资源。反之不然)
    4.两者都是一种容器,只不过发布的东西不同:Apache是html容器,功能像IIS一样;Tomcat是jsp/servlet容器,用于发布jsp及java的,类似的有IBM的webshere、EBA的Weblogic,sun的JRun等等。
    5.Apache和Tomcat是独立的,在通一台服务器上可以集成。
    打个比方:Apache是一辆卡车,上面可以装一些东西如html等。但是不能装水,要装水必须要有容器(桶),Tomcat就是一个桶(装像Java这样的水),而这个桶也可以不放在卡车上。
     
    工作原理:
    Server:指的就是整个 Tomcat 服 务器,包含多组服务,负责管理和 启动各个 Service,同时监听 8005 端口发过来的 shutdown 命令,用 于关闭整个容器 ;
    Service:Tomcat 封装的、对外提 供完整的、基于组件的 web 服务, 包含 Connectors、Container 两个 核心组件,以及多个功能组件,各 个 Service 之间是独立的,但是共享 同一 JVM 的资源 ;
    Connector:Tomcat 与外部世界的连接器,监听固定端口接收外部请求,传递给 Container,并 将 Container 处理的结果返回给外部;
    Container:Catalina,Servlet 容器,内部有多层容器组成,用于管理 Servlet 生命周期,调用 servlet 相关方法。
    Loader:封装了 Java ClassLoader,用于 Container 加载类文件;
    Realm:Tomcat 中为 web 应用程序提供访问认证和角色管理的机制;
    JMX:Java SE 中定义技术规范,是一个为应用程序、设备、系统等植入管理功能的框架,通过 JMX 可以远程监控 Tomcat 的运行状态;
    Jasper:Tomcat 的 Jsp 解析引擎,用于将 Jsp 转换成 Java 文件,并编译成 class 文件。 
    Session:负责管理和创建 session,以及 Session 的持久化(可自定义),支持 session 的集群。
    Pipeline:在容器中充当管道的作用,管道中可以设置各种 valve(阀门),请求和响应在经由管 道中各个阀门处理,提供了一种灵活可配置的处理请求和响应的机制。
    Naming:命名服务,JNDI, Java 命名和目录接口,是一组在 Java 应用中访问命名和目录服务的 API。命名服务将名称和对象联系起来,使得我们可以用名称访问对象,目录服务也是一种命名 服务,对象不但有名称,还有属性。Tomcat 中可以使用 JNDI 定义数据源、配置信息,用于开发 与部署的分离。
     
     
     
    一个Tomcat中只有一个Server,一个Server可以包含多个Service,一个Service只有一个Container,但是可以有多个Connectors,这是因为一个服务可以有多个连接,如同时提供Http和Https链接,也可以提供向相同协议不同端口的连接
     
     
     
    Container组成
    Engine:引擎,用来管理多个站点,一个Service最多只能有一个Engine;
    Host: 代表一个站点,也可以叫虚拟主机,通过配置Host就可以添加站点;
    Context: 代表一个应用程序,对应着平时开发的一套程序,或者一个WEB-INF目录以及下面的web.xml文件;
    Wrapper:最底层的容器,是对 Servlet 的封装,负责 Servlet 实例的创建、执行和销毁。 每一Wrapper封装着一个Servlet;
     
     
     
    多个 Connector 和一个 Container 就形成了一个 Service,有了 Service 就可以对外提供服务了,但是 Service 还要一个生存的环境,整个 Tomcat 的生命周期由 Server 控制
     
    Server标签设置的端口号为8005,shutdown=”SHUTDOWN” ,表示在8005端口监听“SHUTDOWN”命令,如果接收到了就会关闭Tomcat。一个Server有一个Service,当然还可以进行配置,一个Service有多个,Service左边的内容都属于Container的,Service下边是Connector。
     
    1/Tomcat中只有一个Server,一个Server可以有多个Service,一个Service可以有多个Connector和一个Container;
    2/Server掌管着整个Tomcat的生死大权;
    3/Service 是对外提供服务的;
    4/Connector用于接受请求并将请求封装成Request和Response来具体处理;
    5/Container用于封装和管理Servlet,以及具体处理request请求;
     
     
     
     
     
     

    Tomcat 安装

    systemctl stop firewalld.service
    systemctl disable firewalld.service
    firewall-cmd --state
    sed -i '/^SELINUX=.*/c SELINUX=disabled' /etc/selinux/config
    sed -i 's/^SELINUXTYPE=.*/SELINUXTYPE=disabled/g' /etc/selinux/config
    grep --color=auto '^SELINUX' /etc/selinux/config
    setenforce 0

    这是由于yum安装了旧版本的GPG keys造成的,解决办法就是 运行下面命令即可
    #  rpm --import /etc/pki/rpm-gpg/RPM*


    #  yum makecache  安装缓存

    目前Tomcat最新版本为9.0。Java容器还有resin、weblogic等。
    Tomcat官网: http://tomcat.apache.org

     https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.35/src/apache-tomcat-9.0.35-src.tar.gz

    关闭selinux、防火墙
    systemctl stop firewalld.service
    systemctl disable firewalld.service
    firewall-cmd --state
    sed -i '/^SELINUX=.*/c SELINUX=disabled' /etc/selinux/config
    sed -i 's/^SELINUXTYPE=.*/SELINUXTYPE=disabled/g' /etc/selinux/config
    grep --color=auto '^SELINUX' /etc/selinux/config
    setenforce 0
     
     
    安装JDK
    yum install java-1.8.0-openjdk -y
     
    安装Tomcat
    cd /usr/local/src/
    wget http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.42/bin/apache-tomcat-8.5.42.tar.gz
    tar -zxvf apache-tomcat-8.5.38.tar.gz -C /usr/local/
    mv /usr/local/apache-tomcat-8.5.38 /usr/local/tomcat_1
    检查tomcat是否安装成功
    [root@controller1 src]# /usr/local/tomcat_1/bin/version.sh
    Using CATALINA_BASE:   /usr/local/tomcat_1
    Using CATALINA_HOME:   /usr/local/tomcat_1
    Using CATALINA_TMPDIR: /usr/local/tomcat_1/temp
    Using JRE_HOME:        /usr
    Using CLASSPATH:       /usr/local/tomcat_1/bin/bootstrap.jar:/usr/local/tomcat_1/bin/tomcat-juli.jar
    Server version: Apache Tomcat/8.5.38
    Server built:   Feb 5 2019 11:42:42 UTC
    Server number:  8.5.38.0
    OS Name:        Linux
    OS Version:     3.10.0-862.el7.x86_64
    Architecture:   amd64
    JVM Version:    1.8.0_191-b12
    JVM Vendor:     Oracle Corporation
     
    启动/停止tomcat
    [root@controller1 src]# /usr/local/tomcat_1/bin/startup.sh
    Using CATALINA_BASE:   /usr/local/tomcat_1
    Using CATALINA_HOME:   /usr/local/tomcat_1
    Using CATALINA_TMPDIR: /usr/local/tomcat_1/temp
    Using JRE_HOME:        /usr
    Using CLASSPATH:       /usr/local/tomcat_1/bin/bootstrap.jar:/usr/local/tomcat_1/bin/tomcat-juli.jar
    Tomcat started.
    [root@controller1 src]# ss -tpln | grep java
    LISTEN     0      1         ::ffff:127.0.0.1:8005                    :::*                   users:(("java",pid=1618,fd=76))
    LISTEN     0      100         :::8009                    :::*                   users:(("java",pid=1618,fd=54))
    LISTEN     0      100         :::8080                    :::*                   users:(("java",pid=1618,fd=49))
    [root@controller1 src]# /usr/local/tomcat_1/bin/shutdown.sh
    Using CATALINA_BASE:   /usr/local/tomcat_1
    Using CATALINA_HOME:   /usr/local/tomcat_1
    Using CATALINA_TMPDIR: /usr/local/tomcat_1/temp
    Using JRE_HOME:        /usr
    Using CLASSPATH:       /usr/local/tomcat_1/bin/bootstrap.jar:/usr/local/tomcat_1/bin/tomcat-juli.jar
     
    解决Tomcat启动慢的方法
    Tocmat的Session ID是通过SHA1算法计算得到的,计算Session ID的时候必须有一个密钥。为了提高安全性Tomcat在启动的时候会通过随机生成一个密钥。Tomcat启动慢主要原因是生成随机数的时候卡住了,导致tomcat启动不了。
    是否有足够的熵来用于产生随机数,可以通过如下命令来查看
    cat /proc/sys/kernel/random/entropy_avail
    3001
     
    为了加速/dev/random提供随机数的速度,你可以通过操作设备的外设,让其产生大量的中断,网络传输数据,按键,移动鼠标,在命令行敲几个不同的命令,俗称聚气。
    yum install rng-tools -y # 安装rngd服务(熵服务,增大熵池)
    systemctl start rngd  # 启动服务
     
    Tomcat目录介绍
    [root@controller1 tomcat_1]# tree -L 1
    .
    ├── bin              #存放tomcat管理脚本                         
    ├── conf             # tomcat 配置文件存放目录
    ├── lib              # web应用调用的jar包存放路径
    ├── LICENSE
    ├── logs             # tomcat 日志存放目录,catalina.out 为主要输出日志
    ├── NOTICE
    ├── RELEASE-NOTES
    ├── RUNNING.txt
    ├── temp             # 存放临时文件
    ├── webapps          # web程序存放目录
    └── work             # 存放编译产生的.java 与 .class文件
     
    7 directories, 4 files
     
    webapps目录介绍
    [root@controller1 webapps]# tree -L 1
    .
    ├── docs            # tomcat 帮助文档
    ├── examples        # web应用实例
    ├── host-manager    # 主机管理
    ├── manager         # 管理
    └── ROOT            # 默认站点根目录
     
    5 directories, 0 files
     
    Tomcat配置文件目录介绍(conf)
    [root@controller1 conf]# tree -L 1
    .
    ├── Catalina
    ├── catalina.policy
    ├── catalina.properties
    ├── context.xml
    ├── jaspic-providers.xml
    ├── jaspic-providers.xsd
    ├── logging.properties
    ├── server.xml            # tomcat 主配置文件
    ├── tomcat-users.xml      # tomcat 管理用户配置文件
    ├── tomcat-users.xsd
    └── web.xml
     
    1 directory, 10 files
     
     
    浏览器进行访问
    Tomcat管理功能使用
    Tomcat管理功能用于对Tomcat自身以及部署在Tomcat上的应用进行管理的web应用。在默认情况下是处于禁用状态的。如果需要开启这个功能,就需要配置管理用户,即配置tomcat-users.xml 文件。
    [root@controller1]# vi /usr/local/tomcat_1/conf/tomcat-users.xml
    <role rolename="manager-gui"/>
    <role rolename="admin-gui"/>
    <user username="tomcat" password="tomcat" roles="manager-gui,admin-gui"/>
    </tomcat-users>            #在这行上面添加
     
    重启tomcat再次登陆
     
    如果登陆不上去,可能是访问的IP受到限制,将下面的内容注释掉
    [root@controller1 META-INF]# vi /usr/local/tomcat_1/webapps/manager/META-INF/context.xml
    <!--
      <Valve className="org.apache.catalina.valves.RemoteAddrValve"
             allow="127.d+.d+.d+|::1|0:0:0:0:0:0:0:1" />
    -->
     
    server.xml配置文件注释
    <?xml version='1.0' encoding='utf-8'?><!--
    <Server>元素代表整个容器,是Tomcat实例的顶层元素.由org.apache.catalina.Server接口来定义.它包含一个<Service>元素.并且它不能做为任何元素的子元素.
        port指定Tomcat监听shutdown命令端口.终止服务器运行时,必须在Tomcat服务器所在的机器上发出shutdown命令.该属性是必须的.
        shutdown指定终止Tomcat服务器运行时,发给Tomcat服务器的shutdown监听端口的字符串.该属性必须设置
    --><Server port="8005" shutdown="SHUTDOWN">
      <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
      <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
      <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
      <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
      <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
      <GlobalNamingResources>
        <Resource name="UserDatabase" auth="Container"
                  type="org.apache.catalina.UserDatabase"
                  description="User database that can be updated and saved"
                  factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
                  pathname="conf/tomcat-users.xml" />
      </GlobalNamingResources>
      <!--service服务组件-->
      <Service name="Catalina">
        <!-- Connector主要参数说明(见下表) -->
        <Connector port="8080" protocol="HTTP/1.1"
                   connectionTimeout="20000"
                   redirectPort="8443" />
        <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
        <!--engine,核心容器组件,catalina引擎,负责通过connector接收用户请求,并处理请求,将请求转至对应的虚拟主机host
            defaultHost指定缺省的处理请求的主机名,它至少与其中的一个host元素的name属性值是一样的
        -->
        <Engine name="Catalina" defaultHost="localhost">
          <!--Realm表示存放用户名,密码及role的数据库-->
          <Realm className="org.apache.catalina.realm.LockOutRealm">
            <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
                   resourceName="UserDatabase"/>
          </Realm>
          <!-- 详情常见下表(host参数详解)-->
          <Host name="localhost"  appBase="webapps"
                unpackWARs="true" autoDeploy="true">
            <!-- 详情常见下表(Context参数说明 )-->
            <Context path="" docBase="" debug=""/>
            <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" />
          </Host>
        </Engine>
      </Service></Server>
     
    Connector主要参数说明
    connector:收用户请求,类似于httpd的listen配置监听端口.
    port:服务器端要创建的端口号,并在这个端口监听来自客户端的请求。
    address:定连接器监听的地址,默认为所有地址(即0.0.0.0)
    protocol:接器使用的协议,支持HTTP和AJP。AJP(Apache Jserv Protocol)专用于tomcat与apache建立通信的, 在httpd反向代理用户请求至tomcat时使用(可见Nginx反向代理时不可用AJP协议)。
    minProcessors:务器启动时创建的处理请求的线程数
    maxProcessors:大可以创建的处理请求的线程数
    enableLookups:果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址
    redirectPort:定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号
    acceptCount:定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
    connectionTimeout:定超时的时间数(以毫秒为单位)
     
    host参数详解
    host:示一个虚拟主机
    name:定主机名
    appBase:用程序基本目录,即存放应用程序的目录.一般为appBase="webapps" ,相对于CATALINA_HOME而言的,也可以写绝对路径。
    unpackWARs:果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序
    autoDeploy:tomcat启动时,是否自动部署。
    xmlValidation:否启动xml的校验功能,一般xmlValidation="false"。
    xmlNamespaceAware:测名称空间,一般xmlNamespaceAware="false"。
     
    Context参数说明
    Context:示一个web应用程序,通常为WAR文件
    docBase:用程序的路径或者是WAR文件存放的路径,也可以使用相对路径,起始路径为此Context所属Host中appBase定义的路径。
    path:示此web应用程序的url的前缀,这样请求的url为http://localhost:8080/path/****
    reloadable:个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib 和/WEB-INF/classes目录的变化,自动装载新的应用程序,可以在不重启tomcat的情况下改变应用程序
     
    部署一个开源的java代码
    开源中国下载的https://www.oschina.net/
    我已经下好一个
     
    第一种部署方式:
    将压缩包解压,把war通过tomcat管理界面部署
     
    安装mariadb
    yum install mariadb mariadb-server python2-PyMySQL expect -y
     
    修改配置文件
    echo "#
    [mysqld]
    bind-address = 0.0.0.0
    default-storage-engine = innodb
    innodb_file_per_table
    max_connections = 4096
    collation-server = utf8_general_ci
    character-set-server = utf8
    #">/etc/my.cnf.d/openstack.cnf
     
    启动数据库
    systemctl enable mariadb.service
    systemctl start mariadb.service
     
    mysql_secure_installation #初始化设置密码,自动交互
    DBPass=redhat
    /usr/bin/expect << EOF
    set timeout 30
    spawn mysql_secure_installation
    expect {
        "enter for none" { send " "; exp_continue}
        "Y/n" { send "Y " ; exp_continue}
        "password:" { send "$DBPass "; exp_continue}
        "new password:" { send "$DBPass "; exp_continue}
        "Y/n" { send "Y " ; exp_continue}
        eof { exit }
    }
    EOF
     
    创建库
    mysql -uroot -predhat
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'open2017'  ;
    MariaDB [(none)]> create database along;
     
    在压缩包里找到数据库文件,将其上传到tomcat上
    mysql -uroot -p -D along < jeesns.sql
     
    vi /usr/local/tomcat_1/webapps/jeesns/WEB-INF/classes/jeesns.properties
    jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/along?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true
    jdbc.user=root
    jdbc.password=redhat
     
    managePath=manage
    frontTemplate=front
    memberTemplate=member
    manageTemplate=manage
     
    重启tomcat
     
    进入后台管理
    用户名:admin
    密码:jeesns
     
  • 相关阅读:
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(5)
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(4)
    C++多线程库的常用函数 std::lock()
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(3)
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(2)
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(1)
    C++多线程库的常用模板类 std::lock_guard
    C++多线程库的常用类 std::mutex
    npm install 时,下载github的包超时解决方法
    SAP 电商云 Spartacus UI 和路由相关的 State 处理
  • 原文地址:https://www.cnblogs.com/wx9527/p/13052477.html
Copyright © 2020-2023  润新知