Tomcat

Tomcat

tomcat简介

Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应HTML(标准通用标记语言下的一个应用)页面的访问请求。实际上Tomcat是Apache 服务器的扩展,但运行时它是独立运行的,所以当你运行tomcat 时,它实际上作为一个与Apache 独立的进程单独运行的。
Tomcat是一个免费的开源的Serlvet容器,用来运行java程序的容器,是开发和调试Servlet(Server Applet)、JSP(Java Server Pages) 程序的首选;Tomcat就是传说中的中间件之一,tomcat本身是一个容器,专门用来运行java程序,java语言开发的网页.jsp就应该运行于tomcat中,而tomcat本身的运行也依赖于jdk环境。

tomcat的用处

常见的中间件
一般本地开发的话,小项目,或者是个人开发建议使用tomcat;
linux系统建议使用jetty或apache hpppd;
大型的项目就用JBOSS或webloigc;
大项目或者商业项目一般采用:weblgoic/webshere,其他的还有jboss、glasshfish等;
一些示例项目或者小项目常采用jetty;
tomcat , jboss, weblogic, websphere 一般项目tomcat就可以了。

部署tomcat

apache-tomcat-10.0.23安装包
关闭防火墙和selinux

[root@lnh ~]# systemctl stop firewalld.service
[root@lnh ~]# vim /etc/selinux/config
SELINUX=disabled
[root@lnh ~]# setenforce 0
[root@lnh ~]# systemctl disable --now firewalld.service
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.

Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

安装java

[root@lnh ~]# dnf -y install java-11-openjdk

下载tomcat并解压tomcat到/usr/local/目录下

[root@lnh ~]# wget https://downloads.apache.org/tomcat/tomcat-10/v10.0.23/bin/apache-tomcat-10.0.23.tar.gz
[root@lnh ~]# ls
anaconda-ks.cfg  apache-tomcat-10.0.23.tar.gz
[root@lnh ~]# tar xf apache-tomcat-10.0.23.tar.gz -C /usr/local/
[root@lnh ~]# cd /usr/local/
[root@lnh local]# ln -s apache-tomcat-10.0.23/  tomcat

自定义一个Hello World的 java的测试网页

[root@lnh local]# mkdir /usr/local/tomcat/webapps/test
[root@lnh local]# cd /usr/local/tomcat/webapps/test
[root@lnh test]# vim index.jsp
[root@lnh test]# cat index.jsp
<html>
<head>
    <title>test page</title>
</head>
<body>
    <% out.println("hello world"); %>
</%></body>
</html>

启动tomcat

[root@lnh test]# cd /usr/local/tomcat
[root@lnh 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
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.

//&#x9ED8;&#x8BA4;&#x7AEF;&#x53E3;&#x4E3A;8080
&#x901A;&#x8FC7;ps  -ef  | grep  tomcat  &#x53EF;&#x4EE5;&#x67E5;&#x770B;&#x5230;&#x6709;java&#x548C;tomcat&#x7684;&#x8FDB;&#x7A0B;&#xFF0C;&#x8BF4;&#x660E;&#x670D;&#x52A1;&#x5DF2;&#x7ECF;&#x542F;&#x52A8;&#x6210;&#x529F;
[root@lnh tomcat]# ps  -ef  | grep  tomcat
root       36430       1 13 00:17 pts/2    00:00:06 /usr/bin/java -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dorg.apache.catalina.security.SecurityListener.UMASK=0027 -Dignore.endorsed.dirs= -classpath /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/usr/local/tomcat/temp org.apache.catalina.startup.Bootstrap start
root       37846    4714  0 00:18 pts/2    00:00:00 grep --color=auto tomcat
[root@lnh tomcat]# ss -antl
State      Recv-Q     Send-Q              Local Address:Port         Peer Address:Port    Process
LISTEN     0          128                       0.0.0.0:22                0.0.0.0:*
LISTEN     0          1              [::ffff:127.0.0.1]:8005                    *:*
LISTEN     0          100                             *:8080                    *:*
LISTEN     0          128                          [::]:22                   [::]:*

测试访问

访问tomcat首页:
http://192.168.222.250:8080

Tomcat
访问hello world测试页:
http://192.168.222.250:8080/test/
Tomcat

访问Host Manager界面

配置tomcat-users.xml文件,在行上面添加两行,设置角色,登录用户名和密码,角色名称只能是admin-gui 用户名和密码自定义

[root@lnh ~]# vim /usr/local/tomcat/conf/tomcat-users.xml
<role rolename="admin-gui">  //&#x6DFB;&#x52A0;
<user username="tomcat" password="123456" roles="admin-gui"> //&#x6DFB;&#x52A0;

</user></role>

配置host-manager/META-INF/context.xml文件,允许192.168.222.0/24网段访问,在allow字段后添加

[root@lnh ~]# vim /usr/local/tomcat/webapps/host-manager/META-INF/context.xml
<context antiresourcelocking="false" privileged="true">
  <cookieprocessor classname="org.apache.tomcat.util.http.Rfc6265CookieProcessor" samesitecookies="strict">
           <valve classname="org.apache.catalina.valves.RemoteAddrValve" allow="192\.168\.222\.\d+|127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1">
  <manager sessionattributevalueclassnamefilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap">
</manager></valve></cookieprocessor></context>

重启服务,先关服务,再启服务

[root@lnh ~]# /usr/local/tomcat/bin/catalina.sh stop
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:
NOTE: Picked up JDK_JAVA_OPTIONS:  --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
[root@lnh ~]# /usr/local/tomcat/bin/catalina.sh start
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.

登录网页测试登录Host Manager 输入对应的用户名和密码
用户名为tomcat,密码为123456
http://192.168.222.250:8080

Tomcat
Tomcat
Tomcat

访问Server Status

编辑tomcat-users.xml

[root@lnh ~]# vim /usr/local/tomcat/conf/tomcat-users.xml
<role rolename="admin-gui">
<role rolename="manager-gui">  //&#x6DFB;&#x52A0;
<user username="tomcat" password="123456" roles="admin-gui,manager-gui">  //&#x4FEE;&#x6539;

</user></role></role>

编辑manager/META-INF/context.xml,在allow字段添加允许192.168.222.0/24网段访问

[root@lnh ~]# vim /usr/local/tomcat/webapps/manager/META-INF/context.xml
<context antiresourcelocking="false" privileged="true">
  <cookieprocessor classname="org.apache.tomcat.util.http.Rfc6265CookieProcessor" samesitecookies="strict">
  <valve classname="org.apache.catalina.valves.RemoteAddrValve" allow="192\.168\.222\.\d+|127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1">
  <manager sessionattributevalueclassnamefilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap">
</manager></valve></cookieprocessor></context>

重启服务,先关服务,再启服务

[root@lnh ~]# /usr/local/tomcat/bin/catalina.sh stop
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:
NOTE: Picked up JDK_JAVA_OPTIONS:  --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
[root@lnh ~]# /usr/local/tomcat/bin/catalina.sh start
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.

登录网页,访问Server Status,用户名tomcat 密码123456
访问Manager App的时候就不需要密码了,因为访问了Server Status界面,所以不用输入密码

Tomcat
Tomcat
Tomcat
Tomcat
Tomcat

Original: https://www.cnblogs.com/tushanbu/p/16736583.html
Author: 涂山布
Title: Tomcat

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/573940/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 使用MyBatis Generator代码生成器的简单模式

    在动态web项目的lib目录下放入mybatis-3.2.2jar、mysql-connector-java-5.1.25-bin.jar、log4j-1.2.17.jar还有生成…

    Linux 2023年6月8日
    0107
  • iptables快速入门

    iptables简介 在生产实践过程中,为了保证生产安全,通常需要进行数据加密,例如通过网络层面上将应用隔离成内网和公网应用,内网再分成生产、测试、开发、DMZ等区域,然后进行不同…

    Linux 2023年6月6日
    084
  • POJ1611(The Suspects)–简单并查集

    1 #include 2 #include 3 #include 4 #include 5 #include 6 #include 7 #include 8 #include&lt…

    Linux 2023年6月7日
    0101
  • 网络通信知识地图

    知识地图是一种知识导航系统,并显示不同的知识存储之间重要的动态联系。本篇主要就是从更高的视角将之前的文章的结构思路展现出来。文章结构的思路实际上也是达到架构师程度要掌握的网络通信知…

    Linux 2023年6月14日
    091
  • 一键安装Cisco AnyConnect Secure Mobility Client

    Mac版本 背景:公司内部安装此VPN软件的时候,因默认是安装了所有模块,但我们只需要vpn模块,所产生的干扰。并且有人因不熟悉Mac pkg 软件的卸载方法导致非正常卸载,导致重…

    Linux 2023年6月8日
    091
  • 抓到 Netty 一个隐藏很深的内存泄露 Bug | 详解 Recycler 对象池的精妙设计与实现

    欢迎关注公众号:bin的技术小屋,如果大家在看文章的时候发现图片加载不了,可以到公众号查看原文 本系列Netty源码解析文章基于 4.1.56.Final版本 最近在 Review…

    Linux 2023年6月6日
    098
  • mysql update语句的执行流程是怎样的

    update更新语句流程是怎么样的 update更新语句基本流程也会查询select流程一样,都会走一遍。 update涉及更新数据,会对行加dml写锁,这个DML读锁是互斥的。其…

    Linux 2023年6月8日
    087
  • 研发过程中的文档管理与工具

    写文档也是技术活 01:实践 对于多数开发同学来说,很多时候即讨厌没有研发文档,但是自己又不愿意常写文档,痛且倔强着; 程序员该不该写文档,与争论哪种编程语言最好一样,想撕的嘴不留…

    Linux 2023年6月14日
    091
  • js笔记之switch-case

    switch 语句来选择要执行的多个代码块之一。switch 不能处理大于小于的 工作原理:首先设置表达式 n(通常是一个变量)。随后表达式的值会与结构中的每个 case 的值做比…

    Linux 2023年6月13日
    073
  • CentOS7 安装 OpenBLAS

    将仓库clone到本地 git clone https://github.com/xianyi/OpenBLAS.git GitHub 地址:https://github.com/…

    Linux 2023年6月7日
    0136
  • 详解IP地址、子网掩码、网络号、主机号、网络地址、主机地址

    详解IP地址、子网掩码、网络号、主机号、网络地址、主机地址 概念 IP地址:一般是指逻辑ip; 子网掩码:将IP划分为网络号和主机号的IP; 网络号/主机号:子网掩码转成二进制后,…

    Linux 2023年6月6日
    099
  • 继承、封装、多态的实现原理

    欢迎来到Java学习之继承、封装、多态的实现原理 目录 从JVM结构开始谈多态 JVM 的结构 Java 的方法调用方式 常量池(constant pool) 图 2. 常量池各表…

    Linux 2023年6月13日
    096
  • Docker 安装 Redis

    docker 启动 redis 命令 docker run -p 6379:6379 –name redis -v /usr/local/docker/redis.conf:/e…

    Linux 2023年5月28日
    086
  • 需求分析到软件设计复习

    什么是需求分析? 需求分析就是需求分析师对用户期望的软件行为进行表述。 谁来表述 -> 需求分析师 谁有期望-> 用户 期望什么?-> 期望的软件行为 怎样表述?…

    Linux 2023年6月8日
    086
  • thinkphp3.2.3 使用redis session存储

    为了解决session 共享问题,使用redis存储session会话信息 首先我们先研究一下 thinkphp 底层是怎么调用session的 ThinkPHP/Library/…

    Linux 2023年5月28日
    072
  • XXE漏洞学习

    0x00 XXE漏洞介绍: 背景:2018-7-4 微信支付SDK漏洞(XXE漏洞),攻击者可以获取服务器中目录结构,文件内容,eg:代码,各种 私钥。敏感数据泄露 0x01什么是…

    Linux 2023年6月6日
    095
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球