2018-07-16笔记(tomcat 配置)

16.1 Tomcat介绍

1、Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。
2、Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。
3、java程序写的网站用Tomcat+JDK来运行,Tomcat是一个中间件,真正起作用的,解析Java脚本的是JDK。JDK(Java development kit)是整个Java的核心,它包含了Java运行环境和一堆Java相关的工具以及Java基础库。
4、最主流的JDK是由sun公司发布的JDK,除此之外,IBM公司也有发布JDK,centos上也可以使用yum安装openjdk。

16.2 安装jdk

jdk目前版本1.6 1.7 1.8,通常说的6、7、8版本对应的就是1.6、1.7、1.8
我们用1.8版本
1.首先去jdk官网下载一个jdk包
http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
2018-07-16笔记(tomcat 配置)
先同意许可才能下载,选择对应的版本下载即可,先下载到windows机器上,这里因为用的是centos7的系统所以选择下载64位tar.gz的包
下载完成用xshell自带的sftp工具上传到centos7的/usr/local/src/目录下

[root@localhost ~]# cd /usr/local/src/
[root@localhost src]# ll
总用量 912764
-rw-r--r--  1 root  root  185646832 7月  18 09:52 jdk-8u181-linux-x64.tar.gz

解压并移动到对应目录重命名即可,不用安装

[root@localhost src]# tar zxf jdk-8u181-linux-x64.tar.gz 
[root@localhost src]# mv jdk1.8.0_181/ /usr/local/jdk1.8                 #把解压完的目录移动到/usr/local/下并改名为jdk1.8

编辑全局环境变量并使其生效

[root@localhost src]# vi /etc/profile                       #在最后面添加以下几行,对应的目录改成jdk所有的目录即可
JAVA_HOME=/usr/local/jdk1.8/
JAVA_BIN=/usr/local/jdk1.8/bin
JRE_HOME=/usr/local/jdk1.8/jre
PATH=$PATH:/usr/local/jdk1.8/bin:/usr/local/jdk1.8/jre/bin
CLASSPATH=/usr/local/jdk1.8/jre/lib:/usr/local/jdk1.8/lib:/usr/local/jdk1.8/jre/lib/charsets.jar
:wq保存配置
[root@localhost src]# source /etc/profile       #刷新配置

测试有没安装成功

[root@localhost src]# java -version
java version "1.8.0_181"
Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)

#若该命令执行成功,且执行结果和安装信息一致,说明配置成功。
#如果出现open jdk 搜一下 rpm -qa |grep open jdk,可能是系统安装了open jdk,删除即可

16.3 安装Tomcat

下载对应的tomcat包,http://apache.fayea.com/tomcat/tomcat-8/v8.5.32/bin/apache-tomcat-8.5.32.tar.gz
这里提供的下载地址有可能会失效
我们把tomcat下载到/usr/local/src/目录下,并解压

[root@localhost src]# wget http://apache.fayea.com/tomcat/tomcat-8/v8.5.32/bin/apache-tomcat-8.5.32.tar.gz
[root@localhost src]# tar zxf apache-tomcat-8.5.32.tar.gz

解压完后把目录移动到/usr/local/下并改名为tomcat

[root@localhost src]# mv apache-tomcat-8.5.32 /usr/local/tomcat

用tomcat自带的脚本启动

[root@localhost src]# /usr/local/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/local/jdk1.8
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.

这里可以看到输出一些信息,使用的环境变量,就是刚才我们配置的
查看进程和端口,进程名为java

[root@localhost src]# ps aux |grep java
root       1154  3.0  7.9 2294184 79476 pts/0   Sl   10:11   0:02 /usr/local/jdk1.8/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       1201  0.0  0.0 112720   972 pts/0    D+   10:13   0:00 grep --color=auto java
[root@localhost src]# netstat -lnp|grep java
tcp6       0      0 :::8080                 :::*                    LISTEN      1154/java           
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      1154/java           
tcp6       0      0 :::8009                 :::*                    LISTEN      1154/java  

三个端口
端口8080:提供web服务的
端口8005:管理端口
端口8009:第三方服务调用端口(如:httpd和Tomcat结合时会用到)
注意:8005端口有时候会启动的比较慢,起来后页面加载就很快了
防火墙放行对应的tomcat端口或者直接关闭,用浏览器访问页面是否正常,输入IP加端口8080,这里为192.168.66.131:8080
2018-07-16笔记(tomcat 配置)

可以看到已经正常访问,说明tomcat正常
关闭Tomcat,同样是用tomcat自带的脚本关闭:

[root@localhost  src]# /usr/local/tomcat/bin/shutdown.sh
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk1.8
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar

注意:tomcat是不支持restart的,有时候可能会遇到8005端口没起来,无法关闭tomcat的现象,可以使用killall命令把所有java进程杀死

16.4 配置Tomcat监听80端口

修改tomcat配置文件server.xml ,这里我的路径为/usr/local/tomcat/conf/server.xml,可以修改默认的监听的web页面的端口,这里我们把8080改成80,注意80端口是系统保留的端口,必须使用root用户才能绑定

[root@localhost src]# vi /usr/local/tomcat/conf/server.xml             #搜索关键字8080,找到下面的内容,并把8080,改成80
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

修改完后变成

    <Connector port="80" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

2018-07-16笔记(tomcat 配置)
:wq保存配置后,关闭tomcat,并重新启动,使用生效

[root@localhost src]# /usr/local/tomcat/bin/shutdown.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk1.8
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
[root@localhost src]# /usr/local/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/local/jdk1.8
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.

查看java监听的端口是否变成80,有时候可能会遇到80端口给占用的情况,把占用的进程关闭即可

[root@localhost src]# netstat -lnp |grep java
tcp6       0      0 :::80                   :::*                    LISTEN      1283/java           
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      1283/java           
tcp6       0      0 :::8009                 :::*                    LISTEN      1283/java  

使用浏览器直接访问,可以看到直接输入ip即可访问了
2018-07-16笔记(tomcat 配置)

16.5/16.6/16.7 配置Tomcat虚拟主机

在配置文件server.xml中搜索“Host”找到虚拟主机配置参数

    <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">

        <!-- SingleSignOn valve, share authentication between web applications
             Documentation at: /docs/config/valve.html -->
        <!--
        <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
        -->

        <!-- Access log processes all example.
             Documentation at: /docs/config/valve.html
             Note: The pattern used is equivalent to using pattern="common" -->
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />

      </Host>

这里一个Host段表示一个虚拟主机配置,其中name用来定义域名,appBase用来存放java应用程序的目录,应用程序通常为.war的包,unpackWARs定义是否自动解压war包
#appbase是定义Tomcat的应用(war文件)存放位置
#如果未使用该参数定义其应用,可以使用docbase来指定应用存放目录
#当这两个参数同时存在时,需要将其中一个写为空!!!!!!
我们可以模拟新增一个虚拟主机配置,在之前的虚拟主机</Host>下面新增一段配置

<Host name="www.123.cn" appBase=""
        unpackWARs= "true" autoDeploy="true"
        xmlValidation="false" xmlNamespaceAware="false">
        <Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/>
</Host>

这里定义了docBase,就是网站存放的目录
下面我们用实例来应用这个虚拟主机配置
首先先下载用java开发的博客程序zrlog,下载地址可能会失效,请自行查找下载

[root@localhost logs]# cd /usr/local/src/
[root@cham002 src]# wget http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war
[root@localhost src]# ll
总用量 919720
-rw-r--r--  1 root  root    7122027 1月  15 2018 zrlog-1.7.1-baaecb9-release.war

注意:.war文件可以在windows机器用解压软件解压,也可以放到tomcat的webapps目录,让它自动解包,这里放到webapps目录下

[root@localhost src]# cp /usr/local/src/zrlog-1.7.1-baaecb9-release.war /usr/local/tomcat/webapps/
[root@localhost src]# cd /usr/local/tomcat/webapps/
[root@localhost webapps]# ll
总用量 6960
drwxr-x--- 14 root root    4096 7月  18 10:08 docs
drwxr-x---  6 root root      83 7月  18 10:08 examples
drwxr-x---  5 root root      87 7月  18 10:08 host-manager
drwxr-x---  5 root root     103 7月  18 10:08 manager
drwxr-x---  3 root root     306 7月  18 10:08 ROOT
drwxr-x---  9 root root     126 7月  18 11:14 zrlog-1.7.1-baaecb9-release
-rw-r--r--  1 root root 7122027 7月  18 11:14 zrlog-1.7.1-baaecb9-release.war

可以看到已经自动解包了
这里需要注意的是,当把war包删除的时候,对应的目录也会删除,当把目录删除或改名的时候,war包存在,还会自动解压成对应的目录
这里可以直接ip加博客目录名字进行访问,
2018-07-16笔记(tomcat 配置)
因为这样访问后面还要加目录的名字,比较麻烦,我们来应用下刚才我们新加的虚拟主机虚拟文件

<Host name="www.123.cn" appBase=""
        unpackWARs= "true" autoDeploy="true"
        xmlValidation="false" xmlNamespaceAware="false">
        <Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/>
</Host>

把自动解压出来的目录zrlog-1.7.1-baaecb9-release下所有东西放到/data/wwwroot/123.cn/ 下,也就是刚才我们定义的虚拟主机docBase的目录

[root@localhost webapps]# mkdir -p /data/wwwroot/123.cn/ 
[root@localhost webapps]# cp -r zrlog-1.7.1-baaecb9-release/* /data/wwwroot/123.cn/

因为定义了域名www.123.cn,所以还要在windows机器上修改对应的hosts,把www.123.cn指定到对应的机器上
2018-07-16笔记(tomcat 配置)
用浏览器进行访问,直接输入域名www.123.cn
2018-07-16笔记(tomcat 配置)
可以看到也是正常访问的
下面进入到mysql里面创建数据库并授权

mysql> create database zrlog;
Query OK, 1 row affected (0.00 sec)
mysql> grant all on zrlog.* to 'zrlog'@'%' identified by '123456';
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

把这些信息写入到刚才的zrlog安装向导页面里
2018-07-16笔记(tomcat 配置)
根据提示完成后面的信息即可完成zrlog的安装
2018-07-16笔记(tomcat 配置)

16.8 Tomcat日志

tomcat日志默认是放在tomcat安装目录下的 logs目录下

[root@localhost src]# cd /usr/local/tomcat/logs/
[root@localhost logs]# ll
总用量 40
-rw-r----- 1 root root 13993 7月  18 10:39 catalina.2018-07-18.log
-rw-r----- 1 root root 13993 7月  18 10:39 catalina.out
-rw-r----- 1 root root     0 7月  18 10:11 host-manager.2018-07-18.log
-rw-r----- 1 root root  1206 7月  18 10:39 localhost.2018-07-18.log
-rw-r----- 1 root root  1565 7月  18 10:42 localhost_access_log.2018-07-18.txt
-rw-r----- 1 root root     0 7月  18 10:11 manager.2018-07-18.log

说明:

catalina开头的日志为Tomcat的综合日志,它记录Tomcat服务相关信息,也会记录错误日志。
catalina.2018-xx-xx.log和catalina.out内容相同,前者会每天生成一个新的日志。
host-manager和manager为管理相关的日志,其中host-manager为虚拟主机的管理日志。
localhost和localhost_access为虚拟主机相关日志,其中带access字样的日志为访问日志,不带access字样的为默认虚拟主机的错误日志。
访问日志默认不会生成,需要在server.xml中配置一下。
配置访问日志
具体方法是在对应虚拟主机的<Host></Host>里面加入下面的配置(以域名www123.cn为例):

   <Host name="www.123.cn" appBase=""
          unpackWARs= "true" autoDeploy="true"
          xmlValidation="false" xmlNamespaceAware="false">
          <Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/>
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="www.123.cn_access" suffix=".log"
               pattern="%h %l %u %t "%r" %s %b" />
    </Host>

核心参数:<Valve/> 说明:
prefix定义访问日志的前缀;
suffix定义日志的后缀;
pattern定义日志格式。
新增加的虚拟主机默认并不会生成类似默认虚拟主机的那个localhost.日期.log日志,错误日志会统一记录到catalina.out中。关于Tomcat日志,你最需要关注catalina.out,当出现问题时,我们应该第一想到去查看它。

猜你喜欢

转载自blog.51cto.com/13736286/2146252