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)
Net18-AnyISalInNet18-AnyISalIn
上一篇 2016-04-21
下一篇 2016-04-22

相关推荐

  • shell与kernel的理解

    Shell 的英文释义是外壳,与kernel 内核名词遥相呼应,一外一内,一壳一核。内核就像瑞士银行的金库,存放着客户的黄金等众多的(硬件)资产,闲杂人等(包括客户)当然是严格禁止入内的,而作为客户要存取金库中的资产则需要通过专门的特定管理人员代为操作完成,并把存取(操作)的结果呈现给客户。在Linux操作系统中,shell的职能就类似于金库的操作人员,客户…

    Linux干货 2016-02-14
  • linux中扩展swap分区和移动设备使用挂载以及常用的工具free、df 、du、dd命令

    swap分区 swap分区作用:内存不足时充当系统内存,所以swap尽量放在告诉硬盘上也就是尽量使用磁盘的第一个分区 动手创建swap分区       1、创建分区,将分区类型转换成swap分区格式           &nbsp…

    Linux干货 2016-08-29
  • Linxux运维基础小计

    常用cat、ls、touch、mkdir、cp、mv小结 ·cat连续的将文件的内容显示在银幕上 用法:cat[OPTION]…[FILE]… 参数 -A显示所有非正常的所有符号 -E显示行结束符 -T显示制表符 -v显示其他的非打印字符 -n对显示的行进行编号,与文件内容没有关系 -b:打印出行号(空白行不标行号) 直接输入cat命令表示等待用户的输入并打…

    2017-02-18
  • 从新开始,坚持记录

    从新开始,从心开始,记录自己的学习,不逼自己一把,永远不知道自己的潜力。

    Linux干货 2016-12-05
  • N26-第四周-孙逸

    1、  复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 cp –r /etc/skel /home/tuser1 chmod –R 700 /home/tuser1 2、  编辑/etc/group文件,添加组hadoop。 group文件的内容格式: &…

    2017-03-10
  • linux用户与用户组详解

    LINUX用户与用户组详解     1,用户和用户组文件   在linux中,用户帐号,用户密码,用户组信息和用户组密码均是存放在不同的配置文件中的。分别是 passed gpassd shadow group 中。   在linux系统中,所创建的用户帐号和其相关信息(密码除外)均是存放在/etc…

    Linux干货 2017-07-22

评论列表(1条)