16.4 配置Tomcat监听80端口
- Tomcat默认是监听8080端口,本节学习如何配置让它监听80端口.
- 编辑Tomcat配置文件:
vim /usr/local/tomcat/conf/server.xml - 将Connector port="8080" protocol="HTTP/1.1"修改为Connector port="80" protocol="HTTP/1.1"
- 重启Tomcat:
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh - 查看配置结果(是否监听80端口):
ps aux|grep tomcat
netstat -lntp | grep java
注意:此处发现tomcat并没有监听80端口,经查原来是nginx已监听了80端口,所以需要先停止nginx,然后再重启下tomcat,就能监听80端口了. - 此时在浏览器中再访问tomcat就不用再加80端口了:
16.5/16.6/16.7 配置Tomcat虚拟主机
- web服务器(apache,nginx,tomcat)支持一个IP可以访问多个域名,每一个域名代表一个网站,每一个网站的配置文件对应一个虚拟主机.因此,有多少个网站,我们就配置多少个虚拟主机.
- (1)war包形式的虚拟主机(对应appBase)
vim /usr/local/tomcat/conf/server.xml
其中<Host>和</Host>之间的配置为虚拟主机配置部分,name定义域名,appBase定义应用的目录,Java的应用通常是一个war的压缩包,你只需要将war的压缩包放到appBase目录下面即可。appBase为应用存放目录,通常是需要把war包直接放到该目录下面,它会自动解压成一个程序目录(虚拟主机配置文件中的unpackWARs= "true"所定义的)。 - (2)目录形式的虚拟主机(对应docBase)
增加虚拟主机,编辑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包的,docBase则是直接放网站程序.
- 下面我们通过部署一个java的应用来体会appBase和docBase目录的作用:
- (1) 通过部署war包来访问zrlog博客:
- 下载zrlog:
cd /usr/local/src/
wget http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war - 将zrlog的war包放到tomcat的webapps目录下:
cp zrlog-1.7.1-baaecb9-release.war /usr/local/tomcat/webapps/ - 将zrlog的war包改成一个简短的名字:
mv /usr/local/tomcat/webapps/zrlog-1.7.1-baaecb9-release /usr/local/tomcat/webapps/zrlog - 配置博客:
浏览器访问 ip/zrlog/install/ #此处是已设定tomcat监听80端口 - 配置zrlog数据库:
- 查看mysql是否已启动:
ps aux | grep mysql - 连接到mysql数据库:
mysql -uroot -p123456 - 创建zrlog博客用的数据库:
create database zrlog; - 创建用户zrlog:
grant all on zrlog.* to 'zrlog'@127.0.0.1 identified by '123456'; - 验证创建的用户:
mysql -uzrlog -h127.0.0.1 -p123456 - 查看创建的数据库:
show databases; -
然后回到浏览器页面用刚才创建的数据库等信息配置好博客,接着浏览器访问ip/zrlog就是博客页面了.
- (2) 通过docBase来部署并访问zrlog博客:
- 创建 /data/wwwroot/123.cn目录:
mkdir /data/wwwroot/123.cn - 将tomcat webapps zrlog目录下所有文件移到 /data/wwwroot/123.cn目录下:
mv /usr/local/tomcat/webapps/zrlog/* /data/wwwroot/123.cn/ - windows hosts文件中绑定www.123.cn
- windows cmd中测试是否成功映射:
- 重启tomcat让配置生效:
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh - 然后就可以通过www.123.cn 来访问博客了(而不是ip/zrlog的形式)
- 遇到的问题:
实验过程中遇到tomcat的8005端口不能起来的情况(8005端口起不来则无法通过浏览器访问tomcat),直接导致该问题的原因是关闭tomcat时提示不成功,如下图所示: - 解决方法:
参照网上的方法 https://blog.51cto.com/zero01/2053974?utm_source=oschina-app 试了很久,但是没能解决! - 最终是把tomcat重新安装后, 解决了问题!
16.8 Tomcat日志
- 查看tomcat日志:
ls /usr/local/tomcat/logs - 其中catalina开头的日志为Tomcat的综合日志,它记录Tomcat服务相关信息,也会记录错误日志。
- 其中catalina.2018-xx-xx.log和catalina.out内容相同,前者会每天生成一个新的日志。
- host-manager和manager为管理相关的日志,其中host-manager为虚拟主机的管理日志。
-
localhost和localhost_access为虚拟主机相关日志,其中带access字样的日志为访问日志,不带access字样的为默认虚拟主机的错误日志。
- 新增虚拟主机的访问日志默认不会生成,需要在server.xml中配置一下。
具体方法是在对应虚拟主机的<Host></Host>里面加入下面的配置(假如域名为123.cn):
vi /usr/local/tomcat/conf/server.xml
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="123.cn_access" suffix=".log"
pattern="%h %l %u %t "%r" %s %b" /> - prefix定义访问日志的前缀,suffix定义日志的后缀,pattern定义日志格式。新增加的虚拟主机默认并不会生成类似默认虚拟主机的那个localhost.日期.log日志,错误日志会统一记录到catalina.out中。
- 重启tomcat并在博客页面随便做些操作后可看到日志文件生成:
- 注意:
关于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
转载于:https://blog.51cto.com/13517946/2091170