tomcat安装使用

2018-10-21  本文已影响38人  任总

一、JDK

1、JDK版本一

OpenJDK: 开源版本

关闭防火墙和selinux,同步时间

[root@tomcat-77 ~]# yum -y install ntpdate
[root@tomcat-77 ~]# ntpdate time2,aliyun.com

安装jdk,这里选择java-1.8.0-openjdk,yum本地安装即可
[root@tomcat-77 ~]# yum -y install java-1.8.0-openjdk
[r[root@tomcat-77 ~]# java -version   #版本查询
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)  #混合模式
注意:安装完成后,要配置JAVA_HOME环境变量,指向java的安装路径;
设定java环境变量
[root@tomcat-77 ~]# echo  $JAVA_HOME   #查询是否有路径
[root@tomcat-77 ~]# vim /etc/profile.d/java.sh  #编写脚本
export JAVA_HOME=/usr
[root@tomcat-77 ~]# . /etc/profile.d/java.sh
[root@tomcat-77 ~]# echo $JAVA_HOME
/usr

2、JDK版本二

Oracle JDK:oracle官方版本
jdk-VERSION-OS-ARCH.rpm
例如:jdk-1.8.0_25-linux-x64.rpm

3、java环境变量配置

JAVA_HOME=/usr

Oracle JDK版本:

JAVA_HOME=/usr/java/jdk_VERSION

二、Servlet容器:

servlet容器的主要任务是管理servlet的生命周期。而web容器更准确的说应该叫web服务器,它是来管理和部署 web应用的。
web容器最典型的就是tomcat了,Tomcat是web容 器也是servlet容器。

三、java在web中的应用JSP技术

1、JSP技术定义

2、JSP页面运行过程

.jsp文件 -->jasper--> .java --> javac --> .class类 --> jvm虚拟机
示例:

<html>
<title>TITLE</title>
<body>
<h1>...</h1>
<%
... java code... #java代码
%>
</body>
</html>

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

3、JSP Container: jsp容器

JSP技术加Servlet容器就是形成了jsp容器,他就是后来的JWS是Java语言对WebService服务的一种实现,用来开发和发布服务。

四、Tomcat安装

官方网站:http://tomcat.apache.org/
Java 2 EE技术体系的不完整实现;

1、安装Tomcat:

方法一:Tomcat的Base Repo安装:
[root@tomcat-77 ~]# yum install -y tomcat tomcat-lib tomcat-admin-webapps tomcat-webapps tomcat-docs-webapp
[root@tomcat-77 ~]# systemctl start tomcat.service

tomcat #核心包
tomcat-lib #库文件
tomcat-admin-webapp s#基于web页面管理接口
tomcat-webapps #jsp示例程序
tomcat-docs-webapp #操作文档页面

方法二:Tomcat 解压展开安装
 ~]# tar xf apache-tomcat-VERSION.tar.gz  -C /usr/local/  #解压缩到指定目录
 ~]# cd /usr/local
local ~]# ln -sv apache-tomcat-VERSION  tomcat  #设置别名
local ~]# vim /etc/profile.d/tomcat.sh  #编辑环境变量shell
export CATALINA_BASE=/usr/local/tomcat
export PATH=$CATALINA_BASE/bin:$PATH
local ~]# .  /etc/profile.d/tomcat.sh #执行
local ~]#  cd tomcat/bin
bin ~]#catalina.sh --help #帮助信息
bin ~]#catalina.sh version  #版本信息
bin ~]#catalina.sh start  #启动 tomcat
bin ~]#catalina.sh stop #停止tomcat
bin ~]#catalina.sh stop 9 #9秒后停止tomcat
bin ~]#catalina.sh stop 9 -force#9秒后强制停止tomcat

2、tomcat程序环境:

tomcat的目录结构
bin:脚本,及启动时用到的类;
conf:配置文件目录;
lib:库文件,Java类库,jar;
logs:日志文件目录;
temp:临时文件目录;
webapps:webapp的默认目录;
work:工作目录;

3、tomcat的配置文件构成:

web.xml:每个webapp只有“部署”后才能被访问,它的部署方式通常由web.xml进行定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认部署相关的配置;
context.xml:每个webapp都可以专用的配置文件,它通常由专用的配置文件context.xml来定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认配置;
tomcat-users.xml:用户认证的账号和密码文件;
catalina.policy:当使用-security选项启动tomcat时,用于为tomcat设置安全策略;
catalina.properties:Java属性的定义文件,用于设定类加载器路径,以及一些与JVM调优相关参数;
logging.properties:日志系统相关的配置;

4、Tomcat的核心组件:server.xml

<Server>
    <Service>
       <connector/>
        <connector/>
...
        <Engine>#引擎
             <Host> #主机
                <Context/> #程序
                <Context/>
               ...
            </Host> 
             <Host>
              ...
            </Host>
              ...
         </Engine>
    </Service>
</Server>
每一个组件都由一个Java“类”实现,这些组件大体可分为以下几个类型:

顶级组件:Server
服务类组件:Service
连接器组件:http, https, ajp(apache jserv protocol)
容器类:Engine, Host, Context
被嵌套类:valve, logger, realm, loader, manager, ...
集群类组件:listener, cluster, ...

五、JSP WebAPP部署:

1、JSP WebAPP的组织结构:

/: webapps的根目录
index.jsp:主页;
WEB-INF/:当前webapp的私有资源路径;通常用于存储当前webapp的web.xml和context.xml配置文件;
META-INF/:类似于WEB-INF/;
classes/:类文件,当前webapp所提供的类;
lib/:类文件,当前webapp所提供的类,被打包为jar格式;

2、webapp归档格式:

.war:webapp
.jar:EJB的类打包文件;
.rar:资源适配器类打包文件;
.ear:企业级webapp;

[root@tomcat-77 ~]# ls /var/lib/tomcat
webapps

3、部署(deploy)webapp的相关操作:

步骤:
部署有两种方式:自动部署和手动部署

操作分为:

反部署:

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

部署工具:

manage:r、ant脚本、tcd(tomcat client deployer)等;

命令:

start:启动处于停止状态的webapp;
stop:停止webapp,不再向用户提供服务;其类依然在jvm上;
redeploy:重新部署;

4、手动提供一测试类应用,并冷部署:

示例:

[root@tomcat-77 ~]# cd  /var/cache/tomcat/work
[root@tomcat-77 work]# ls
Catalina
[root@tomcat-77 work]# tree Catalina/
Catalina/
└── localhost
    ├── _
    │   └── org
    │       └── apache
    │           └── jsp
    │               ├── index_jsp.class
    │               └── index_jsp.java
    ├── docs
    ├── examples
    ├── host-manager  #管理虚拟主机
    ├── manager
    │   └── org
    │       └── apache
    │           └── jsp
    │               └── WEB_002dINF
    │                   └── jsp
    │                       ├── _401_jsp.class
    │                       └── _401_jsp.java
    └── sample

# 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.*" %>
<html>
<head>
<title>Test Page</title>
</head>
<body>
<% out.println("hello world");
%>
</body>
</html>

六、tomcat的两个管理应用:

1、启用manager
[root@tomcat-77 ~]# vim /etc/tomcat/tomcat-users.xml 
 <role rolename="manager-gui"/>   <user username="tomcat" password="tomcat" roles="manager-gui"/>
[root@tomcat-77 ~]# systemctl restart tomcat
登录
部署管理页面
内存使用和回收信息
2、host-manager虚拟主机管理
[root@tomcat-77 ~]# vim /etc/tomcat/tomcat-users.xml 
<role rolename="admin-gui"/> 
  <user username="tomcat" password="tomcat" roles="manager-gui,admin-gui"/>
[root@tomcat-77 ~]# systemctl restart tomcat
登录
显示和添加虚拟主机

3、tomcat的常用组件配置:

4、Connector连接器组件:

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

进入tomcat的请求可分为两类:

5、Connector连接器属性:

port="8080" #监听的端口
protocol="HTTP/1.1" #协议
connectionTimeout="20000" #超时时间
address:监听的IP地址;默认为本机所有可用地址;
maxThreads:最大并发连接数,默认为200;
enableLookups:是否启用DNS查询功能,提升性能建议关闭;
acceptCount:等待队列的最大长度;
secure:安全
sslProtocol:

6、Engine容器组件:

Servlet实例,即servlet引擎,其内部可以一个或多个host组件来定义站点; 通常需要通过defaultHost来定义默认的虚拟主机;

Engine容器组件属性:

name= #名称
defaultHost="localhost" #默认主机
jvmRoute= :jvm的路由标识

7、Host组件:

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

示例:
<Host name="localhost"  appBase="webapps"
unpackWARs="true" autoDeploy="true"> #自动部署
</Host>

常用属性说明:

示例:
<Host name="tc1.magedu.com" appBase="/appdata/webapps"   #webapps的默认存放目录
 unpackWARs="true" autoDeploy="true">#自动部署
</Host>

# mkdir -pv /appdata/webapps #创建存储目录
# mkdir -pv /appdata/webapps/ROOT/{lib,classes,WEB-INF}     #创建目录,站点部署到root路径下

提供一个测试页即可;

8、Context组件:

示例:
<Context path="/PATH" docBase="/PATH/TO/SOMEDIR" reloadable="true"/> #访问url路径,然后被指定其他路径上,可以被重新装载

9、Valve组件:

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"  #prefix日志前缀,suffix日志为后缀
pattern="%h %l %u %t &quot;%r&quot; %s %b" />#这里&quot是引号的意思,%r用户的请求内容

Valve存在多种类型:
定义访问日志:org.apache.catalina.valves.AccessLogValve
定义访问控制:org.apache.catalina.valves.RemoteAddrValve
tomcat日志路径:/var/log/tomcat/
<Valve className="org.apache.catalina.valves.RemoteAddrValve" deny="172.16.100.67"/>

综合示例:
<Host name="node1.magedu.com" appBase="/web/apps" unpackWARs="true" autoDeploy="true">
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="node1_access" suffix=".log"
pattern="%h %l %u %t &quot;%r&quot; %s %b" />
<Context path="/test" docBase="/tmp/test" reloadable="true">   #访问url为test,文档路径为tmp/test,可以被重新装载
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="node1_test_access_" suffix=".log" #前缀是node1_test_access,后缀是log
pattern="%h %l %u %t &quot;%r&quot; %s %b" />  #记录日志格式
</Context>
</Host>

七、tomcat反代配置

1、LNMT架构

Client (http) --> nginx (reverse proxy)(http) --> tomcat (http connector)

nginx连接器

nginx反代设置:
vim /etc/nginx/conf.d/ilinux.conf
server {
     listen 80;  #监听端口
      server_name www.ilinux.io; #服务名称 
location / {
proxy_pass http://192.168.1.15:80;  #匹配静态内容到后端静态主机的80端口
}

location ~* \.(jsp|do)$ {
proxy_pass http://192.168.1.16:8080; #匹配动态jsp内容到后端Tomcat主机
}

2、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)

http连接器:使用proxy_http_module模块反向代理

#proxy_http_module代理配置示例:
<VirtualHost *:80>  #定义虚拟主机
ServerName      tc1.ilinux.io
ProxyRequests Off   #关闭正向代理
ProxyVia        On     #在响应报文中加via
ProxyPreserveHost On  #请求报文转发到后端
<Proxy *>
    Require all granted #反代功能可以由那些用户使用
</Proxy>
#如果后端有多个虚拟主机,不能使用ip地址
ProxyPass / http://192.168.1.15:8080/ #后端tomcat主机地址端口  
ProxyPassReverse / http://192.168.1.15:8080/ #返回重定向 
<Location />
Require all granted  #此url可以被谁访问
</Location>
</VirtualHost>

ajp连接器:使用proxy_ajp_module代理

#proxy_ajp_module代理配置示例
<VirtualHost *:80>
ServerName      tc1.ilinux.io
ProxyRequests Off#关闭正向代理
ProxyVia        On     #在响应报文中加via
ProxyPreserveHost On
<Proxy *>
Require all granted#反代功能可以由那些用户使用
</Proxy>
#如果后端有多个虚拟主机,不能使用ip地址
ProxyPass / ajp://http://192.168.1.15:8009/  后端tomcat主机地址端口  
ProxyPassReverse / ajp://http://192.168.1.15:8009/
<Location />
Require all granted#此url可以被谁访问
</Location>
</VirtualHost>

八、Tomcat的常用优化配置:

1 、内存空间管理:

image.png image.png
image.png

编辑/etc/sysconfig/tomcat

 #重要不能超过32G!!!!!!!!!!!
JAVA_OPTS="-server -Xms32g -Xmx32g -XX:NewSize= -XX:MaxNewSize= -XX:PermSize= -XX:MaxPermSize=" 
#实验添加:
JAVA_OPTS= "-Xmx512m"  -Xms"512m"

-server:服务器模型
-Xms:堆内存初始化大小;
-Xmx:堆内存空间上限;
-XX:NewSize=:新生代空间初始化大小;
-XX:MaxNewSize=:新生代空间最大值;
-XX:PermSize=:持久代空间初始化大小;
-XX:MaxPermSize=:持久代空间最大值;

2、线程池设置:

<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

常用属性:
maxThreads:最大线程数;
minSpareThreads:最小空闲线程数;
maxSpareThreads:最大空闲线程数;
acceptCount:等待队列的最大长度;
URIEncoding:URI地址编码格式,建议使用UTF-8;
enableLookups:是否启用dns解析,建议禁用;
compression:是否启用传输压缩机制,建议“on";
compressionMinSize:启用压缩传输的数据流最小值,单位是字节;
compressableMimeType:定义启用压缩功能的MIME类型;
text/html, text/xml, text/css, text/javascript

3)、禁用8005端口;

<Server port="-1" shutdown="SHUTDOWN">

(4) 隐藏版本信息:

<Connector port="8080" protocol="HTTP/1.1"  connectionTimeout="20000" redirectPort="8443" />

Server="SOME STRING"   #加上自定义字符串

九、JVM常用的分析工具:

JVM的分析工具有:

1、jps工具

jps:Java虚拟机进程状态工具,

格式:
jps [-q] [-mlvV] [<hostid>]
-q:静默模式;
-v:显示传递给jvm的命令行参数;
-m:输出传入main方法的参数;
-l:输出main类或jar完全限定名称;
-V:显示通过flag文件传递给jvm的参数;
[<hostid>]:主机id,默认为localhost;

2、jinfo工具

jinfo:输出给定的java进程的所有配置信息;

格式:
jinfo [option] <pid>
-flags:to print VM flags打印标志位
-sysprops:to print Java system properties
-flag <name>:to print the value of the named VM flag

3、jstack工具

jstack:查看指定的java进程的线程栈的相关信息;

格式:
jstack [-l] <pid>
jstack -F [-m] [-l] <pid>
-l:long listings,会显示额外的锁信息,因此,发生死锁时常用此选项;
-m:混合模式,既输出java堆栈信息,也输出C/C++堆栈信息;
-F:当使用“jstack -l PID"无响应,可以使用-F强制输出信息;

4、jstat工具

jstat:输出指定的java进程的统计信息

格式:
jstat -help|-options
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]

示例:
# jstat -options
-class:class loader
-compiler:JIT
-gc:gc
-gccapacity:统计堆中各代的容量
-gccause:
-gcmetacapacity
-gcnew:新生代
-gcnewcapacity
-gcold:老年代
-gcoldcapacity
-gcutil
-printcompilation

[<interval> [<count>]]
interval:时间间隔,单位是毫秒;
count:显示的次数;

-gc:
YGC:新生代的垃圾回收次数;
YGCT:新生代垃圾回收消耗的时长;
FGC:Full GC的次数;
FGCT:Full GC消耗的时长;
GCT:GC消耗的总时长;

[root@tomcat-77 ~]# jps #查询java进程端口
3552 Jps
3541 Jstat
2296 Bootstrap
3529 Jstat
[root@tomcat-77 ~]# jstat -gc 2296 1000
 S0C    S1C    S0U    S1U      EC       EU        OC         OU       MC     MU    CCSC   CCSU   YGC     YGCT    FGC    FGCT     GCT   
1344.0 1344.0  0.0    36.9  10816.0   4288.3   26984.0    19719.9   25728.0 24993.2 2688.0 2449.0     83    0.201   6      0.184    0.385

5、jmap工具

jmap:Memory Map, 用于查看堆内存的使用状态;
jhat:堆分析工具
格式:

jmap [option] <pid>

查看堆空间的详细信息:

jmap -heap <pid>

查看堆内存中的对象的数目:

jmap -histo[:live] <pid>
live:只统计活动对象;

保存堆内存数据至文件中,而后使用jvisualvm或jhat进行查看:

jmap -dump:<dump-options> <pid>
dump-options:
live         dump only live objects; if not specified, all objects in the heap are dumped.
format=b     binary format
file=<file>  dump heap to <file>

6、jconsole和jvisualvm工具

远程图形工具软件
[root@tomcat-77 ~]# ssh -X root@192.168.1.77
The authenticity of host '192.168.1.77 (192.168.1.77)' can't be established.
ECDSA key fingerprint is SHA256:Pe8fJryVngsVj6R+3J5Vq2Bv5CPbWaZ08m1DwMmV1fc.
ECDSA key fingerprint is MD5:ea:8e:35:b5:c2:eb:cb:b7:8e:6f:55:06:5e:11:cd:9d.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '192.168.1.77' (ECDSA) to the list of known hosts.
root@192.168.1.77's password: 
Last login: Sun Oct  7 20:58:43 2018 from 192.168.1.78
[root@tomcat-77 ~]# jconsole
[root@tomcat-77 ~]# jvisualvm
上一篇 下一篇

猜你喜欢

热点阅读