【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志

一、配置Tomcat监听80端口

如何让访问浏览器时,输入IP后,不用后缀8080,直接默认80端口(80端口可以忽略,访问的时候可以直接IP访问):

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


编辑tomcat的配置文件:

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


Connector port="8080" protocol="HTTP/1.1"       修改为Connector port="80" protocol="HTTP/1.1"

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


停用并重新启用tomcat:
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh


查看一下端口:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志

发现80端口被nginx占用了,所以要stop掉nginx进程,再来重启tomcat就可以了:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


因为前面的实验我们把host修改了 ,所以现在它直接显示it works,也是代表OK了:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志



二、配置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>

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


 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

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


 浏览器访问 : 

172.16.17.71/zrlog/

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


登录到mysql:

mysql -uroot -p222222

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


创建zrlog数据库:

create database zrlog;

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


创建用户和密码:

grant all on zrlog.* to 'zrlog'@127.0.0.1 identified by '222222';

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


再到前面的谷歌浏览器,按提示去配置下去即可:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


这样就安装好了一个博客了。


但是这样http://172.16.17.71/zrlog/这个网址访问不方便 ,我们要设置成其他的域名来跳转过去,先看一下我们前面在tomcat的配置文件里设置的路径:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


所以我们要设置成直接访问www.123.cn 来访问,如果做呢?先创建一个123.cn目录:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


再将zrlog的所有文件移到这个目录下:

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

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


再去绑定windows的host:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


在windows上ping一下www.123.cn是否是通的:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


然后重启一下服务:

/usr/local/tomcat/bin/shutdown.sh

/usr/local/tomcat/bin/startup.sh

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


查看一下端口 ,要8005端口起来了再去浏览器访问www.123.cn:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


再到浏览器访问发现OK了:

【Tomcat搭建】配置Tomcat监听80端口、配置Tomcat虚拟主机和Tomcat日志


三、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,当出现问题时,我们应该第一想到去查看它。



扩展


邱李的tomcat文档:
https://www.linuser.com/forum.php?mod=forumdisplay&fid=37 

JAR、WAR包区别:
http://blog.****.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.****.net/l1028386804/article/details/51547408 

4 jvm性能调优监控工具jps/jstack/jmap/jhat/jstat:
http://blog.****.net/wisgood/article/details/25343845 
http://guafei.iteye.com/blog/1815222 

5 gvm gc 相关:
http://www.cnblogs.com/Mandylover/p/5208055.html 

http://blog.****.net/yohoph/article/details/42041729