易截截图软件、单文件、免安装、纯绿色、仅160KB

Java 日志

19.1.1. Spring对log4j的几个增强
注意
个人建议都不要使用。
定时刷新log4j.properties,无须重启服务器更新log4j设置。虽然这是个J2EE Best
Practice,但在Spring的JavaDoc里注明了不推荐用于生产环境,因为服务器重启的时候,那条watch thread不会关闭。

log4j.properties文件放在WEB-INF/log4j.properties。
这种增强看不出有什么好处,而且如果放
WEB-INF,测试的时候就不能输出log4j信息了,除非像Appfuse那样把WEB-INF也设为class
path,不过这种设法只适用于Ant脚本的情况。
通过设定{web.root}这样的系统变量,将log文件放到项目
的WEB-INF目录中
log4j.appender.logfile.File=${oa.root}/WEB-INF/logs/oa.log

这样做的好处是路径比较稳定,但如果是war式的部署,每次重新部署的时候就会把原来的
log文件全部删掉,遇上jboss 这种不解压war包的应用服务器就更会出错,所以把log文件放WEB-INF/logs不是一个好的选择。

实logfile路径的规则是,如果不是绝对路径,就以应用运行的目录作为相对路径的根目录。
可以这样定义,一般就指向tomcat和很多
应用服务器的logs目录:
log4j.appender.logfile.File=../logs/oa.log

19.1.2. 默
认写入操作员ID
比如在一个ServletFilter里实现如下代码
Customer customer = (Customer) session.getAttribute("customer");
MDC.put("userid", customer.getLoginid());

则log4j会线程安全的把cusomer
id写入MDC的userId变量中,而userID变量的使用见下。
19.1.3. 忽略某些类库框架的不必要的信息
控制第三
方框架类库的logging level,可以避免满屏都是不重要的info,把真正重要的信息掩盖了。
# Changing the log level to DEBUG when debug
log4j.logger.org.springframework=WARN
# Changing the log level to DEBUG will display SQL Hibernate generated
log4j.logger.org.hibernate=WARN
log4j.logger.org.hibernate.SQL=ERROR

19.1.4. 把
重要的业务日志异步批量写入数据库
配置文件示例:
log4j.logger.business=INFO,db
log4j.appender.db=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.db.BufferSize=10
log4j.appender.db.URL=jdbc:hsqldb:res:/hsqldb/bookstore
log4j.appender.db.driver=org.hsqldb.jdbcDriver
log4j.append


相关文档:

Java中集合容器类List和Set的用法

List的用法
List包括List接口以及List接口的所有实现类。因为List接口实现了Collection接口,所以List接口拥有Collection接口提供的所有常用方法,又因为List是列表类型,所以List接口还提供了一些适合于自身的常用方法,如表1所示。
表1  List接口定义的常用方法及功能
从表1可以看出,List接口提供的适合于自身的 ......

java:经典文件写入和读取,速度超快

package arrays.file;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamRea ......

java:递归汉罗塔游戏最少的走法

package game;
public class HanTaGame {
 public static void main(String[] args) {
  fun('1', '2', '3', 2);
 }
 // 汉塔游戏解决方案
 public static void fun(char src, char idle, char dest, int n) {
  if (1 == n) {
   System.out.println(src ......

调整 Java I/O 性能

这篇文章讨论和阐明了提供 JavaTM I/O 性能的多种技术。大多技术围绕调整磁盘文件 I/O,但是有些内容也同样适合网络 I/O 和窗口输出。第一部分技术讨论底层的I/O问题,然后讨论诸如压缩,格式化和串行化等高级I/O问题。然而这个讨论没有包含应用设计问题,例如搜索算法和数据结构,也没有讨论系统级的问题,例如文件高速缓冲 ......

Java串口编程3

    终于完成了串口的编写,功能很简单,如下:
    做出一个简单界面,向串口发送特定的命令(串口上接有供测试用的串口设备),接收设备返回的数据在界面上显示:
import gnu.io.CommPortIdentifier;
import gnu.io.PortInUseException;
import gnu.io.SerialPort;
import gnu.io.Ser ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号