log4php的使用方法与详细配置
log4php的使用
首先引入logger.php文件。log4php可以通过引入logger.php来完成自动加载的过程。文件位置如下:
日志记录器自身没有定义日志的输出目的地和格式,所以我们通常需要引入log4php后要先引入配置文件(下面会详细介绍)。日志记录器是一个组件,我们通过日志记录器来记录日志信息。引入配置文件后通过getLogger获得一个将日志记录器实体。然后可以通过打印方法打印出日志信息。打印方法通常包括info、warn、error、debug等。
include('Logger.php');
Logger::Configure(COMMON_PATH . 'Conf/log.php');//引入配置文件
$logger = Logger::getLogger("main"); //生成日志实例
$logger->info("This is an informational message."); //在规定好的输出目的地用规定好的输出格式显示信息消息
log4php配置
log4php配置文件支持 XML、PHP、Properties (INI)等格式。同样支持可编程配置,即通过函数来改变配置。
class MyConfigurator implements LoggerConfigurator {
public function configure(LoggerHierarchy $hierarchy, $input = null) {
// Create an appender which logs to file
$appFile = new LoggerAppenderFile('foo');
$appFile->setFile('D:/Temp/log.txt');
$appFile->setAppend(true);
$appFile->setThreshold('all');
$appFile->activateOptions();
// Use a different layout for the next appender
$layout = new LoggerLayoutPattern();
$layout->setConversionPattern("%date %logger %msg%newline");
$layout->activateOptions();
// Create an appender which echoes log events, using a custom layout
// and with the threshold set to INFO
$appEcho = new LoggerAppenderEcho('bar');
$appEcho->setLayout($layout);
$appEcho->setThreshold('info');
$appEcho->activateOptions();
// Add both appenders to the root logger
$root = $hierarchy->getRootLogger();
$root->addAppender($appFile);
$root->addAppender($appEcho);
}
}
log4php 官方文档:http://logging.apache.org/log4php/
Logger::Configure(COMMON_PATH . 'Conf/log.php');
项目中由这行代码引入配置。配置中一般包含以下内容:
1.日志信息的优先级;2.日志信息的输出目的地; 3.日志信息的输出格式。
一.log4php 日志信息优先级
日志信息的优先级从高到低有ERROR、WARN、INFO、DEBUG。
以下是常用四种等级的用法:
DEBUG Level指出细粒度信息事件对调试应用程序是非常有帮助的。
INFO level表明 消息在粗粒度级别上突出强调应用程序的运行过程。
WARN level表明会出现潜在错误的情形。
ERROR level指出虽然发生错误事件,但仍然不影响系统的继续运行。
程序只能显示比当前设置的等级优先级级更低的信息。例如当前程序设置level为DEBUG,那么就是说程序中所有信息都能显示出来。如果当前程序level为info,那么只有info,warn,error三中日志信息可以展示。
return array(
'rootLogger' => array(
'appenders' => array(
'myConsoleAppender',
),
'level' => 'DEBUG'
),
)
二.输出地址配置
和优先级一样,输出地址同样可以在配置文件中作出配置,并且可以根据不同的日志类别设置不同的输出目的地。例:
'loginFileAppender' => [
'class' => 'LoggerAppenderDailyFile',
'layout' => [
'class' => 'LoggerLayoutPattern',
'params' => [
'conversionPattern' => '%date [%logger] %message%newline',
],
],
'params' => [
'file' => './log/login/login_%s.log',
'datePattern' => 'Y_m_d',
]
],
log4php支持12种输出目的地,分别为:
- LoggerAppenderConsole 以php://stdout为输出目的地
- LoggerAppenderFile 以文件为输出目的地
- LoggerAppenderDailyFile 以文件为目的地,每日输出一个文件
- LoggerAppenderDb 以数据库为输出目的地
- LoggerAppenderEcho 在执行文件尾输出
- LoggerAppenderMail 以邮件为输出地
- LoggerAppenderMailEvent 以邮件为输出地, 为事件触发
- LoggerAppenderNull 不输出任何信息
- LoggerAppenderPhp LoggerAppenderPhp 输出至PHP错误信息,将各类日志等级信息转化为php标准信息
- LoggerAppenderRollingFile 以xxx.log.1, xxx.log.2的形式输出
- LoggerAppenderSocket 以socket方式输出
- LoggerAppenderSyslog 以系统日志为目的地输出,使用php中的syslog()函数进行记录
代码中便是规定了以每日输出一个文件作为输出目的地,用来记录登录类型的日志信息。
三.日志文件输出格式
它作为输出目的地的一个属性存在,log4php上包含5种不同的输出方式,分别为:
- LoggerLayoutHtml 以html格式输出调试信息
- LoggerLayoutSimple 简单的以 "等级信息 - 日志信息"的格式显示
- LoggerLayoutTTCC 以"月/日/年 时间[进程] 等级信息 日志名称 - 调试信息"的格式来显示
- LoggerLayoutPattern 以模式表达式作为输出格式来显示(这个模式可以自定义输出格式)
- LoggerXmlLayout//以xml的模式来输出
LoggerLayoutPattern 模式的一些格式参数
LoggerLayoutPattern为我们提供了自定义日志信息格式的方法,项目中也常常使用该模式来自定义日志信息。在实际使用中,我们通过配置conversionPattern参数来定义模式。而参数变量中通常使用一些log4php提供的转换说明符来配置。
例如:
'conversionPattern' => '%date [%logger] %message%newline'
格式为: yyyy-mm-ddThh:mm:ss+08:00.[日志类型].日志内容.换行。
常用的转换说明符有:
- %logger(%lo,%c)请求日志的日志记录器的名称。
- %data($d)时间。默认为ISO8601格式。可以通过%data{(格式)}改变格式。
- %location(%l)调用者的位置信息
- %message(%m %msg)日志的内容
- %n(%newline)换行
- %level(%p)当前日志事件的优先级
关于转换说明符的完整说明:http://logging.apache.org/log4php/docs/layouts/pattern.html
log4php的使用方法与详细配置的更多相关文章
- PL/SQL Developer 连接Oracle数据库详细配置方法
PL/SQL Developer 连接Oracle数据库详细配置方法 近段时间很多网友提出监听配置相关问题,客户终端(Client)无法连接服务器端(Server).本文现对监听配置作一简单介绍,给出 ...
- 百度在线编辑器UEditor(v1.3.6) .net环境下详细配置教程之更改图片和附件上传路径
本文是接上一篇博客,如果有疑问请先阅读上一篇:百度在线编辑器UEditor(v1.3.6) .net环境下详细配置教程 默认UEditor上传图片的路径是,编辑器包目录里面的net目录下 下面就演示如 ...
- apache 虚拟主机详细配置:http.conf配置详解
apache 虚拟主机详细配置:http.conf配置详解 Apache的配置文件http.conf参数含义详解 Apache的配置由httpd.conf文件配置,因此下面的配置指令都是在httpd. ...
- HighCharts学习笔记(二)HighCharts结构及详细配置
HighCharts结构及详细配置: 一.HighCharts整体结构: 通过查看API文档我们知道HighCharts结构如下:(API文档在文章后面提供下载) var chart = new Hi ...
- proxool详细配置
proxool详细配置 博客分类: Java 配置管理SQLServletprototypeXML proxool一个数据库连接池框架,提供了对你选择的其它类型的驱动程序的连接池封装.可以非常简单的 ...
- Window VNC远程控制LINUX:VNC详细配置介绍
Window VNC远程控制LINUX:VNC详细配置介绍 //---------------------------------------vnc linux下的详细配置 1.VNC的启动/停止/重 ...
- c3p0详细配置
c3p0详细配置 官方文档 : http://www.mchange.com/projects/c3p0/index.html <c3p0-config> <default-conf ...
- squid透明代理+iptables防火墙,多网卡详细配置
squid透明代理+iptables防火墙详细配置 看到很多人都在不停地问iptables+squid做透明代理的问题,鄙人不才,斗胆在此做统一解答.如有任何纰漏还望各位批评指教. ========= ...
- CentOS+Nginx+PHP+MySQL详细配置(图解)
原文地址: http://www.jb51.net/article/26597.htm CentOS+Nginx+PHP+MySQL详细配置(带有图解),需要的朋友可以参考下. 一.安装MySQL ...
随机推荐
- css理论
1css语法 2css的四种引入方式 3css选择器 4css四种属性操作 5float属性操作 6盒子模型 1 css语法 CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明. '' se ...
- Linux基础第六课——grep|awk|sort|uniq
管道符 | 前面的输出作为后面的输入 grep 可以理解为正则表达式 grep [参数] 文件名 -c 打印符合要求的行数 -v 打印不符合要求的行 -n 在输出符合要求的行的同时连同行号一起输出 - ...
- ActivityThread
/** * This manages the execution of the main thread in an * application process, scheduling and exec ...
- Java SE和Java EE应用的性能调优
凡事预则立,不预则废,和很多事情一样.Java性能调优的成功.离不开行动计划.方法或策略以及特定的领域背景知识.为了在Java性能调优工作中有所成就.你得超越"花似雾中看"的状态, ...
- spring.factories
在Spring Boot中有一种非常解耦的扩展机制:Spring Factories.这种扩展机制实际上是仿照Java中的SPI扩展机制来实现的. Java SPI机制SPI的全名为Service P ...
- Git提交新项目
Github或者码云上新建项目 $ git init $ git add * $ git remote add origin https://gitee.com/demo/demo.git $ git ...
- Idea设置快捷键以及修改Eclipse的debug快捷键
Idea强大不多说了,用久了都可以习惯,但是感觉Idea的debug真是不如eclipse好用,Idea的快捷键都是组合键,用着繁琐.两种方法可以设置eclipse的快捷键: 1:直接全局都使用ecl ...
- 字典树模板题(统计难题 HDU - 1251)
https://vjudge.net/problem/HDU-1251 标准的字典树模板题: 也注意一下输入方法: #include<iostream> #include<cstdi ...
- php api 接口
<?php //简单形式 header('Content-Type:text/html;charset=utf-8'); //避免输出乱码 $output = array(); $a = @$_ ...
- QT 14 线程使用
1 线程基础 QThread 是对本地平台线程的一个非常好的跨平台抽象.启动一个线程非常简单.让我们看一段代码,它产生另一个线程,该线程打印hello,然后退出. // hellothread/hel ...