tomcat基础进阶

                    tomcat基础进阶


前言

我们在前面的博客中介绍以及实现的web架构都是基于”世界上最好的语言”PHP实现动态web站点, 事实上在当今的web服务器端还经常python,perl,Java Script等编程语言实现动态的web站点, 我们今天就介绍一款实现著名的开源软件tomcattomcat其实是一个Serlet Container,我们不能将其与nginx,httpd等软件混淆, tomcat其实是一款用C语言实现的Web Application Server, 就相当于我们之前的php-fpm,本文主要介绍tomcat的安装及基本使用进阶

相关学习资料 
如果要深入理解
tomcat就必须要了解Java的技术体系, 由于本人水平太低, 这里没法给大家做具体的解释, 遂提供一些参考资料供大家深入学习.

Tomcat官方站点 
Java Time Line

Tomcat Architecture

blob.png

blob.png

Tomcat Installation

安装环境及软件版本:

System:CentOS6.7 
Tomcat
tomcat-8.0.33(binary distributions) 
JDK
java-1.8.0-openjdk.x86_64(yum install)

安装过程

[root@node1 ~]# [root@node1 ~]# wget http://mirrors.cnnic.cn/apache/tomcat/tomcat-8/v8.0.33/bin/apache-tomcat-8.0.33.tar.gz
[root@node1 ~]# tar xf apache-tomcat-8.0.33.tar.gz  -C /usr/local/
[root@node1 ~]# cd /usr/local ; ln -sv apache-tomcat-8.0.33 tomcat ; cd ~
[root@node1 ~]# wget http://download.oracle.com/otn-pub/java/jdk/8u77-b03/jdk-8u77-linux-x64.rpm #如果下载出错, 使用浏览器下载
[root@node1 ~]# rpm -ivh jdk-8u77-linux-x64.rpm   #安装JDK

[root@node1 ~]# vim /etc/profile.d/java.sh     #定义JAVA_HOME
export JAVA_HOME=/usr/java/latest
export PATH=$JAVA_HOME/bin:$PATH

[root@node1 ~]# vim /etc/profile.d/tomcat.sh    #配置tomcat的环境变量
export CATALINA_BASE=/usr/local/tomcat
export PATH=$CATALINA_BASE/bin:$PATH

[root@node1 ~]# source /etc/profile.d/tomcat.sh
[root@node1 ~]# source /etc/profile.d/java.sh

[root@node1 ~]# catalina.sh start  #启动tomcat, 默认监听在8080端口

测试

blob.png

Tomcat basic configuration

如何进入Tomcat manager页面?

现在我们搭建了最基础的tomcat服务器, 上面没有跑我们的JSP脚本, 是tomcat提供的一个manual页面, 页面的左上方有几个图形界面的管理界面server status,manager appHost manager, 我们需要提供用户名和密码才能进入并配置它们

修改/usr/local/tomcat/conf/tomcat-users.xml文件

blob.png

重启tomcat测试

tomcat默认的用户认证是basic认证, 不进行加密, 如果有人在你的网络中进行抓包很容易截获用户名密码..

你现在的表情很可能是下面这样的

blob.png 

然而, 我们现在登录manager-gui然后使用wire shark进行抓包 

blob.png

blob.png

所以建议大家不要使用basic认证

(⊙o⊙)…, 刚才有点跑题了, 我们来看一下manager-gui界面, 这是tomcat-status界面, 可以看到内存的占用情况 

blob.png

这是tomcat-host-manager界面, 可以在这这里部署virtual_Host 

blob.png

配置Virtual_Host

我们早已熟悉在httpd,nginx虚拟主机的配置, 我们现在来看看如何在tomcat上配置虚拟主机吧!

对tomcat进行配置之前, 我们需要了解其配置文件的结构

server.xml配置文件的结构

<server>
    <service>
        <connector>
            <Engine>
                <Host>
                    <Context>
                    </Context>
                    ....    
                </Host>
                ....
            </Engine>
            ...
        </connector>
        ...
    </service>
</server>

其中, service是用来连接connector和server的, connector可以有多个, Engine、Host、Context都可以有多个

顾名思义, 我们的虚拟主机应该定义在<Host> </Host> 中

我们先来看一个最简单的VirtualHost定义

<Host name="www.anyisalin.com" appBase="/data/webapps" />

上述意思为. FQDN为www.anyisalin.com, 虚拟主机的路径在/data/webapps, 但是我们没有定义<Context>, <Context>就类似于httpd中的Alias, Nginx中的location


#一次完整的虚拟主机配置过程

[root@node2 conf]# vim server.xml, 在engine中添加如下内容{位置一定要放对}

<Engine name="catalina" defaultHost="web1.anyisalin.com" jvmRoute=TomcatA/>  #修改默认虚拟主机

#添加虚拟主机
<Host name="web1.anyisalin.com" appBase="/data/webapps/" unpackWARS="true" autoDeploy="true">
    <Context path="" docBase="/data/webapps" reloadable="true" />
    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/data/logs"
         prefix="web1_access_log." suffix=".txt"
         pattern="%h %l %u %t &quot;%r&quot; %s %b" />
</Host>

[root@node2 conf]# mkdir -pv /data/webapps/{classes,META-INF,WEB-INF,lib} #创建虚拟主机的主目录

[root@node2 conf]# cd /data/webapps/
[root@node2 webapps]# vim index.jsp   #创建主页文件
<%@ page language="java" %>
<html>
  <head><title>TomcatA</title></head>
  <body>
    <h1><font color="red">TomcatA.magedu.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("magedu.com","magedu.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>

#保存退出, 重启tomcat
[root@node2 webapps]# catalina.sh stop
[root@node2 webapps]# catalina.sh start

测试虚拟主机

这个页面文件在我们以后的实验中有大用!!

blob.png

总结

本篇文章简单的介绍了tomcat的使用, 下几篇文章才是重中之重, 大家千万不要错过 !

作者水平很低, 如果有错误及时指出, 如果你觉得本文写的好请点一波赞~(≧▽≦)/~ 
作者: AnyISaIln QQ: 1449472454 
感谢: MageEdu

原创文章,作者:Net18-AnyISalIn,如若转载,请注明出处:http://www.178linux.com/15175

(0)
上一篇 2016-04-21 15:45
下一篇 2016-04-22 12:39

相关推荐

  • 第六周博客作业

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; cp /etc/rc.d/rc.sysinit /tmp vim /tmp/rc.sysinit :%s@^[[:space:]]\+[^[:space:]]@#&a…

    Linux干货 2017-02-26
  • 网络班第27期第二周作业

    1、 Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关的实例演示。 cp命令:copy 文件à>目录 文件à>文件 目录->文件(报错)           目录->目录 常用选项:     &nbsp…

    2017-07-31
  • linux 必须掌握的60个命令

    Linux提供了大量的命令,利用它可以有效地完成大量的工 作,如磁盘操作、文件存取、目录操作、进程管理、文件权限设定等。所以,在Linux系统上工作离不开使用系统提供的命令。要想真正理解Linux系统, 就必须从Linux命令学起,通过基础的命令学习可以进一步理解Linux系统。 不同Linux发行版的命令数量不一样,但Linux发行版本最少的命令也有200…

    2017-09-05
  • iptables基础概念

    iptables基本概念梳理 前言 netfilter/Iptables (其中包括netfilter和Iptables两个组件)组 成了Linux平台下的包过滤防火墙,它与大多数的Linux自带软 件一样,这个防火墙是免费提供的,它可以代替昂贵的企业级 防火墙来解决实际问题与实际方案,完成封包过滤,封包重定 向和网络地址转换等功能。 一、工作原理 数据包从…

    Linux干货 2016-12-19
  • 用户和权限管理

    一、用户 Linux中用户是资源获取的标识符,资源分配,文件系统安全权限模型的核心要素之一。密码则是用户认证的凭证,用户信息和密码信息都存放在相应的文本文件中,密码信息在存放的过程用了一定的加密算法进行加密。   1.加密算法: 资源分派:    Authentication:认证(确认身份,也有可能好几个人一个身份) &nbs…

    Linux干货 2016-08-05
  • 逻辑卷管理器(LVM)-介绍

    逻辑卷管理器(LVM) §·逻辑卷管理器LVM介绍 2 ※·LVM逻辑卷的简单描述 2 ※·LVM逻辑卷的好坏 2 ※·LVM结构组成部分 2 §·LVM的举例分析 3 ※·LVM设备名称 3 ※·LVM分区类型: 3 ※·LVM  PV相关命令 3 ※·LVM  VG相关命令 3 ※·LVM  LV 相关命令 3 ※·LVM …

    Linux干货 2016-08-29

评论列表(1条)