1.what‘s this?

Stable performance, free Java web application server!

相关:

Java,Javac,JVM,JRE,JDK,Java SE,Java EE,JSP

基本逻辑:

xxx.java-->Javac-->xxx.class-->JVM-->MachineLanguage-->runing

一点儿总结:

一个java程序只有一个jvm进程,但可以开多线程。

tomcat通过servlet处理响应给客户端。

tomcat是JDK+JSP实现的Java EE,servlet的容器。

Tomcat相关组件:

server: 顶级类,一个server算一个tomcat实例。

service: server的子组件,用于封装connector和containor。

connector: 连接器,接收客户端请求处理返回给客户端。

containor: 容器,分析处理请求返回数据给connector。

engine: 定义servlet引擎。

host: 定义虚拟主机。

context: 定义webapp。

wrapper: 真正的servlet容器。

2.why use it?

一些优点:

开源,免费,配置简单,性能稳定。

一些缺点:

处理静态资源不如nginx,apache。

3.How to use it?

3.1.安装部署

1.安装java环境(jdk1.8.0_161)

流程:下载省略,解压,软链,配置环境变量。

tar -zxvf jdk-8u161-linux-x64.tar.gz -C /usr/local/
ln -s /usr/local/jdk1.8.0_161 /usr/local/jdk
sed -i.ori '$a export JAVA_HOME=/usr/local/jdk\nexport CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$JAVA_HOME/lib/tools.jar\nexport PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH' /etc/profile

检查是否安装完毕。

source /etc/profile
[root@izbp1gp76zixjk79d0yfaxz bin]# java -version
java version "1.8.0_161"
Java(TM) SE Runtime Environment (build 1.8.0_161-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.161-b12, mixed mode)

2.安装tomcat

流程:下载,解压,软链,配置环境变量。

wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.31/bin/apache-tomcat-8.5.31.tar.gz
tar -zxvf apache-tomcat-8.5.31.tar.gz -C /usr/local
ln -s /usr/local/apache-tomcat-8.5.31 /usr/local/tomcat
echo 'export TOMCAT_HOME=/usr/local/tomcat' >> /etc/profile
source /etc/profile

3.启动脚本:

方法一

#!/bin/bash
# Tomcat init script for linux.
#
# chkconfig: 2345 96 14
# description: The Apache Tomcat servlet/JSP container.
. /etc/profile
CATALINA_HOME=/usr/local/tomcat
export CATALINA_HOME
case $1 in
start)
exec $CATALINA_HOME/bin/catalina.sh start;;
stop)
exec $CATALINA_HOME/bin/catalina.sh stop;;
restart)
$CATALINA_HOME/bin/catalina.sh stop
sleep 2
exec $CATALINA_HOME/bin/catalina.sh start;;
*)
echo "Usage: `basename $0` {start|stop|restart}"
exit 1
;;
esac

方法二

#!/bin/bash
# chkconfig: 2345 74 44
# description: Tomcat is a Java servlet container.
. /etc/profile
TOMCAT_HOME=/usr/local/tomcat8_1 start(){
TOMCAT_PID=`ps -ef | grep "$TOMCAT_HOME" | grep -v "grep" | awk '{print $2}'`
if [ -z $TOMCAT_PID ];then
/bin/bash $TOMCAT_HOME/bin/startup.sh
else
echo "$0 is running"
fi
} stop(){
TOMCAT_PID=`ps -ef | grep "$TOMCAT_HOME" | grep -v "grep" | awk '{print $2}'`
if [ -z $TOMCAT_PID ];then
echo "$0 is not running"
else
echo "shutdown down $0"
kill -9 "$TOMCAT_PID" && echo "PID $TOMCAT_PID killed"
fi
} status(){
TOMCAT_PID=`ps -ef | grep "$TOMCAT_HOME" | grep -v "grep" | awk '{print $2}'`
if [ -z $TOMCAT_PID ];then
echo "$0 is not running."
else
echo "$0 is running PID is $TOMCAT_PID"
fi
} case $1 in
start)
start
;;
stop)
stop
;;
status)
status
;;
restart)
stop
start
;;
*)
echo "Usage:$0 {start|stop|status|restart}."
;;
esac

4.tomcat的目录结构

.
├── bin //功能脚本
├── conf //配置文件
│   └── Catalina
│   └── localhost
├── lib //存放web能访问的jar包
├── logs //web应用日志
├── temp //临时文件
├── webapps //web应用目录
│   ├── docs
│   │   ├── api
│   │   ├── appdev
│   │   │   └── sample
│   │   │   ├── docs
│   │   │   ├── src
│   │   │   │   └── mypackage
│   │   │   └── web
│   │   │   ├── images
│   │   │   └── WEB-INF
│   │   ├── architecture
│   │   │   ├── requestProcess
│   │   │   └── startup
│   │   ├── config
│   │   ├── elapi
│   │   ├── funcspecs
│   │   ├── images
│   │   │   └── fonts
│   │   ├── jspapi
│   │   ├── servletapi
│   │   ├── tribes
│   │   ├── WEB-INF
│   │   └── websocketapi
│   ├── examples
│   │   ├── jsp
│   │   │   ├── async
│   │   │   ├── cal
│   │   │   ├── checkbox
│   │   │   ├── colors
│   │   │   ├── dates
│   │   │   ├── error
│   │   │   ├── forward
│   │   │   ├── images
│   │   │   ├── include
│   │   │   ├── jsp2
│   │   │   │   ├── el
│   │   │   │   ├── jspattribute
│   │   │   │   ├── jspx
│   │   │   │   ├── misc
│   │   │   │   ├── simpletag
│   │   │   │   └── tagfiles
│   │   │   ├── jsptoserv
│   │   │   ├── num
│   │   │   ├── plugin
│   │   │   │   └── applet
│   │   │   ├── security
│   │   │   │   └── protected
│   │   │   ├── sessions
│   │   │   ├── simpletag
│   │   │   ├── snp
│   │   │   ├── tagplugin
│   │   │   └── xml
│   │   ├── servlets
│   │   │   ├── images
│   │   │   └── nonblocking
│   │   ├── WEB-INF
│   │   │   ├── classes
│   │   │   │   ├── async
│   │   │   │   ├── cal
│   │   │   │   ├── checkbox
│   │   │   │   ├── colors
│   │   │   │   ├── compressionFilters
│   │   │   │   ├── dates
│   │   │   │   ├── error
│   │   │   │   ├── examples
│   │   │   │   ├── filters
│   │   │   │   ├── jsp2
│   │   │   │   │   └── examples
│   │   │   │   │   ├── el
│   │   │   │   │   └── simpletag
│   │   │   │   ├── listeners
│   │   │   │   ├── nonblocking
│   │   │   │   ├── num
│   │   │   │   ├── sessions
│   │   │   │   ├── util
│   │   │   │   ├── validators
│   │   │   │   └── websocket
│   │   │   │   ├── chat
│   │   │   │   ├── drawboard
│   │   │   │   │   └── wsmessages
│   │   │   │   ├── echo
│   │   │   │   └── snake
│   │   │   ├── jsp
│   │   │   │   └── applet
│   │   │   ├── jsp2
│   │   │   ├── lib
│   │   │   └── tags
│   │   └── websocket
│   ├── host-manager
│   │   ├── images
│   │   ├── META-INF
│   │   └── WEB-INF
│   │   └── jsp
│   ├── manager
│   │   ├── images
│   │   ├── META-INF
│   │   └── WEB-INF
│   │   └── jsp
│   └── ROOT
│   └── WEB-INF
└── work //存放JSP编译出的.java,.class文件
└── Catalina
└── localhost
├── docs
├── examples
├── host-manager
├── manager
│   └── org
│   └── apache
│   └── jsp
│   └── WEB_002dINF
│   └── jsp
└── ROOT
└── org
└── apache
└── jsp

3.2.配置管理

Server.xml包含

server

service

connector

containor

engine

host

context

wrapper

<?xml version="1.0" encoding="UTF-8"?>
<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 name="Catalina">
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
<Engine name="Catalina" defaultHost="localhost">
<Realm className="org.apache.catalina.realm.LockOutRealm">
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
resourceName="UserDatabase"/>
</Realm>
<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" />
</Host>
</Engine>
</Service>
</Server>

3.3.站点部署

基本方法:

1.直接放代码。

2.放war包。

3.4.多实例集群部署

1.多实例

cd /usr/local
cp -a tomcat tomcat8_1
cp -a tomcat tomcat8_2
sed -i '22s#8005#8011#;69s#8080#8081#;123s#appBase=".*"# appBase="/data/wwwroot"#' tomcat8_1/conf/server.xml
sed -i '22s#8005#8012#;69s#8080#8082#;123s#appBase=".*"# appBase="/data/wwwroot"#' tomcat8_2/conf/server.xml
for i in {1..2};do /usr/local/tomcat8_$i/bin/startup.sh;done
mkdir /data/wwwroot -p
cp tomcat/webapps/manager/index.jsp /data/wwwroot/

2.集群nginx反向代理

[root@izbp1gp76zixjk79d0yfaxz conf.d]# cat tomcat.conf
upstream web-pools{
server 127.0.0.1:8080;
server 127.0.0.1:8081;
server 127.0.0.1:8082;
}
server {
listen 80;
server_name boyang.geek-zoo.net;
location / {
root html;
index index.jsp index.html index.htm;
proxy_pass http://web-pools;
}
}

3.5.监控

zabbix配置监控tomcat

3.6.安全优化及性能优化

3.6.1.安全优化

降权启动

telnet管理端口保护

ajp连接端口保护

禁用管理端

3.6.2.性能优化

屏蔽dns查询enableLookups="false"

JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m -XX:MaxPermSize=512m"

Tomcat之初识初体验的更多相关文章

  1. Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验

    Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出E ...

  2. MyEclipse性能调优初体验

    MyEclipse性能调优初体验 简介一下工作环境,MyEclipse2014,你懂的 项目中有一个基于web的工作流引擎,仅仅要执行起来就CPU差点儿耗尽(尽管看似27%,事实上已经把俺4核的CPU ...

  3. 蚂蚁 RPC 框架 SOFA-RPC 初体验

    前言 最近蚂蚁金服开源了分布式框架 SOFA,楼主写了一个 demo,体验了一下 SOFA 的功能,SOFA 完全兼容 SpringBoot(当然 Dubbo 也是可以兼容的). 项目地址:Alipa ...

  4. (一)SpringBoot基础篇- 介绍及HelloWorld初体验

    1.SpringBoot介绍: 根据官方SpringBoot文档描述,BUILD ANYTHING WITH SPRING BOOT (用SPRING BOOT构建任何东西,很牛X呀!),下面是官方文 ...

  5. Spring Boot 学习笔记1——初体验之3分钟启动你的Web应用[z]

    前言 早在去年就简单的使用了一下Spring Boot,当时就被其便捷的功能所震惊.但是那是也没有深入的研究,随着其在业界被应用的越来越广泛,因此决定好好地深入学习一下,将自己的学习心得在此记录,本文 ...

  6. (一)SpringBoot2.0基础篇- 介绍及HelloWorld初体验

    1.SpringBoot介绍: 根据官方SpringBoot文档描述,BUILD ANYTHING WITH SPRING BOOT (用SPRING BOOT构建任何东西,很牛X呀!),下面是官方文 ...

  7. Node.js 网页瘸腿爬虫初体验

    延续上一篇,想把自己博客的文档标题利用Node.js的request全提取出来,于是有了下面的初哥爬虫,水平有限,这只爬虫目前还有点瘸腿,请看官你指正了. // 内置http模块,提供了http服务器 ...

  8. SpringFox 初体验

    本文来自网易云社区. 1.什么是SpringFox? 1.1 Springfox 是一个开源的API Doc的框架, 它的前身是swagger-springmvc,可以将我们的Controller中的 ...

  9. Docker深入浅出系列 | 容器初体验

    目录 Docker深入浅出系列 | 容器初体验 教程目标 预备工作 容器与虚拟化技术 什么是Docker 为什么要用Docker 事例 什么是容器镜像和容器 容器与虚拟机的区别 Vagrant与Doc ...

随机推荐

  1. virtualbox+vagrant学习-2(command cli)-25-Machine Readable Output

    Machine Readable Output机器可读的输出 每个vagrant命令都接受一个--machine-readable的标志,它支持机器可读的输出模式.在这种模式下,终端的输出被机器友好的 ...

  2. ganache-cli

    安装: npm install -g ganache-cli@6.1.8 使用: userdeMacBook-Pro:~ user$ ganache-cli -m "success rifl ...

  3. Opencv——级联分类器(AdaBoost)

    API说明: cv::CascadeClassifier::detectMultiScale(InputArray image,//输入灰度图像 CV_OUT std::vector<Rect& ...

  4. spark机制理解(一)

    一  基本术语 Application:  基于Spark的用用户程序,包含了Driver程序和集群上的Executor. Driver Program: 运行行main函数并且新建SparkCont ...

  5. mac 设置mysql开机自启动

    1.编辑一个mysql启动文件. 在终端里面输入: sudo vi /Library/LaunchDaemons/com.mysql.mysql.plist 2.输入启动文件内容: <?xml ...

  6. Robosup3D平台搭建

    目录 1.安装simspark及默认播放器 安装依赖库/下载simspark源码 编译并安装simspark 编译并安装rcssmonitor3d播放器 2.安装Roboviz播放器 安装java 安 ...

  7. hive介绍、安装配置、表操作基础知识适合小白学习

    1.hive概述 Apache Hive数据仓库软件有助于使用SQL读取,编写和管理驻留在分布式存储中的大型数据集.可以将结构投影到已存储的数据中.提供了命令行工具和JDBC驱动以将用户连接到Hive ...

  8. Go指南 - 笔记

    Go指南 - 笔记 标签(空格分隔): Go Go指南 一.基础 1.包 每个Go程序都是由包构成的. 程序从main包开始运行. 包名与导入路径的最后一个元素一致 2.导入 分组导入:使用圆括号组合 ...

  9. 批量生成文件夹内所有文件md5

    说明:md5批量生成批处理脚本,无需安装任何软件,直接调用系统文件进行生成,简单基于windows命令编写了一个批量生成md5值的脚本. 使用说明:新建文本文档,命名为get_md5.bat,直接将代 ...

  10. 3-[Mysql]-库操作

    1.系统数据库 information_schema: 虚拟库,不占用磁盘空间,存储的是数据库启动后的一些参数,如用户表信息.列信息.权限信息.字符信息等 performance_schema: My ...