发表于: 2017-10-21 20:06:50

1 711


一.今日学习

1.整合redis数据库,创建工具类

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public final class RedisUtils {
//Redis服务器IP
   private static String ADDR = "127.0.0.1";
//Redis的端口号
   private static int PORT = 6379;
//"admin";//访问密码
   private static String AUTH = null;
//可用连接实力的最大数目,默认值为8;如果复制为-1则表示不限制,
   //如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
   private static int MAX_ACTIVE = 1024;
//控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
   private static int MAX_IDLE = 200;
//等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
   private static int MAX_WAIT = 10000;

private static int TIMEOUT = 10000;
//在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
   private static boolean TEST_ON_BORROW = true;

private static JedisPool jedisPool = null;


static {
try {
JedisPoolConfig config = new JedisPoolConfig();
//config.setMaxActive(MAX_ACTIVE);
           config.setMaxIdle(MAX_IDLE);
config.setMaxWaitMillis(MAX_WAIT);
config.setTestOnBorrow(TEST_ON_BORROW);
jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
    * 获取Jedis实例
    */
   public synchronized static Jedis getJedis() {
try {
if (jedisPool != null) {
Jedis resource = jedisPool.getResource();
return resource;
} else {
return null;
}
} catch(Exception e) {
e.printStackTrace();
return null;
}
}
/**
    * 释放jedis资源
    */
   public static void returnResource(final Jedis jedis) {
if (jedis != null) {
jedisPool.returnResource(jedis);
}
}

}


2.学习slf4j与log4j 2整合打印日志

(1)slf4j----Simple Logging Facade for Java,为java提供的简单日志Facade。slf4j入口不负责具体的日志实现,只在编译时负责寻找合适的日志系统进行绑定。

目前的日志框架有jdk自带的logging,log4j1、log4j2、logback,用于实现日志统一的框架apache的commons-logging、slf4j.slf4j与具体实现的整合关系如下:

(2)采用log4j 2作为日志框架实现的调用关系:

1)首先系统包含slf4j-api作为日志接入的接口。

2)at compile时slf4j-api中public final class LoggerFactor类中 private final static void bind() 方法会寻找具体的日志实现类绑定,主要通过StaticLoggerBinder.getSingleton();语句调用。

3)slf4j-log4j12:链接slf4j-api和log4j中间的适配器。它实现了slf4j-api中StaticLoggerBinder接口,从而使得在编译时绑定的是slf4j-log4j12的getSingleton()方法。

4)log4j:这个是具体的日志系统。通过log4j-slf4j-impl初始化Log4j,达到最终日志的输出。

(3)具体实现方法

1)在pom.xml新增log4j2与slf4j依赖

<!--引入 slf4j相关依赖-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
</dependency>
<!-- Slf4j桥接Log4j2 -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.version}</version>
<scope>test</scope>
</dependency>
<!--引入log4j 2相关依赖-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>${log4j.version}</version>
</dependency>

(2)在src/main/resources目录下新建log4j2.xml配置文件

<?xml  version="1.0" encoding="UTF-8"?>
<!-- Log4j 2.x 配置文件。每600秒自动检查和应用配置文件的更新; -->
<Configuration status=" DEBUG" monitorInterval="600" strict="true" schema="Log4J-V2.2.xsd">

<properties>
<property name="LOG_HOME">/home/data/jnshu/logs</property>
</properties>


<Appenders>
<!-- 输出到控制台 -->
       <Console name="Console" target="SYSTEM_OUT">
<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
<PatternLayout pattern="%highlight{%d{yyyy.MM.dd   HH:mm:ss,SSS} %-5level %class{36} %L %M - %msg%xEx%n }
                                                                       {FATAL=white, ERROR=red, WARN=blue, INFO=black, DEBUG=green, TRACE=blue}" />
</Console>

<!--输出到文件-->
       <File name="FileInfo" fileName="../logs/Info.log" append="false">
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
<PatternLayout pattern=" %d{yyyy.MM.dd   HH:mm:ss,SSS} %-5level %class{36} %L %M - %msg%xEx%n "/>
</File>

<!-- 输出到文件,按天或者超过50MB分割 -->
       <RollingFile name="RollingFile" fileName="../logs/Debug.log"    filePattern="../logs/$${date:yyyy-MM}/Info-%d{yyyy-MM-dd}-%i.log.gz">
<!-- 需要记录的级别 -->
           <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
<PatternLayout pattern="%d{yyyy-MM-dd   HH:mm:ss,SSS}  %-5level %class{36} %L %M - %msg%xEx%n" />
<Policies>
<OnStartupTriggeringPolicy />
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="50 MB" />
</Policies>
<!-- DefaultRolloverStrategy属性默认同一文件夹下最多7个文件 -->
           <DefaultRolloverStrategy max="20"/>
</RollingFile>
</Appenders>

<Loggers>
<root level="debug"> <!-- 全局配置 -->
           <AppenderRef ref="Console" />
<AppenderRef ref="FileInfo"/>
<AppenderRef ref="RollingFile"/>
</root>
<!--过滤掉spring和mybatis的DEBUG信息-->
       <logger name="org.springframework" level="info"></logger>
<logger name="org.mybatis" level="info"></logger>
</Loggers>
</Configuration>

(3)向web项目的web.xml文件中增加如下配置:

<!--设置log4j2的监听器和过滤器(servlet3.0及以上版本不需要)-->
<listener>
<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>
</listener>
<filter>
<filter-name>log4jServletFilter</filter-name>
<filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>log4jServletFilter</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
<dispatcher>ERROR</dispatcher>
</filter-mapping>

<!--配置log4j 2.xml文件路径,默认扫描src/main/resources-->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/*****/log4j2.xml</param-value>
</context-param>

(4)调用日志输出方法

private  static Logger log= LoggerFactory.getLogger(StudentController.class);

这里LoggerFactory方法是import org.slf4j.LoggerFactory接口提供,而不再像单纯使用log4j那样来自org.apache.logging.log4j.Logger;所以,即使具体的日志实现类发生变化,依旧不影响代码中

log.info("-------"+list);

等日志输出方法的调用,实现了日志系统相互迁移和兼容的特点.


二.明日计划

1.整理任务代码,提交任务.

2.整理JSP相关知识点.


三.遇到问题

暂无.


四.收获

以上.



返回列表 返回列表
评论

    分享到