云计算百科
云计算领域专业知识百科平台

企业级WEB应用服务器TOMCAT

WEB技术

WEB框架

web资源和访问

从静态服务器请求HTMLCSSJS等文件发送到浏览器端,浏览器端接收后渲染在浏览器上从图片服务

器请求图片资源显示

从业务服务器访问动态内容,动态内容是请求后有后台服务访问数据库后得到的,最终返回到浏览器端

手机 App 访问

内置了HTMLJS文件,不需要从静态WEB服务器下载 JS HTML。为的就是减少文件的发送,现代前

端开发使用的JS文件太多或太大了

有必要就从图片服务器请求图片,从业务服务器请求动态数据

客户需求多样,更多的内容还是需要由业务服务器提供,业务服务器往往都是由一组服务器组成。

结合反向代理实现tomcat部署

常见部署方式介绍

安装 Tomcat:

#安装java环境
[root@tomcat ~]# yum install java-1.8.0-openjdk.x86_64 -y
#查看java版本
[root@tomcatA ~]# java -version
openjdk version "1.8.0_402"
OpenJDK Runtime Environment (build 1.8.0_402-b06)
OpenJDK 64-Bit Server VM (build 25.402-b06, mixed mode)
#查看java的环境目录
[root@tomcatA ~]# which java
/usr/bin/java
[root@tomcatA ~]# ll /usr/bin/java
lrwxrwxrwx 1 root root 22 Jul 30 10:41 /usr/bin/java -> /etc/alternatives/java
#java的运行环境
[root@tomcatA ~]# cd /etc/alternatives/jre
[root@tomcatA jre]# ls
ASSEMBLY_EXCEPTION bin lib LICENSE THIRD_PARTY_README

安装并启动tomcat:

#解压并生成tomcat的程序目录
[root@tomcatA ~]# tar zxf apache-tomcat-9.0.107.tar.gz -C /usr/local/
[root@tomcatA ~]# cd /usr/local/
[root@tomcatA local]# ls
apache-tomcat-9.0.107 bin etc games include lib lib64 libexec sbin share
src
[root@tomcatA local]# mv apache-tomcat-9.0.107/ tomcat
[root@tomcatA local]# ls
3.查看端口
4.访问tomcat
bin etc games include lib lib64 libexec sbin share src tomcat
#启动tomcat
[root@tomcatA local]# cd tomcat/
[root@tomcatA tomcat]# cd bin/
[root@tomcatA bin]# ls
bootstrap.jar commons-daemon-native.tar.gz makebase.sh tomcatjuli.jar
catalina.bat configtest.bat setclasspath.bat tomcatnative.tar.gz
catalina.sh configtest.sh setclasspath.sh toolwrapper.bat
catalina-tasks.xml daemon.sh shutdown.bat toolwrapper.sh
ciphers.bat digest.bat shutdown.sh version.bat
ciphers.sh digest.sh startup.bat version.sh
commons-daemon.jar makebase.bat startup.sh
[root@tomcatA 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
Using CLASSPATH:
/usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.

生成tomcat的启动文件:

生成tomcat的主配置文件:

[root@tomcat ~]# vim /usr/local/tomcat/conf/tomcat.conf
JAVA_HOME=/etc/alternatives/jre

生成启动文件

[root@tomcat ~]# vim /lib/systemd/system/tomcat.service
[Unit]
Description=Tomcat
#After=syslog.target network.target remote-fs.target nss-lookup.target
After=syslog.target network.target
[Service]
Type=forking
EnvironmentFile=/usr/local/tomcat/conf/tomcat.conf
ExecStart=/usr/local/tomcat/bin/startup.sh
ExecStop=/usr/local/tomcat/bin/shutdown.sh
PrivateTmp=true
User=tomcat
Group=tomcat
[Install]
WantedBy=multi-user.target

生成tomcat用户并设定软件安装目录权限

useradd -s /sbin/nologin -M tomcat
chown tomcat.tomcat /usr/local/tomcat/ -R

用启动脚本开启服务:

systemctl enable –now tomcat

集群部署及绘画绑定:

利用 nginx 反向代理实现:

利用nginx反向代理功能,实现图中的代理功能,将用户请求全部转发至指定的同一个tomcat主机

利用nginx指令proxy_pass 可以向后端服务器转发请求报文,并且在转发时会保留客户端的请求报文中的 host首部

安装nginx:

dnf install nginx -y

vim vhosts.conf

server {
listen 80;
server_name www.timinglee.org;

location ~ \\.jsp$ {
proxy_pass http://172.25.254.10:8080;
}
}
~

vim /etc/hosts

重启A,B的tomcat:

systemctl restart tomcat.service

重启nginx:

systemctl start nginx

测试:

curl -I 172.25.254.10:8080/test.jsp

实现tomcat中的负载均衡

动态服务器的问题,往往就是并发能力太弱,往往需要多台动态服务器一起提供服务。如何把并发的压

力分摊,这就需要调度,采用一定的调度策略,将请求分发给不同的服务器,这就是Load Balance负载

均衡。

当单机Tomcat,演化出多机多级部署的时候,一个问题便凸显出来,这就是Session。而这个问题的由

来,都是由于HTTP协议在设计之初没有想到未来的发展。

 HTTP的无状态,有连接和短连接

无状态:指的是服务器端无法知道2次请求之间的联系,即使是前后2次请求来自同一个浏览器,也

没有任何数据能够判断出是同一个浏览器的请求。后来可以通过cookiesession机制来判断。

浏览器端第一次HTTP请求服务器端时,在服务器端使用session这种技术,就可以在服务器端

产生一个随机值即SessionID发给浏览器端,浏览器端收到后会保持这个SessionIDCookie

中,这个Cookie值一般不能持久存储,浏览器关闭就消失。浏览器在每一次提交HTTP请求的

时候会把这个SessionID传给服务器端,服务器端就可以通过比对知道是谁了

Session通常会保存在服务器端内存中,如果没有持久化,则易丢失

Session会定时过期。过期后浏览器如果再访问,服务端发现没有此ID,将给浏览器端重新发

新的SessionID

[root@Nginx ~]# vim /usr/local/nginx/conf.d/vhosts.conf

location ~ \\.jsp$ {

proxy_pass http://172.25.254.10:8080;

}

lee.timinglee.org/test.jsp更换浏览器也将重新获得新的SessionID

有连接:是因为它基于TCP协议,是面向连接的,需要3次握手、4次断开。

短连接:Http 1.1之前,都是一个请求一个连接,而Tcp的连接创建销毁成本高,对服务器有很大的

影响。所以,自Http 1.1开始,支持keep-alive,默认也开启,一个连接打开后,会保持一段时间

(可设置),浏览器再访问该服务器就使用这个Tcp连接,减轻了服务器压力,提高了效率。

服务器端如果故障,即使Session被持久化了,但是服务没有恢复前都不能使用这些SessionID

如果使用HAProxy或者Nginx等做负载均衡器,调度到了不同的Tomcat上,那么也会出现找不到

SessionID的情况。

upstream tomcat {
#ip_bash;
#hash $cookie_JSESSIONID;
server 172.25.254.10:8080;
server 172.25.254.20:8080;
}

server {
listen 80;
server_name www.timinglee.org;
root /webdataw/nginx/timinglee.org/lee;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
try_files $uri $uri.html $uri/index.html /error/default.html;

location ~ \\.jsp$ {
proxy_pass http://tomcat;
}
}

测试:

http://www.timinglee.org:8080/test.jsp

Memcached:

Memcached简介:

Memcached 只支持能序列化的数据类型,不支持持久化,基于Key-Value的内存缓存系统memcached

虽然没有像redis所具备的数据持久化功能,比如RDBAOF都没有,但是可以通过做集群同步的方式,

让各memcached服务器的数据进行同步,从而实现数据的一致性,即保证各memcached的数据是一样

的,即使有任何一台 memcached 发生故障,只要集群中有一台 memcached 可用就不会出现数据丢

失,当其他memcached 重新加入到集群的时候,可以自动从有数据的memcached 当中自动获取数据并

提供服务。

Memcached 借助了操作系统的 libevent 工具做高效的读写。libevent是个程序库,它将Linuxepoll

BSD类操作系统的kqueue等事件处理功能封装成统一的接口。即使对服务器的连接数增加,也能发挥高

性能。memcached使用这个libevent库,因此能在LinuxBSDSolaris等操作系统上发挥其高性能

Memcached 支持最大的内存存储对象为1M,超过1M的数据可以使用客户端压缩或拆分报包放到多个

key中,比较大的数据在进行读取的时候需要消耗的时间比较长,memcached 最适合保存用户的

session实现session共享

Memcached存储数据时, Memcached会去申请1MB的内存, 把该块内存称为一个slab, 也称为一个page

Memcached 支持多种开发语言,包括:JAVA,C,Python,PHP,C#,Ruby,Perl

Memcached 官网:http://memcached.org/

memcached的安装与启动

yum install memcached -y

vim /etc/sysconfig/memcached
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS="-l 0.0.0.0,::1"

systemctl enable –now memcached

netstat -antlupe | grep memcache

memcached 操作命令

五种基本 memcached 命令执行最简单的操作。这些命令和操作包括:

set

add

replace

get

delete

#前三个命令是用于操作存储在 memcached 中的键值对的标准修改命令,都使用如下所示的语法:
command <key> <flags> <expiration time> <bytes>
<value>
#参数说明如下:
command set/add/replace
key key 用于查找缓存值
flags 可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息
expiration time 在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes 在缓存中存储的字节数
value 存储的值(始终位于第二行)
#增加key,过期时间为秒,bytes为存储数据的字节数
add key flags exptime bytes

示例:

安装软件:

yum install memcached -y

telnet localhost 11211

add leekey 0 60 4 #0 是否压缩 60 过期时间 4 字长
test
STORED

session 共享服务器:

msm 介绍:

msmmemcached session manager)提供将Tomcatsession保持到memcached可以实现高可用。

项目早期托管在google code,目前在Github

github网站链接: https://github.com/magro/memcached-session-manager

支持Tomcat 6.x7.x8.x9.x

TomcatSession管理类,Tomcat版本不同

memcached-session-manager-2.3.2.jar

memcached-session-manager-tc9-2.3.2.jar

Session数据的序列化、反序列化类

官方推荐kyro

webappWEB-INF/lib/

驱动类

memcached(spymemcached.jar)

Redis(jedis.jar)

安装:

参考链接: https://github.com/magro/memcached-session-manager/wiki/SetupAndConfiguration

spymemcached.jarmemcached-session-managekyro相关的jar文件都放到Tomcatlib目录

中,这个目录是 $CATALINA_HOME/lib/ ,对应本次安装就是/usr/local/tomcat/lib

t1m1部署可以在一台主机上,t2m2部署也可以在同一台。

当新用户发请求到Tomcat1, Tomcat1生成session返回给用户的同时,也会同时发给memcached2

份。即Tomcat1 session为主sessionmemcached2 session为备用session,使用memcached相当于

备份了一份Session

如果Tomcat1发现memcached2 失败,无法备份Sessionmemcached2,则将Sessoin备份存放在

memcached1

配置过程

下载相关jar,参考下面官方说明的下载链接

https://github.com/magro/memcached-session-manager/wiki/SetupAndConfiguration

修改tomcat配置:

vim /usr/local/tomcat/conf/context.xml

[root@tomcat-1 ~]# vim /usr/local/tomcat/conf/context.xml
@@@@内容省略@@@@
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:172.25.254.10:11211,n2:172.25.254.20:11211"
failoverNodes="n1"
requestUriIgnorePattern=".*\\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFacto
ry"
/>
[root@tomcat-2 tomcat]# vim /usr/local/tomcat/conf/context.xml
@@@@内容省略@@@@
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:172.25.254.10:11211,n2:172.25.254.20:11211"
failoverNodes="n2"
requestUriIgnorePattern=".*\\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFacto
ry"
/>

修改nginx配置:

upstream tomcat {
hash $cookie_JSESSIONID;
server 172.25.254.10:8080;
server 172.25.254.20:8080;
}
server {
listen 80;
server_name lee.timinglee.org;
root /webdataw/nginx/timinglee.org/lee;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
try_files $uri $uri.html $uri/index.html /error/default.html;
location ~ \\.jsp$ {
proxy_pass http://tomcat;
}
}

测试:

赞(0)
未经允许不得转载:网硕互联帮助中心 » 企业级WEB应用服务器TOMCAT
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!