配置Tomcat监听80端口
1.修改配置文件
Tomcat 监听的是8080端口,如果想要直接访问,不加8080端口(默认输入一个IP或者域名,访问80端口时是可以省略IP后端口号的)就需要配置Tomcat监听80端口,Tomcat是支持端口自定义的。
编辑Tomcat配置文件server.xml,命令如下:
[root@tomcat ~]# vi /usr/local/tomcat/conf/server.xml
直接搜索8080找到如下内容:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
将这里的8080直接改成80
修改完配置文件,接下来就是重启Tomcat服务,Tomcat服务是不支持restart的方式重启服务的,所以要想重启服务必须先关闭服务,使用命令:
[root@tomcat ~]# /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@tomcat ~]# /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.
2.测试
这时,我们再次使用netstat命令监听Java相关服务端口
[root@tomcat ~]# netstat -plnt | grep java
tcp6 0 0 :::8009 :::* LISTEN 47873/java
tcp6 0 0 :::80 :::* LISTEN 47873/java
tcp6 0 0 127.0.0.1:8005 :::* LISTEN 47873/java
可以看到这次三个服务端口都存在,证明Tomcat服务启动成功。
3.浏览器访问
配置文件修改完成,并Tomcat服务启动成功后,打开浏览器在地址栏中输入http://192. 168.100.11/(注意你的IP),这时又会看见Tomcat默认页面。
配置Tomcat虚拟主机
1.查看默认虚拟主机
Tomcat和Apache、Nginx一样,都支持虚拟主机配置。每个虚拟主机配置文件都是一台服务器,支持一个IP下可以访问多个域名,每个域名代表一个网站。所以一台服务器上可以配置多个网站。
编辑Tomcat配置文件,直接在配置文件内搜索Host,找到以下内容
[root@tomcat ~]# vi /usr/local/tomcat/conf/server.xml
<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>和</Host>之间的配置为虚拟主机配置部分:
- name 定义域名;
- appBase 定义应用的目录;
- unpackWARs 为是否自动解压war包;
- autoDeploy 如果此项设置为true,表示Tomcat服务处于运行状态,能够检测appbase下的文件,如果有新的Web应用加入进来,会自动发布这个Web应用。
Java的应用通常是一个JAR的压缩包,你只需要将JAR的压缩包放到appBase目录下面即可。刚刚我们访问的Tomcat默认页其实就是在appBase目录下面,不过是在它的子目录ROOT里。
2.新增虚拟主机
新增虚拟主机,编辑server.xml在</Host>下面增加以下内容:
[root@tomcat ~]# vi /usr/local/tomcat/conf/server.xml
<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为应用存放目录(实际上是一个相对路径,相对于/usr/local/tomcat/路径),通常是需要把war包直接放在该目录下面,它会自动解压成一个程序目录。
搭建了一个Tomcat,想要使用Tomcat去跑一个网站。首先应用不能是一个传统所谓的目录(Apache、Nginx访问网站,首先需要指定一个目录,目录里存放着PHP文件或者是Html的文件,然后去访问),Tomcat需要提供一个war的包,就是一个压缩包,这个压缩包里面包含着运行这个网站的一些文件,包括配置,js代码,数据库相关的等等,都需要打包成war这种文件,而这个文件需要放置在webapps里面。
3.appBase部署Java应用
接下来我们通过部署一个Java应用来体会appBase和docBase目录的区别。
为了方便测试,下载一个zrlog(Java写的blog站点应用,轻量),zrlog实际就是一个war包
(下载地址:http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war)
先暂时将zrlog的war包下载到/usr/local/src目录下:
[root@tomcat ~]# cd /usr/local/src/
[root@tomcat src]# wget http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war
[root@tomcat src]# ls |grep zrlog
zrlog-1.7.1-baaecb9-release.war
appBase支持自动解压,所以直接将war包拷贝到/usr/local/tomcat/webapps/目录下:
[root@tomcat src]# cp zrlog-1.7.1-baaecb9-release.war /usr/local/tomcat/webapps/
[root@tomcat 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
将war包拷贝到/usr/local/tomcat/webapps/目录下之后,包会自动解压。(前提是tomcat正常启动)
重命名war包的文件名:
[root@tomcat src]# cd /usr/local/tomcat/webapps/
[root@tomcat webapps]# mv zrlog-1.7.1-baaecb9-release zrlog
[root@tomcat webapps]# ls
docs examples host-manager manager ROOT zrlog zrlog-1.7.1-baaecb9-release.war
[root@tomcat webapps]# ls
docs host-manager ROOT zrlog-1.7.1-baaecb9-release
examples manager zrlog zrlog-1.7.1-baaecb9-release.war
一旦重命名或者删除war包解压之后的包的文件时,war包就会再解压出一个文件夹。
用浏览器访问http://192.168.100.11/zrlog(注意你的IP)。
出现安装向导,这是一个配置数据库的过程。首先安装数据库服务,登入数据库,在数据库中创建一个zrlog数据库和zrlog用户。
[root@tomcat webapps]# yum -y install mariadb mariadb-server
[root@tomcat webapps]# systemctl start mariadb
[root@tomcat webapps]# mysql_secure_installation //初始化数据库
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.6.39 MySQL Community Server (GPL)
Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> create database zrlog;
//创建zrlog数据库
Query OK, 1 row affected (0.00 sec)
mysql> grant all on zrlog.* to 'zrlog'@127.0.0.1 identified by '000000';
Query OK, 0 rows affected (0.05 sec)
//创建zrlog用户
mysql>exit
Byebye
//退出数据库
检查创建用户是否可以登录数据库,使用zrlog用户登录。
[root@tomcat webapps]# mysql -uzrlog -h127.0.0.1 -p000000
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.6.39 MySQL Community Server (GPL)
Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
//检查已有数据库
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
| zrlog |
+--------------------+
3 rows in set (0.00 sec)
mysql> exit
Byebye
检查完成,zrlog用户登录成功。使用zrlog用户信息填写刚才在浏览器中打开的网页,Email填写自己的邮箱,本次是实验,填写内容为自定义邮箱(tomcat@163.com),单击“下一步”按钮。
设置管理员账号(admin)和管理员密码(123456),网站标题和子标题按需填写,本次自定义内容(网站标题:“测试”,网站子标题:“linux”)。
填写完成后,单击“下一步”按钮,可以看到安装完成的界面。
单击“点击查看”按钮,我们就可以进入搭建好的zrlog页面了。
我们也可以进入管理页面,写一些文章,单击上图主菜单栏中的“管理”按钮。
输入安装向导里已经设置好的账户名和密码(admin:123456),单击“登录”按钮,登录成功页面。
单击“文章撰写”栏目,写上自己想写的内容,然后保存。
然后回到主页面,你就可以看到刚才你写的内容。
4.docBase部署Java应用
我们在浏览器访问zrlog需要指定IP地址加目录,那么如何才能输入IP直接访问该目录。
查看虚拟主机docBase的路径:
[root@tomcat ~]# vi /usr/local/tomcat/conf/server.xml
<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定义的目录为:/data/wwwroot/123.cn
创建docBase目录:
[root@tomcat webapps]# mkdir -p /data/wwwroot/123.cn/
将/usr/local/tomcat/webapps/zrlog中的所有文件移动到/data/wwwroot/123.cn/目录下:
[root@tomcat webapps]# mv /usr/local/tomcat/webapps/zrlog/* /data/wwwroot/123.cn/
接下来在Windows下绑定hosts文件
hosts文件路径:C:\Windows\System32\drivers\etc
在文件下面添加:
192.168.100.11 www.123.cn
5.测试
打开命令提示符(CMD),用ping命令ping www.123.cn 看IP是否为虚拟机IP,如果是的话,现在就可以访问了。
接下来就用域名去访问zrlog页面,因为之前配置完虚拟主机后,并没有重启服务,这里要重启一下服务。
[root@tomcat webapps]# /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@tomcat webapps]# /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.
重启Tomcat服务完成后,打开浏览器在地址栏输入www.123.cn,就可以看到zrlog的首页。
这个页面跟之前用指定IP加目录访问的页面一模一样的。
Tomcat日志
1.查看日志
Tomcat在应用过程中,难免会出现错误,如何去查看这些错误,这就需要查看Tomcat的日志。Tomcat日志放在/usr/local/tomcat/logs/目录下。
[root@tomcat ~]# ls /usr/local/tomcat/logs/
catalina.2020-03-29.log localhost.2020-03-29.log
catalina.out localhost_access_log.2020-03-29.txt
host-manager.2020-03-29.log manager.2020-03-29.log
- catalina开头的日志为Tomcat的综合日志,它记录Tomcat服务相关的信息,也会记录错误日志。
- catalina.2020-xx-xx.log和catalina.out内容相同,前者会每天生成一个新的日志。
- host-manager和manager为管理相关的日志,其中host-manager为虚拟主机的管理日志。
- localhost和localhost-access为虚拟主机相关日志,其中带access字样的日志为访问日志,不带access字样的为默认虚拟主机的错误日志。
2.配置生成日志
由于日志默认不会生成,需要在server.xml中配置一下。所以接下来配置新增虚拟主机的访问日志,具体方法是在对应虚拟主机的<Host></Host>里面加入下面的配置(我们用www.123.cn来进行配置),编辑以下配置文件server.xml。
[root@tomcat ~]# vi /usr/local/tomcat/conf/server.xml
<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="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,当出现问题是,我们应该第一想到去查看它。
配置完成后,重启Tomcat服务。
[root@tomcat ~]# /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@tomcat ~]# /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.
重启Tomcat服务完成后,访问网站,查看/usr/local/tomcat/logs目录下是否有日志生成并且查看生成的日志信息。
[root@tomcat ~]# ls /usr/local/tomcat/logs/
123_access_log.2020-03-29.txt localhost.2020-03-29.log
catalina.2020-03-29.log localhost_access_log.2020-03-29.txt
catalina.out manager.2020-03-29.log
host-manager.2020-03-29.log
[root@tomcat ~]# cat /usr/local/tomcat/logs/123_access_log.2020-03-29.txt
192.168.100.1 - - [29/Mar/2020:22:06:16 -0700] "GET / HTTP/1.1" 200 8645
192.168.100.1 - - [29/Mar/2020:22:06:16 -0700] "GET //favicon.ico HTTP/1.1" 200 9662
至此,Tomcat搭建配置完成。