Tomcat配置主机、日志

十四周二次课(1月22日)
16.4 配置Tomcat监听80端口
16.5/16.6/16.7 配置Tomcat虚拟主机
16.8 Tomcat日志

• vim /usr/local/tomcat/conf/server.xml
Connector port=”8080” protocol=”HTTP/1.1”修改为Connector port=”80” protocol=”HTTP/1.1”
• /usr/local/tomcat/bin/shutdown.sh
• /usr/local/tomcat/bin/startup.sh
重启后发现没有监听80端口。查找80端口是nginx占用了。所有要先停掉nginx再重启tomcat
这里写图片描述
/etc/init.d/nginx stop
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh
netstat -lntp |grep java
这里写图片描述

8005端口启动有点慢,启动8005之后打开页面就会很快
这里写图片描述

16.5 配置Tomcat的虚拟主机
编辑Tomcat配置文件,找到Host位置,Host就是一个虚拟主机,也是Tomcat的核心配置

vim /usr/local/tomcat/conf/server.xml

     <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
<!--appBase是应用项目位置,相当于root或者documentroot,unpackWARs是自动解压webapps中的war包,-->
        <!-- 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 &quot;%r&quot; %s %b" />
      </Host>

其中和之间的配置为虚拟主机配置部分,name定义域名,
appBase定义应用的目录,Java的应用通常是一个war的压缩包,你只需要将war的压缩包放到appBase目录下面即可。刚刚阿铭访问的Tomcat默认页其实就是在appBase目录下面,不过是在它子目录ROOT里。

增加一个虚拟主机,编辑server.xml,在下面增加如下内容(单独指定一个目录用docBase。不用上面的war包)

<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,这个参数用来定义网站的文件存放路径,如果不定义,默认是在appBase/ROOT下面,定义了docBase就以该目录为主了,其中appBase和docBase可以一样。在这一步操作过程中很多同学遇到过访问404的问题,其实就是docBase没有定义对。
appBase为应用存放目录,通常是需要把war包直接放到该目录下面,它会自动解压成一个程序目录
这里写图片描述

下面我们通过部署一个java的应用来体会appBase和docBase目录的作用
下载zrlog wget http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war
mv zrlog-1.7.1-baaecb9-release.war /usr/local/tomcat/webapps/
mv /usr/local/tomcat/webapps/zrlog-1.7.1-baaecb9-release /usr/local/tomcat/webapps/zrlog
浏览器访问 ip:8080/zrlog/install/
这里写图片描述

需要创建一个zrlog数据库

[root@wwlinux701 webapps]# ps -ef | grep mysql
[root@wwlinux701 webapps]# mysql -uroot -p123456
mysql> creator database zrlog;
mysql> grant all on zrlog.* to 'zrlog'@127.0.0.1 identified by '123456';
[root@wwlinux701 webapps]# mysql -uzrlog -h127.0.0.1 -p123456
mysql> show databases;

这里写图片描述

这里写图片描述

这里写图片描述

上面每次访问都是用的ip和目录。前面我们配置了docBase=”/data/wwwroot/123.cn/现在把网站内容mv到这个目录下。然后修改本机的host文件就可以直接用域名访问了
mv /usr/local/tomcat/webapps/zrlog/* /data/wwwroot/123.cn/
这里写图片描述
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh
netstat -lnpt
这里写图片描述

16.8 Tomcat日志
这里写图片描述
ls /usr/local/tomcat/logs
其中catalina开头的日志为Tomcat的综合日志,它记录Tomcat服务相关信息,也会记录错误日志。
其中catalina.2017-xx-xx.log和catalina.out内容相同,前者会每天生成一个新的日志。

host-manager和manager为管理相关的日志,其中host-manager为虚拟主机的管理日志。

localhost和localhost_access为虚拟主机相关日志,其中带access字样的日志为访问日志,不带
access字样的为默认虚拟主机的错误日志。
访问日志默认不会生成,需要在server.xml中配置一下。

具体方法是在对应虚拟主机的里面加入下面的配置(假如域名为123.cn):

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
         prefix="123.cn_access" suffix=".log"
         pattern="%h %l %u %t &quot;%r&quot; %s %b" />

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值