需要安装JDK JAVA Development Kit //JAVA 2 SE 的接口
TOMCAT 的安装:
-
yum 安装
#yum install -y java-1.8.0-openjdk-devel
如下界面出现的话就是安装OK
注意:安装完成后,要配置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的控制端口和命令,注意修改
defaulthost 默认的虚拟主机
host 相当于之前虚拟主机
<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 "%r" %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:工作目录;//
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
自动部署://不建议用,通过测试可以
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
tomcat管理界面用户认证:// 以Yum安装的为例
cd /etc/tomcat/
# vim tomcat-user.xml
重启服务 并链接实验
配置用于管理hostmanager //参照配置文件底层示例
常用配置:
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内容
链接实验:
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;
实验示例:
Context组件: //内嵌到虚拟主机host中
示例:
<Context path=”/PATH” docBase=”/PATH/TO/SOMEDIR” reloadable=””/>
context path : uri 路径
实验示例:
#cp -a /usr/share/tomcat/webapps/ROOT /app/tomcat/test
重启链接实验:
-
VALVE : 控制模块
Valve组件:
<Valve className=”org.apache.catalina.valves.AccessLogValve” directory=”logs”
prefix=”localhost_access_log” suffix=”.txt”
pattern=”%h %l %u %t "%r" %s %b” />
Valve存在多种类型:
定义访问日志:org.apache.catalina.valves.AccessLogValve
定义访问控制:org.apache.catalina.valves.RemoteAddrValve
访问控制也可以用iptables 管控
TOMCAT 的集群组合实验:
nginx+tomcat // 本机实验;centos7
开启服务并链接:
nginx+tomcat //本机实验;代理虚拟主机名
重新启动并链接实验
nginx+tomcat // 实习那动静分离;这里仅仅实验。
重启链接测试
额外参考: rewrite 规则:
apache+tomcat:// 利用proxy_http_module
在/etc/httpd/conf.d/ 新建 tomcat.conf
启动服务并测试链接
apache+tomcat:// 利用proxy_ajp_module;重点是ajp
重启并链接测验:
负载均衡时的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 创建目录:
修改index.html内容
启动tomcat服务并测试:
48.72 同样配置
ip 48.64 安装 并配置 nginx /etc/nginx/nginx.conf
在 http 字段中填加 如下字段
在/etc/nginx/conf.d/default.conf 填加转发规则
重启服务并测试链接
现在填加会话保持: // memcached server 来实现
安装memcached 并开启服务
# yum install memcached -y
systemctl start memcached
额外: //配置文件的内容。
配置tomcat文件设定
a.首先架起tomcat与memcached 的桥梁;放置到下图目录中
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 保持不变
tomcat 调优相关: //依据JVM 特性进行设置
JVM 内存区的结构
公共区
方法区(method area) //加载class 常量 静态变量和编译后的代码
堆内存 (JAVA heap) //所有的对象和数组、
私有区
线程栈 (JAVA Stack) //私有数据,线程调用进入和返回栈的操作。
PC寄存器 (program covnter register) //每个线程自己的计数寄存器,用来存储当前线程存储字节码的地址。
本地方法栈 (native stack ) //为调用本地方法服务(类似与JAVA STACK)
JAVA 代码运行:
创建对象–>运行对象–>销毁对象
内存中的结构
eden –>from–>to–>old–>perm (每一次筛选,计数非0 的对象状态流程)
调优相关
原创文章,作者:zhoulz,如若转载,请注明出处:http://www.178linux.com/79614