一、关于Tomcat的理解
tomcat是免费开源的servlet的容器。
二、安装Tomcat(非安装版)
(首先确保你的电脑中已经装上了对应的JDK了)
1. 首先下载Tomcat完整zip包: http://tomcat.apache.org 我下载了 最新的 apache-tomcat-9.0.2
2. 然后把包解压后,随便放入一个文件下:如:
/Users/***/Documents/server/apache-tomcat-9.0.2
3. 下载完之后:cd进入该目录下
cd /Users/***/Documents/server/apache-tomcat-9.0.2/bin/
4. 修改所有的 sh 脚本文件的权限 : chmod 755 *.sh
5. 执行启动脚本:sh startup.sh
6. 打开浏览器访问:http://localhost:8080/ :如显示如下页面说明配置成功。
三、 Tomcat的目录结构
四、 一个JavaWeb如何部署到Tomcat下
五. 关于输出log
1. 开发的时候在idea配置Tomcat时候,有一项log可以指定到你想要存储log的位置
2. 部署logj4
参考:http://blog.youkuaiyun.com/hu_shengyang/article/details/6754031
1)导入logj4的jar包
下载:http://mirrors.hust.edu.cn/apache/logging/log4j/1.2.17/log4j-1.2.17.zip 或者添加maven库
<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
2)在/WEB-INF/log4j.xml新建一个log4j.xml(log4j的配置文件),并写入如下配置(注意修改里面存放log的路径文件)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<!-- 输出日志到控制台 ConsoleAppender -->
<appender name="console"
class="org.apache.log4j.ConsoleAppender">
<param name="Threshold" value="info"></param>
<layout class="org.apache.log4j.TTCCLayout">
<param name="ConversionPattern" value="TTCCLayout"></param>
</layout>
</appender>
<!-- 输出日志到文件 每天一个文件 -->
<appender name="dailyRollingFile"
class="org.apache.log4j.DailyRollingFileAppender">
<param name="Threshold" value="info"></param>
<param name="ImmediateFlush" value="true"></param>
<param name="File" value="/Applications/apache-tomcat-8.5.24/logs/loglog1.log"></param>
<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"></param>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss\} %-5p] [%t] {%c:%L}-%m%n"></param>
</layout>
</appender>
<!-- 输出日志到文件 文件大小到达指定尺寸的时候产生一个新的文件 -->
<appender name="railyFile"
class="org.apache.log4j.RollingFileAppender">
<param name="File" value="/Applications/apache-tomcat-8.5.24/logs/loglog2.log"></param>
<param name="ImmediateFlush" value="true"/>
<param name="Threshold" value="info"></param>
<param name="Append" value="true"></param>
<param name="MaxFileSize" value="30KB"></param>
<param name="MaxBackupIndex" value="100"></param>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss\} %-5p] [%t] {%c:%L}-%m%n"></param>
</layout>
</appender>
<!-- 输出日志到文件 -->
<appender name="file"
class="org.apache.log4j.FileAppender">
<param name="File" value="/Applications/apache-tomcat-8.5.24/logs/loglog3.log"></param>
<param name="Threshold" value="info"></param>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss\} %-5p] [%t] {%c:%L}-%m%n"></param>
</layout>
</appender>
<!--
定义全局的日志输出级别,但是在输出目的地的配置中配置的具体输出级别优先级高于全局定义的优先级。
如果在railyFile中定义<param name="Threshold" value="info"></param>,那么将会把info以上级别的信息输出
-->
<root>
<priority value="debug" />
<appender-ref ref="console" />
<appender-ref ref="dailyRollingFile" />
<appender-ref ref="railyFile" />
<appender-ref ref="file" />
</root>
</log4j:configuration>
注意 :log4j建议只使用五个级别,级别顺序(由低到高): DEBUG < INFO < WARN < ERROR < FATAL
- 需要在此项去调整:<param name="Threshold" value="info"></param>
- 当前是info所以debug会出不来
- http://bbs.youkuaiyun.com/topics/390982201
- 分离:cat file.log |grep ERROR > error.log
3)让项目知道这个log4j.xml文件。所以在web.xml中引入(配置)
<!-- log4j 系统日志-->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log4j.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
4)实例化它
import org.apache.log4j.Logger;
...
private static Logger logger = Logger.getLogger(other.class);
5)引用
logger.info("这是 log info");
logger.debug("这是 log debug");
logger.error("这是 log error");
6)输出
[2017-12-11 17:16:39 INFO ] -这是 log info
[2017-12-11 17:16:39 ERROR] -这是 log error