十四周二次课

16.4 配置Tomcat监听80端口

• 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

编辑Tomcat配置文件:

[root@adailinux ~]# vim /usr/local/tomcat/conf/server.xml 
……
<Connector port="80" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
……

说明: 在配置文件中搜索8080找到如上所示参数,将默认的8080端口改为80端口,更改完成后重启服务。

[root@adailinux ~]# /usr/local/tomcat/bin/shutdown.sh

[root@adailinux ~]# /usr/local/tomcat/bin/startup.sh

查看服务状态:

[root@adailinux ~]# ps aux |grep tomcat

[root@adailinux ~]# netstat -lntp |grep java
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      2716/java           
tcp6       0      0 :::8009                 :::*                    LISTEN      2716/java   

[root@adailinux ~]# netstat -lntp |grep 80
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      1825/nginx: master  
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      2716/java           
tcp6       0      0 :::8009                 :::*                    LISTEN      2716/java           

说明: 此时Tomcat服务正常运行,但是没有监听端口,监听80端口的是nginx服务。如果想让Tomcat监听80端口,需要关闭nginx服务,然后重启Tomcat服务。

[root@adailinux ~]# systemctl stop nginx.service 
[root@adailinux ~]# /usr/local/tomcat/bin/shutdown.sh
[root@adailinux ~]# /usr/local/tomcat/bin/startup.sh 

检测服务状态:
[root@adailinux ~]# netstat -lntp |grep java
tcp6       0      0 :::80                   :::*                    LISTEN      2815/java           
tcp6       0      0 :::8009                 :::*                    LISTEN      2815/java           

说明: 此时使用浏览器访问主机IP可以直接进入Tomcat主页。

 

 


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

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

•其中<Host>和</Host>之间的配置为虚拟主机配置部分,name定义域名,

appBase定义应用的目录,Java的应用通常是一个war的压缩包,你只需要将war的压缩包放到appBase目录下面即可。刚刚阿铭访问的Tomcat默认页其实就是在appBase目录下面,不过是在它子目录ROOT里。

• 增加虚拟主机,编辑server.xml,在</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,这个参数用来定义网站的文件存放路径,如果不定义,默认是在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/

• mv /usr/local/tomcat/webapps/zrlog/* /data/wwwroot/123.cn/

配置虚拟主机(上)

[root@adailinux ~]# vim /usr/local/tomcat/conf/server.xml
……
<Host name="www.123.cn" appBase=""
#appbase是定义Tomcat的应用(war文件)存放位置  
#如果未使用该参数定义其应用,可以使用docbase来指定应用存放目录
#当这两个参数同时存在时,需要将其中一个写为空
        unpackWARs= "true" autoDeploy="true"
        xmlValidation="false" xmlNamespaceAware="false">
        <Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/>
</Host>

说明: 在配置文件中搜索“Host”找到虚拟主机配置参数,在配置文件自带(默认)虚拟主机后面增加如上参数(增加一个虚拟主机)。

配置Tomcat的虚拟主机(中)

本节使用Tomcat部署一个Java应用。

下载zrlog

[root@adailinux src]# wget http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war

[root@adailinux src]# cp zrlog-1.7.1-baaecb9-release.war /usr/local/tomcat/webapps/
#因为appbase支持自动解压war包,所以将zrlog包放到appbase的根目录下。

[root@adailinux src]# ls /usr/local/tomcat/webapps/
docs      host-manager  ROOT                         zrlog-1.7.1-baaecb9-release.war
examples  manager       zrlog-1.7.1-baaecb9-release
#拷贝完成后,zrlog包会自动被解压,解压完成后就可以直接访问该文件。  

重命名:
[root@adailinux src]# cd /usr/local/tomcat/webapps/
[root@adailinux webapps]# mv zrlog-1.7.1-baaecb9-release zrlog

注: 只要war包在appbase的目录下,更改相应文件名后就会自动被解压再次生成相应的文件,所以为了方便起见,当war下载完成后进行移动的同时对其重命名,如下:

[root@adailinux webapps]# cp /usr/local/src/zrlog-1.7.1-baaecb9-release.war ./zrlog.war

安装zrlog

在浏览器输入IP:192.168.8.132:8080/zrlog/instll 进入安装向导:

mark

创建数据库

[root@adailinux ~]# mysql -uroot -p123456
Welcome to the MySQL monitor.
mysql> create database zrlog;
Query OK, 1 row affected (0.00 sec)

mysql> grant all on zrlog.* to 'zrlog'@'127.0.0.1' identified by '123456';
Query OK, 0 rows affected (0.00 sec)

连接数据库

mark

创建管理员密码

mark

创建完成后点击“下一步”: mark

配置Tomcat的虚拟主机(下)

之前想要访问zrlog需要在浏览器中指定IP和目录(192.168.8.132/zrlog),那么如何才能输入IP直接访问该目录呢?配置如下:

[root@adailinux ~]# vim /usr/local/tomcat/conf/server.xml
……
    <Host name="www.zrlog.cn" appBase=""
          unpackWARs= "true" autoDeploy="true"
          xmlValidation="false" xmlNamespaceAware="false">
          <Context path="" docBase="/data/wwwroot/zrlog.cn/" debug="0" reloadable="true" crossContext="true"/>
    </Host>
……
[root@adailinux ~]# /usr/local/tomcat/bin/shutdown.sh 
[root@adailinux ~]# /usr/local/tomcat/bin/startup.sh

然后创建docbase指定的目录,并将zrlog的war文件移动到该目录下:

[root@adailinux ~]# mkdir /data/wwwroot/zrlog.cn
[root@adailinux ~]# mv /usr/local/tomcat/webapps/zrlog/* /data/wwwroot/zrlog.cn/

完成以上操作后,在Windows中绑定hosts。

mark

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中配置一下。

•具体方法是在对应虚拟主机的<Host></Host>里面加入下面的配置(假如域名为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,当出现问题时,我们应该第一想到去查看它。

[root@adailinux ~]# ls /usr/local/tomcat/logs/
catalina.2017-08-29.log      localhost.2017-08-29.log
catalina.out                 localhost_access_log.2017-08-29.txt
host-manager.2017-08-29.log  manager.2017-08-29.log

说明:

  • catalina开头的日志为Tomcat的综合日志,它记录Tomcat服务相关信息,也会记录错误日志。
  • catalina.2017-xx-xx.log和catalina.out内容相同,前者会每天生成一个新的日志。
  • host-manager和manager为管理相关的日志,其中host-manager为虚拟主机的管理日志。
  • localhost和localhost_access为虚拟主机相关日志,其中带access字样的日志为访问日志,不带access字样的为默认虚拟主机的错误日志。
  • 访问日志默认不会生成,需要在server.xml中配置一下。

配置访问日志

具体方法是在对应虚拟主机的<Host></Host>里面加入下面的配置(以域名www.zrlog.cn为例):

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

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

 


 

扩展
邱李的tomcat文档 https://www.linuser.com/forum.php?mod=forumdisplay&fid=37
JAR、WAR包区别  http://blog.csdn.net/lishehe/article/details/41607725
tomcat常见配置汇总  http://blog.sina.com.cn/s/blog_4ab26bdd0100gwpk.html
resin安装 http://fangniuwa.blog.51cto.com/10209030/1763488/
1 tomcat  单机多实例
http://www.ttlsa.com/tomcat/config-multi-tomcat-instance/
2 tomcat的jvm设置和连接数设置
http://www.cnblogs.com/bluestorm/archive/2013/04/23/3037392.html
3 jmx监控tomcat
http://blog.csdn.net/l1028386804/article/details/51547408
4 jvm性能调优监控工具jps/jstack/jmap/jhat/jstat
http://blog.csdn.net/wisgood/article/details/25343845 
http://guafei.iteye.com/blog/1815222
5 gvm gc 相关
http://www.cnblogs.com/Mandylover/p/5208055.html
http://blog.csdn.net/yohoph/article/details/42041729

猜你喜欢

转载自my.oschina.net/u/3803405/blog/1813445