目录
一:tomcat的介绍
Tomcat请求过程
实验部分:
1:安装 Tomcat
1.1:安装java环境
1.2:安装并启动tomcat
1.3: 查看端口
1.4:浏览器访问以下试试
2:tomcat的文件结构和组成
3:生成tomcat的启动文件
3.1:生成tomcat的主配置文件
3.2:生成启动文件
3.3:然后重载并开机自启
二:结合反向代理实现tomcat部署
2.1:常见部署方式介绍
2.2:利用 nginx 反向代理实现
实验步骤:
1:首先把test.jsp文件放进去,然后复制内容到tomcat中去
2:把主机10的这个test.jsp文件传到主机20去
3:然后修改配置文件:
4:浏览器测试:
2.3:实现tomcat中的负载均衡
2.31:HTTP的无状态,有连接和短连接
2.32:tomcat负载均衡实现
实验步骤:
修改配置文件:
然后测试一下:
三:Memcached
3.1:Memcached简介
3.2:memcached的安装与启动
四:session 共享服务器
4.1:msm介绍
4.2:安装
4.3:配置过程
4.31:修改tomcat配置
4.32:然后把服务先停掉然后重启
4.33:修改nginx配置
4.34:测试:
(1) web容器:完成web服务器的功能。
(2) servlet容器:名字为catalina,用于处理Servlet代码。
(3 ) JSP容器:用于将JSP动态网页翻译成Servlet代码。
因此Tomcat是web应用服务器,也是一个Servlet/JSP容器。Tomcat作为 Servlet容器,负责处理客户请求,把请求传送给servlet,并将servlet的响应传送回给客户。
什么是servlet ?
Servlet 是 Java Servlet 的简称,可以理解为是一个服务连接器,是用Java编写的服务器端程序,具有独立于平台和协议的特性,简单的理解: servlet就是一个中间件,包含了接口和方法,将客户端和数据库连接,从而实现动态网页的创建。
什么是JSP?
JSP 全称 Java Server Pages,是一种动态网页开发技术。它使用JSP 标签在HTML,网页中插入Java代码。标签通常以 <% 开头,以 %> 结束。
JSP是一种Java servlet,主要用于实现Java web 应用程序的用户界面部分。
JSP通过网页表单获取用户输入数据、访问数据库及其他数据源,然后动态地创建网页。
Tomcat 功能组件结构:
Tomcat的核心功能有两个,分别是负责接收和反馈外部请求的连接器Connector,和负责处理请求的容器Container:其中连接器和容器相辅相成,一起构成了基本的 web服务Service。每个Tomcat服务器可以管理多个Service。
Conector: 负责对外接收和响应请求。它是Tomcat与外界的交通枢纽,监听端口接收外界请求,并将请求处理后传递给容器做业务处理,最后将容器处理后的结果响应给外界。
Container: 负责对内处理业务逻辑。其内部由 Engine、Host、Context和wrapper 四个容器组成,用于管理和调用Servlet相关逻辑。
Service:对外提供的web服务。主要包含Connector和 Container两个核心组件,以及其他功能组件。Tomcat可以管理多个
Service,且各Service 之间相互独立
1、用户在浏览器中输入网址,请求被发送到本机端口8080,被在那里监听的 Connector获得;
2、Connector 把该请求交给它所在的Service 的 Engine (Container)来处理,并等待Engine的回应;
3、请求在Engine、Host、Context和Wwrapper 这四个容器之间层层调用,最后在Servlet 中执行对应的业务逻辑、数据存储等。
4、执行完之后的请求响应在Context、Host、Engine容器之间层层返回,最后返回给Connector,并通过Connector 返回给客户端。
以下步骤在主机10和主机20都需要做的操作:三台主机 tomcat 172.25.254.100 tomcat-node1.chl.org 172.25.254.10 tomcat-node2.chl.org 172.25.254.20
yum install java-1.8.0-openjdk.x86_64 -y
tar zxf apache-tomcat-9.0.91.tar.gz -C /usr/local/ ###把文件解压到/usr/local中
ln -s /usr/local/apache-tomcat-9.0.91/ /usr/local/tomcat ###做一个软链接
/usr/local/tomcat/bin/startup.sh ###开启服务
tcp6 0 0 :::8080 :::* LISTEN 1001 92406 35814/java
主机10的:
主机20的
目录结构
目录 说明 ------------------------------------------------------- bin 服务启动、停止等相关程序和文件 conf 配置文件 lib 库目录 logs 日志目录 webapps 应用程序,应用部署目录,相当于nginx的默认发布目录 work jsp 编译后的结果文件,建议提前预热访问
查看tomcat相关目录和文件
[root@tomcat ~]# tar zxf apache-tomcat-9.0.93.tar.gz -C /usr/local/ [root@tomcat ~]# ls /usr/local/tomcat/ bin conf lib logs README.md RUNNING.txt webapps BUILDING.txt CONTRIBUTING.md LICENSE NOTICE RELEASE-NOTES temp work
vim /usr/local/tomcat/conf/tomcat.conf
JAVA_HOME=/etc/alternatives/jre_openjdk
useradd -s /sbin/nologin -M tomcat
chown -R tomcat.tomcat /usr/local/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
systemctl daemon-reload
systemctl enable --now tomcat
主机10和主机20都要做的操作:
cp test.jsp /usr/local/tomcat/webapps/ROOT/
scp test.jsp root@172.25.254.20:/usr/local/tomcat/webapps/ROOT/
vim /usr/local/nginx/conf.d/vhosts.conf
ocation ~ \.jsp$ {
proxy_pass http://172.25.254.10:8080;
}
vim /usr/local/nginx/conf.d/vhosts.conf
upstream tomcat {
#ip_hash;
hash $cookie_JSESSIONID;
server 172.25.254.10:8080;
server 172.25.254.20:8080;
}server {
listen 80;
server_name www.chl.org;
root /data/php;location ~ \.jsp$ {
proxy_pass http://tomcat;
}
}
edge浏览器访问:
谷歌浏览器访问:
不同的浏览器访问互不影响!!!!!!
主机10和主机20都需要做!!!!
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
[root@nginx ~]# netstat -anltupe | grep memcache
tcp 0 0 127.0.0.1:11211 0.0.0.0:* LISTEN 978 267432 189679/memcached
tcp6 0 0 ::1:11211 :::* LISTEN 978 267433 189679/memcached
在主机10和主机20都要做!!!!!
将spymemcached.jar、memcached-session-manage、kyro相关的jar文件都放到Tomcat的lib目录
中,这个目录是 $CATALINA_HOME/lib/ ,对应本次安装就是/usr/local/tomcat/lib。首先把老师发的jar文件夹里面的东西全部放到/usr/local/tomcat/lib里面
[root@tomcat-node1 conf]# ls /usr/local/tomcat/lib/
annotations-api.jar servlet-api.jar
asm-5.2.jar spymemcached-2.12.3.jar
catalina-ant.jar tomcat-api.jar
catalina-ha.jar tomcat-coyote-ffm.jar
catalina.jar tomcat-coyote.jar
catalina-ssi.jar tomcat-dbcp.jar
catalina-storeconfig.jar tomcat-i18n-cs.jar
catalina-tribes.jar tomcat-i18n-de.jar
ecj-4.20.jar tomcat-i18n-es.jar
el-api.jar tomcat-i18n-fr.jar
jasper-el.jar tomcat-i18n-ja.jar
jasper.jar tomcat-i18n-ko.jar
jaspic-api.jar tomcat-i18n-pt-BR.jar
jsp-api.jar tomcat-i18n-ru.jar
kryo-3.0.3.jar tomcat-i18n-zh-CN.jar
kryo-serializers-0.45.jar tomcat-jdbc.jar
memcached-session-manager-2.3.2.jar tomcat-jni.jar
memcached-session-manager-tc9-2.3.2.jar tomcat-util.jar
minlog-1.3.1.jar tomcat-util-scan.jar
msm-kryo-serializer-2.3.2.jar tomcat-websocket.jar
objenesis-2.6.jar websocket-api.jar
reflectasm-1.11.9.jar
t1和m1部署可以在一台主机上,t2和m2部署也可以在同一台。 当新用户发请求到Tomcat1时, Tomcat1生成session返回给用户的同时,也会同时发给memcached2备 份。即Tomcat1 session为主session,memcached2 session为备用session,使用memcached相当于 备份了一份Session 如果Tomcat1发现memcached2 失败,无法备份Session到memcached2,则将Sessoin备份存放在 memcached1中
vim /usr/local/tomcat/conf/context.xml
@@@@内容省略@@@@
memcachedNodes="m1:172.25.254.10:11211,m2:172.25.254.20:11211"
failoverNodes="m1"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>
[root@tomcat-2 tomcat]# vim /usr/local/tomcat/conf/context.xml
@@@@内容省略@@@@
memcachedNodes="m1:172.25.254.10:11211,m2:172.25.254.20:11211"
failoverNodes="m2"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>
systemctl stop tomcat.service
systemctl start tomcat.service
[root@Nginx ~]# vim /usr/local/nginx/conf.d/vhosts.confupstream tomcat {
#ip_hash;
hash $cookie_JSESSIONID;
server 172.25.254.10:8080;
server 172.25.254.20:8080;
}server {
listen 80;
server_name www.chl.org;
root /data/php;location ~ \.jsp$ {
proxy_pass http://tomcat;
}
}
1.在两台tomcat都开启的情况下访问https://blog.csdn.net/qq_26553949/article/details/www.chl.org/test.jsp
2:n1被停止后继续提交信息看是否可以读取到之前的会话信息
systemctl stop tomcat.service
3:然后浏览器看还在不在