Log4PHP 配置和使用
Log4PHP2.3.0使用解释
1. 什么是Log4PHP
Log4php它为apche组织维护项目,是Log4xx系列日志组件之一,log4j在JAVA中可算是大名鼎鼎的日志开发包。Log4PHP也作为一个单独的子项目存在,可以很方便的加载使用。
apache官方网站:http://logging.apache.org/log4php/
另外一个LOG4PHP的主站:http://www.vxr.it/log4php/
2. Log4PHP目录结构
从apache官网下载之后,解压得到的文件夹目录如下:

对于需要的LOG4PHP的主要核心代码在src/main/php下面,

3. Log4PHP的简单使用
3.1 建立Log4PHP的XML配置文件
<?xml version="1.0" encoding="UTF-8"?>
<configuration xmlns="http://logging.apache.org/log4php/">
<!-- 标准控制台输出的appender -->
<appender name="STDOUT" class="LoggerAppenderConsole">
<param name="threshold" value="debug"/>
<layout class="LoggerLayoutPattern" >
<param name="ConversionPattern" value="[%date{Y-m-d H:i:s,u}] [%t] %-5p %l - %message%newline%ex"/>
</layout>
</appender>
<!-- 记录所有ERROR日志的appender -->
<appender name="ERROR-ALL" class="LoggerAppenderDailyFile">
<layout class="LoggerLayoutPattern" >
<param name="ConversionPattern" value="[%date{Y-m-d H:i:s,u}] [%t] %-5p %l - %message%newline%ex"/>
</layout>
<param name="file" value="log/php-error.log.%s" />
<param name="threshold" value="error"/>
<param name="append" value="true" />
<param name="datePattern" value="Y-m-d" />
</appender>
<!-- 记录所有DEBUG日志的appender -->
<appender name="DEBUG-ALL" class="LoggerAppenderDailyFile">
<layout class="LoggerLayoutPattern" >
<param name="ConversionPattern" value="[%date{Y-m-d H:i:s,u}] [%t] %-5p %l - %message%newline%ex"/>
</layout>
<param name="file" value="log/php-debug.log.%s" />
<param name="threshold" value="debug"/>
<param name="append" value="true" />
<param name="datePattern" value="Y-m-d" />
</appender>
<!-- 记录所有INFO日志的appender -->
<appender name="INFO-ALL" class="LoggerAppenderDailyFile">
<layout class="LoggerLayoutPattern" >
<param name="ConversionPattern" value="[%date{Y-m-d H:i:s,u}] [%t] %-5p %l - %message%newline%ex"/>
</layout>
<param name="file" value="log/php-info.log.%s" />
<param name="threshold" value="info"/>
<param name="append" value="true" />
<param name="datePattern" value="Y-m-d" />
</appender>
<root>
<level value="warn"/>
<appender-ref ref="STDOUT"/>
<appender-ref ref="DEBUG-ALL"/>
<appender-ref ref="INFO-ALL"/>
<appender-ref ref="ERROR-ALL"/>
</root>
</configuration>
3.2 简单PHP测试
<?php
require_once('log4php/Logger.php');
Logger::configure('log4php.xml');
$pay = Logger::getRootLogger();
$pay->info('测试LOG4PHP');
//$pay->warn("测试LOG4PHP");
//$pay->debug("测试LOG4PHP");
//$pay->error("测试LOG4PHP");
//$pay->fatal("测试LOG4PHP");
?>
运行PHP文件即可,即:
info 、debug 不会产生文件
warn 生成两个文件:php-debug.log*** php-info.log***
errror fatal会产生三个文件:php-debug.log*** php-error.log*** php-info.log***
4. Log4PHP的配置文件解释
4.1 优先级
由低到高: debug、 info、warn、 error、 fatal, 日志的输出和你的等级设置相关,比如上面的配置文件,root 下的 level = debug 那么所有的等级都会出现日志,但是日志文件的数量是不等的
4.2 日志输出的目的地
(有很多种,数据库、文件等等)
LoggerAppenderConsole //以php://stdout为输出地 LoggerAppenderDailyFile //继承自LoggerAppenderFile, 以文件为输出地,每日输出一个文件 LoggerAppenderDb //以数据库为输出地 LoggerAppenderEcho //在执行文件尾输出 LoggerAppenderFile //以文件为输出地 LoggerAppenderMail //以邮件为输出地 LoggerAppenderMailEvent //继承自LoggerAppenderMail, 以邮件为输出地, 为事件触发 LoggerAppenderNull //不输出任何信息 LoggerAppenderPhp //输出至PHP错误信息,将各类日志等级信息转化为php标准信息 LoggerAppenderRollingFile //继承自LoggerAppenderFile,以xxx.log.1, xxx.log.2的形式输出, LoggerAppenderSocket //以socket方式输出 LoggerAppenderSyslog //以系统日志为目的地输出,使用php中的syslog()函数进行记录
4.3 输出的格式
日志输出的格式,LOG4PHP有5种输出方式
LoggerLayoutHtml//以html格式输出调试信息 LoggerLayoutSimple//简单的以 "等级信息 - 日志信息"的格式显示 LoggerLayoutTTCC//以"月/日/年 时间[进程] 等级信息 日志名称 - 调试信息"的格式来显示 LoggerPatternLayout//以模式表达式作为输出格式来显示(这个功能极为强悍,你可以随心所欲的来设置输出格式,在实例部分详细讲解) LoggerXmlLayout//以xml的模式来输出
这样就可以通过建立多个配置文件,采用灵活管理日志目录,为每一个产品模块采用不同的配置。
Log4PHP 配置和使用的更多相关文章
- log4php的配置
网上关于log4php配置的文章很多,下面是我的配置,跟网上部分略有不同 (1)添加日志 1.下载log4php,到官网就可以下载到,下载后解压 我的版本是log4php_2.3.0 ...
- log4php的使用方法与详细配置
log4php的使用 首先引入logger.php文件.log4php可以通过引入logger.php来完成自动加载的过程.文件位置如下: 日志记录器自身没有定义日志的输出目的地和格式,所以我们通常需 ...
- log4php使用及配置
log4php使用及配置 1.在项目中加入log4php包 2.log4php配置 在项目配置包中添加logger_config.xml配置文件: logger_config.xml配置文件添加代码如 ...
- PHP日志 LOG4PHP 的配置与使用
维护了 一个老项目, 没有日志功能, 就给加了这个log4php, 主要是集成进去很简单,使用起来也够用了. 1.下载log4php 2.创建配置文件 log4php_config.xml < ...
- Log4PHP日志库使用
库下载地址: http://logging.apache.org/log4php/download.html 当前测试使用的版本为2.3.0 1.解压缩下载的压缩文件apache-log4php-2. ...
- 配置android sdk 环境
1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/
- Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记
以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...
- react-router 组件式配置与对象式配置小区别
1. react-router 对象式配置 和 组件式配置 组件式配置(Redirect) ----对应---- 对象式配置(onEnter钩子) IndexRedirect -----对应-- ...
- 总结:Mac前端开发环境的搭建(配置)
新年新气象,在2016年的第一天,我入手了人生中第一台自己的电脑(大一时好友赠送的电脑在一次无意中烧坏了主板,此后便不断借用别人的或者网站的).macbook air,身上已无分文...接下来半年的房 ...
随机推荐
- 蓝桥杯-第39级台阶-java
/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...
- 用Redis存储Tomcat集群的Session
作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 前段时间,我花了不少时间来寻求一种方法,把新开发的代码推送到到生产系统中部署,生产系统要能够零宕机.对使用 ...
- 产品经理学Python:条件控制
条件控制其实就是if...else...(如果...条件是成立的,就做...:反之,就做...)的使用,其基本结构是: 具体看下面这个例子: def account_login(): # 定义函数 p ...
- OC中@class的使用
作用: 可以简单地引用一个类简单使用@class Dog; //类的引入 #import "Dog.h"仅仅是告诉编译器:Dog是一个类;并不会包含Dog这个类的所有内容 具体使用 ...
- Python实现脚本锁功能,同时只能执行一个脚本
1. 文件锁 脚本启动前检查特定文件是否存在,不存在就启动并新建文件,脚本结束后删掉特定文件. 通过文件的判断来确定脚本是否正在执行. 方法实现也比较简单,这里以python脚本为例 #coding= ...
- jQuery中的选择器(下)
这一篇主要写过滤选择器和表单选择器 在这里,我不再已表格形式说明(自己太懒了),主要以文字形式说明一下每个选择器的作用描述. 3.过滤选择器 过滤选择器主要是通过特定的过滤规则筛选出所需的DOM元素 ...
- 移动Web开发小结
以下是做移动端Web开发过程中小结的几个事项:希望能够帮助到大家,同时也方便自己查看: 1,在移动开发页面中,主体盒子的max-width与min-width的设置原因: ①设置max-width是为 ...
- Hibernate map enum type
1. Bean @Entity @Table(name = "entities") public class Entities { public enum entityType { ...
- (中级篇 NettyNIO编解码开发)第六章-编解码技术
基于Java提供的对象输入/输出流ObjectlnputStream和ObjectOutputStream,可以直接把Java对象作为可存储的字节数组写入文件,也可以传输到网络上.对程序员来说,基于J ...
- 初入计算机图形学(二):对bidirectional path tracing的一些困惑
本人水平有限,若有错误也请指正~ 前文提及了光线追踪的一些常用手法,但是其中path tracing的实现最为简单,但是其最致命的一个缺点就是图像收敛速度很慢..原因在于从摄影机发射出的每一条光线若不 ...