Tomcat构建高负载web服务器

前言
什么是JAVA虚拟机?
所谓虚拟机,就是一台虚拟的计算机。他是一款软件,用来执行一系列虚拟计算机指令。大体上,虚拟机可以分为系统虚拟机和程序虚拟机。大名鼎鼎的VisualBox、VMware就属于系统虚拟机。他们完全是对物理计算机的仿真。提供了一个可以运行完整操作系统的软件平台;程序虚拟机的典型代表就是Java虚拟机,它专门为执行单个计算机程序而设计,在Java虚拟机中执行的指令我们称为Java字节码指令。无论是系统虚拟机还是程序虚拟机,在上面运行的软件都被限制于虚拟机提供的资源中。

JAVA 如何做到跨平台?
同一个JAVA程序(JAVA字节码的集合),通过JAVA虚拟机(JVM)运行于各大主流操作系统平台比如Windows、CentOS、Ubuntu等。程序以虚拟机为中介,来实现跨平台。

Java语言:
Java语言的一个非常重要的特点就是与平台的无关性。而使用Java虚拟机是实现这一特点的关键。一般的高级语言如果要在不同的平台上运行,至少需要编译成不同的目标代码。而引入Java语言虚拟机后,Java语言在不同平台上运行时不需要重新编译。Java语言使用Java虚拟机屏蔽了与具体平台相关的信息,使得Java语言编译程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。Java虚拟机在执行字节码时,把字节码解释成具体平台上的机器指令执行。这就是Java的能够“一次编译,到处运行”的原因。

JDK简介:JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。包括JVM,JVM是Java Virtual Machine(Java虚拟机)的缩写,
JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。

JRE也务必了解,JRE为Java Runtime Environment运行环境的简称,Java Runtime Environment(包括Java Plug-in)是Sun的产品,包括两部分:Java Runtime Environment和Java Plug-in。JavaRuntimeEnvironment(JRE)是可以在其上运行、测试和传输应用程序的Java平台。

Java SE
Java SE(Java Platform,Standard Edition),应该先说这个,因为这个是标准版本。JavaSE 可以开发和部署在桌面、服务器、嵌入式环境和实时环境中使用的 Java 应用程序。是EE,和ME的基础。一般就是指JDK。就是Java的基础语法(变量、方法、类之间的调用、关系,继承、接口、线程之类的),工具包(java.util.* ),或者其他的一些封装,是学习其他的基础。

Java EE
Java EE (Java Platform,Enterprise Edition),java 的企业版本。JavaEE,其实是一套规范,就是用java语言做企业开发中的一整套规范,比如类怎么封装,网页的请求要用什么方法处理,语言编码一类的处理,拦截器啊什么的定义,请求返回得有什么信息。比如:tomcat就是按照这套规范开发的容器软件,还有什么weblogic,JBoss、Resin等等
正因为我们开发网站(使用JSP,Servelet或者封装了这些的框架:SSH)可以放在tomcat,也可以放在JBoss,因为都是按照一个规范开发的东西,实际使用的还是JavaSE的那些东西,多出来的就是EE的一些规范类的封装代码。

Java ME
Java ME(Java Platform,Micro Edition),java的微型版本。
JavaME 是微型版本,顾名思义,使用在手机啊,小设备啊上面的Java版本,特点就是小,相比JavaSE精简了很大一部分东西,(增加了一些小设备上的专有API,这个不是很确定)。
安卓中既然用的是Java,那么Java的语法应该都是适用的。所以SE是核心基础。其他的都是使用方法方式不同。

Tomcat介绍:
Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP 2.0 规范。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Tomcat下载地址:

 http://tomcat.apache.org/

JDK下载地址

http://www.oracle.com/technetwork/java/javase/downloads/index.html

正题
一、Java环境的部署

准备一台主机——192.168.231.41
(1)解包,多版本部署java

# tar xf jdk-8u181-linux-x64.tar.gz  -C /usr/local
# ln -s /usr/local/jdk1.8.0_181/ /usr/local/java

(2) 配置环境变量

# vim /etc/profile
JAVA_HOME=/usr/local/java
PATH=$JAVA_HOME/bin:$PATH
export JAVA_HOME PATH
# source /etc/profile
# env |grep JAVA
JAVA_HOME=/usr/local/java

(3)测试Java

# java -version
java version "1.8.0_181"
Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)

二、安装Tomcat

# tar xf apache-tomcat-7.0.103.tar.gz   -C /usr/local/
# ln -s /usr/local/apache-tomcat-7.0.103/ /usr/local/tomcat

定义Tomcat所需环境变量:
# vim /etc/profile	
CATALINA_HOME=/usr/local/tomcat              #Tomcat安装目录
export CATALINA_HOME
# source /etc/profile

三、启动Tomcat

# bash  /usr/local/tomcat/bin/startup.sh
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/java
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
# netstat -tnlp |grep java
tcp6       0      0 :::8080                 :::*                    LISTEN      1222/java           
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      1222/java           
tcp6       0      0 :::8009                 :::*                    LISTEN      1222/java         
关于tomcat端口:
			8005 是tomcat本身的端口
			8080 tomcat负责建立HTTP连接.
			8009 tomcat负责和其他的HTTP服务器建立连接。				

访问,注意关闭防火墙,注意端口
在这里插入图片描述
四、Tomct介绍
(1 )tomcat主目录介绍

# tree -L 1    /usr/local/tomcat/
.
├── bin              #存放tomcat管理脚本
├── conf             # tomcat 配置文件存放目录
├── lib              # web应用调用的jar包存放路径
├── LICENSE
├── logs             # tomcat 日志存放目录,catalina.out 为主要输出日志
├── NOTICE
├── RELEASE-NOTES
├── RUNNING.txt
├── temp             # 存放临时文件
├── webapps         # web程序存放目录
└── work             # 存放编译产生的.java 与 .class文件

(2) webapps目录介绍

# tree -L 1   /usr/local/tomcat/webapps/
.
├── docs            # tomcat 帮助文档
├── examples       # web应用示例
├── host-manager  # 主机管理
├── manager         # 管理
└── ROOT             # 默认站点根目录

(3) Tomcat配置文件目录介绍(conf)

# tree -L 1  /usr/local/tomcat/conf/
.
├── Catalina
├── catalina.policy
├── catalina.properties
├── context.xml
├── logging.properties
├── server.xml           # tomcat 主配置文件
├── tomcat-users.xml    # tomcat 管理用户配置文件
├── tomcat-users.xsd
└── web.xml

(3)解决Tomcat启动慢的方法
Tomcat启动慢主要原因是生成随机数的时候卡住了,导致tomcat启动不了。是否有足够的值来用于产生随机数,可以通过如下命令来查看

# cat /proc/sys/kernel/random/entropy_avail
1035
# vim $JAVA_HOME/jre/lib/security/java.security
		#将
		securerandom.source=file:/dev/random
		#改为
		securerandom.source=file:/dev/urandom
		#问题解决

五、Tomcat多实例
(1)关闭主站

# bash /usr/local/tomcat/bin/shutdown.sh 

(2)制作多实例目录

# cp -r /usr/local/tomcat/{conf,logs,temp,work} /usr/local/tomcat/instance1/
# cp -r /usr/local/tomcat/{conf,logs,temp,work} /usr/local/tomcat/instance2/
# cp -r /usr/local/tomcat/{conf,logs,temp,work} /usr/local/tomcat/instance3/

(3)查看目录结构

# tree -d -L 2 /usr/local/tomcat/
/usr/local/tomcat/
├── bin
├── conf
│   └── Catalina
├── instance1
│   ├── conf
│   ├── logs
│   ├── temp
│   └── work
├── instance2
│   ├── conf
│   ├── logs
│   ├── temp
│   └── work
├── instance3
│   ├── conf
│   ├── logs
│   ├── temp
│   └── work
├── lib
├── logs
├── temp
├── webapps
│   ├── docs
│   ├── examples
│   ├── host-manager
│   ├── manager
│   └── ROOT
└── work
    └── Catalina

(4)修改端口
将web程序拷贝三分,分别修改为不同的端口
第一份:

# vim /usr/local/tomcat/instance1/conf/server.xml
<Connector port="8081" protocol="HTTP/1.1" 
               connectionTimeout="20000"
               redirectPort="8443" />
       <Server port="8091" shutdown="SHUTDOWN">
                  appBase="/webapps"

第二份:

# cp /usr/local/tomcat/instance1/conf/server.xml  /usr/local/tomcat/instance2/conf/
# vim  /usr/local/tomcat/instance2/conf/server.xml
<Connector port="8082" protocol="HTTP/1.1"  
<Server port="8092" shutdown="SHUTDOWN">

第三份:

# cp /usr/local/tomcat/instance1/conf/server.xml  /usr/local/tomcat/instance3/conf/
# vim  /usr/local/tomcat/instance2/conf/server.xml
<Connector port="8083" protocol="HTTP/1.1"  
<Server port="8093" shutdown="SHUTDOWN">

(5)做启动脚本

# vim /usr/local/tomcat/instance1/ins1.sh
#!/bin/bash
#instance1
. /etc/init.d/functions
export CATALINA_BASE="/usr/local/tomcat/instance1"

case "$1" in
start)
        $CATALINA_HOME/bin/startup.sh
        ;;
stop)
        $CATALINA_HOME/bin/shutdown.sh
        ;;
restart)
        $CATALINA_HOME/bin/shutdown.sh
        sleep 5
        $CATALINA_HOME/bin/startup.sh
        ;;
esac
export JAVA_OPTS='-Xms64m -Xmx128m'

# cp /usr/local/tomcat/instance1/ins1.sh /usr/local/tomcat/instance2/ins2.sh
# vim /usr/local/tomcat/instance2/ins2.sh
#!/bin/bash
#instance2              #####
. /etc/init.d/functions
export CATALINA_BASE="/usr/local/tomcat/instance2"    #####

case "$1" in
start)
        $CATALINA_HOME/bin/startup.sh
        ;;
stop)
        $CATALINA_HOME/bin/shutdown.sh
        ;;
restart)
        $CATALINA_HOME/bin/shutdown.sh
        sleep 5
        $CATALINA_HOME/bin/startup.sh
        ;;
esac

# cp /usr/local/tomcat/instance1/ins1.sh /usr/local/tomcat/instance3/ins3.sh
# vim /usr/local/tomcat/instance3/ins3.sh
#!/bin/bash
#instance3
. /etc/init.d/functions
export CATALINA_BASE="/usr/local/tomcat/instance3"

case "$1" in
start)
        $CATALINA_HOME/bin/startup.sh
        ;;
stop)
        $CATALINA_HOME/bin/shutdown.sh
        ;;
restart)
        $CATALINA_HOME/bin/shutdown.sh
        sleep 5
        $CATALINA_HOME/bin/startup.sh
        ;;
esac
export JAVA_OPTS='-Xms64m -Xmx128m'

(6)赋权

# chmod +x /usr/local/tomcat/instance1/ins1.sh 
# chmod +x /usr/local/tomcat/instance2/ins2.sh 
# chmod +x /usr/local/tomcat/instance3/ins3.sh 

(7)网站源码

# mkdir /webapps
# cp -r /usr/local/tomcat/webapps/ROOT/ /webapps/

(8)启动

# /usr/local/tomcat/instance1/ins1.sh start
# /usr/local/tomcat/instance2/ins2.sh start
# /usr/local/tomcat/instance3/ins3.sh start

(9)测试
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

面试题:
JVM常用分析工具:
常用的java分析命令有哪些?说明含义。
jps
描述:jps (Java Virtual Machine Process Status Tool)是JDK 1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/unix平台上简单察看当前java进程的一些简单情况。ps命令我们经常用到,这个命令主要是用来显示当前系统的进程情况。比如有哪些进程及其 id。jps命令也是一样,它的作用是显示当前系统的java进程情况及其id号。我们可以通过它来查看我们到底启动了几个java进程(因为每一个java程序都会独占一个java虚拟机实例)以及他们的进程号(为下面几个程序做准备),并可通过opt来查看这些进程的详细启动参数。
语法:

jps [-q] [-mlvV] [<hostid>]
-q    安静,只显示pid,不显示class名称,jar文件名和传递给main 方法的参数
-m   输出传递给main 方法的参数,在嵌入式jvm上可能是null
-l (显示完整路径)
-v (显示传递给JVM的命令行参数)
-V (显示通过flag文件传递给JVM的参数)
hostid是主机id,默认localhost

jinfo
描述:负责观察进程运行环境参数,包括Java System属性和JVM命令行参数。当系统崩溃时,jinfo可以从core文件里面知道崩溃的Java应用程序的配置信息。
语法:

jinfo [ option ] pid
	jinfo [ option ] executable core
	jinfo [ option ] [server-id@]remote-hostname-or-IP
	pid   进程号
	executable    产生 core dump 的 java executable
	core   core file
	remote-hostname-or-IP   主机名或ip
	server-id   远程主机上的debug server的唯一id
	-flags         打印命令行参数
	-sysprops      打印系统属性

jstack
描述:用来观察 jvm 中当前所有线程的运行情况和线程当前状态。
语法:

jstack [ option ] pid
	jstack [ option ] executable core
	jstack [ option ] [server-id@]remote-hostname-or-IP
	core 将被打印信息的core dump文件
	remote-hostname-or-IP 远程debug服务的主机名或ip
	server-id 唯一id,假如一台主机上多个远程debug服务
	pid    需要被打印配置信息的java进程id,可以用jps查询
	选项
		-F      当’jstack [-l] pid’没有相应的时候强制打印栈信息
		-l      长列表. 打印关于锁的附加信息,例如属于java.util.concurrent的ownable synchronizers列表.
		-m     打印java和native c/c++框架的所有栈信息.

jstat
描述:用于输出指定 java 进程的统计信息。利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对进程的classloader,compiler情况;可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量,以及加载类的数量。
语法:

jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
	class:统计classloader的行为
	compiler:统计hotspot just-in-time编译器的行为
	gc:统计gc行为
	gccapacity:统计堆中代的容量、空间
	gccause:垃圾收集统计,包括最近引用垃圾收集的事件,基本同gcutil,比gcutil多了两列
	gcnew:统计新生代的行为
	gcnewcapacity:统计新生代的大小和空间
	gcold:统计旧生代的行为
	gcoldcapacity:统计旧生代的大小和空间
	gcpermcapacity:统计永久代的大小和空间
	gcutil:垃圾收集统计
	printcompilation:hotspot编译方法统计
	-h n 每n个样本,显示header一次
	-t n 在第一列显示时间戳列,时间戳时从jvm启动开始计算
	<vmid>   就是进程号
	<interval> interval是监控时间间隔,单位为微妙,不提供就意味着单次输出
	<count>      count是最大输出次数,不提供且监控时间间隔有值的话, 就无限打印

实例:
在这里插入图片描述

列名介绍:
	Column 	Description
	Loaded 	被读入类的数量
	Bytes 	被读入的字节数(K)
	Unloaded 	被卸载类的数量
	Bytes 	被卸载的字节数(K)
	Time 	花费在load和unload类的时间

jmap
描述: 用来监视进程运行中的jvm物理内存的占用情况,该进程内存内,所有对象的情况,例如产生了哪些对象,对象数量。当系统崩溃时,jmap 可以从core文件或进程中获得内存的具体匹配情况,包括Heap size, Perm size等。
语法

jmap [option] <pid>
	jmap [option] <executable <core>
	jmap [option] [server_id@]<remote server IP or hostname>
	-dump:format=b,file=<filename> pid    # dump堆到文件,format指定输出格式,live指明是活着的对象,file指定文件名
	-finalizerinfo  # 打印等待回收对象的信息
	-heap           # 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况,可以用此来判断内存目前的使用情况以及垃圾回收情况
	-histo[:live]   # 打印堆的对象统计,包括对象数、内存大小等等 (因为在dump:live前会进行full gc,因此不加live的堆大小要大于加live堆的大小 )
	-permstat       # 打印classload类装载器和 jvm heap长久层的信息. 包含包括每个装载器的名字,活跃,地址,父装载器,和其总共加载的类大小。另外,内部String的数量和占用内存数也会打印出来. 
	-F              # 强制,强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效.  
	-J              # 传递参数给jmap启动的jvm. ,如:-J-Xms256m

JVM运维实用监控工具
请说出VirtualVM性能分析的主要方式?
监视
监视是一种用来查看应用程序运行时行为的一般方法。通常会有多个视图(View)分别实时地显示 CPU 使用情况、内存使用情况、线程状态以及其他一些有用的信息,以便用户能很快地发现问题的关键所在。

转储
转储:性能分析工具从内存中获得当前状态数据并存储到文件用于静态的性能分析。Java 程序是通过在启动 Java 程序时添加适当的条件参数来触发转储操作的。
它包括以下三种:
系统转储:JVM 生成的本地系统的转储,又称作核心转储。一般的,系统转储数据量大,需要平台相关的工具去分析,如 Windows 上的 windbg 和 Linux 上的 gdb。
Java 转储:JVM 内部生成的格式化后的数据,包括线程信息,类的加载信息以及堆的统计数据。通常也用于检测死锁。
堆转储:JVM 将所有对象的堆内容存储到文件

快照
快照:应用程序启动后,性能分析工具开始收集各种运行时数据,其中一些数据直接显示在监视视图中,而另外大部分数据被保存在内部,直到用户要求获取快照,基于这些保存的数据的统计信息才被显示出来。快照包含了应用程序在一段时间内的执行信息,通常有 CPU 快照和内存快照两种类型。
CPU 快照:主要包含了应用程序中函数的调用关系及运行时间,这些信息通常可以在 CPU 快照视图中进行查看。
内存快照:主要包含了内存的分配和使用情况、载入的所有类、存在的对象信息及对象间的引用关系等。这些信息通常可以在内存快照视图中进行查看。

性能分析
性能分析:性能分析是通过收集程序运行时的执行数据来帮助开发人员定位程序需要被优化的部分,从而提高程序的运行速度或是内存使用效率,主要有以下三个方面:

CPU 性能分析:CPU 性能分析的主要目的是统计函数的调用情况及执行时间,或者更简单的情况就是统计应用程序的 CPU 使用情况。通常有 CPU 监视和 CPU 快照两种方式来显示 CPU 性能分析结果。
内存性能分析:内存性能分析的主要目的是通过统计内存使用情况检测可能存在的内存泄露问题及确定优化内存使用的方向。通常有内存监视和内存快照两种方式来显示内存性能分析结果。
线程性能分析:线程性能分析主要用于在多线程应用程序中确定内存的问题所在。一般包括线程的状态变化情况,死锁情况和某个线程在线程生命期内状态的分布情况等

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值