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 配置和使用的更多相关文章

  1. log4php的配置

    网上关于log4php配置的文章很多,下面是我的配置,跟网上部分略有不同 (1)添加日志     1.下载log4php,到官网就可以下载到,下载后解压     我的版本是log4php_2.3.0 ...

  2. log4php的使用方法与详细配置

    log4php的使用 首先引入logger.php文件.log4php可以通过引入logger.php来完成自动加载的过程.文件位置如下: 日志记录器自身没有定义日志的输出目的地和格式,所以我们通常需 ...

  3. log4php使用及配置

    log4php使用及配置 1.在项目中加入log4php包 2.log4php配置 在项目配置包中添加logger_config.xml配置文件: logger_config.xml配置文件添加代码如 ...

  4. PHP日志 LOG4PHP 的配置与使用

    维护了 一个老项目, 没有日志功能, 就给加了这个log4php,  主要是集成进去很简单,使用起来也够用了. 1.下载log4php 2.创建配置文件 log4php_config.xml < ...

  5. Log4PHP日志库使用

    库下载地址: http://logging.apache.org/log4php/download.html 当前测试使用的版本为2.3.0 1.解压缩下载的压缩文件apache-log4php-2. ...

  6. 配置android sdk 环境

    1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/

  7. Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记

    以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...

  8. react-router 组件式配置与对象式配置小区别

    1. react-router 对象式配置 和 组件式配置    组件式配置(Redirect) ----对应---- 对象式配置(onEnter钩子) IndexRedirect -----对应-- ...

  9. 总结:Mac前端开发环境的搭建(配置)

    新年新气象,在2016年的第一天,我入手了人生中第一台自己的电脑(大一时好友赠送的电脑在一次无意中烧坏了主板,此后便不断借用别人的或者网站的).macbook air,身上已无分文...接下来半年的房 ...

随机推荐

  1. 蓝桥杯-猜字母-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  2. Java基础之equals方法和"= ="的区别

    ==操作符专门用来比较两个变量的值是否相等,也就是用于比较变量所对应的内存中所存储的数值是否相同,要比较两个基本类型的数据或两个引用变量是否相等,只能用==操作符. 如果一个变量指向的数据是对象类型的 ...

  3. cd命令使用详解

    cd命令是目录切换命令,是shell内置命令. 语法: cd [-L|-P] [dir] 选项: -p 如果要切换到的目标目录是一个符号连接,直接切换到符号连接指向的目标目录 -L 如果要切换的目标目 ...

  4. 如何将网站升级为HTTPS协议?

    基本概念: HTTP: 是互联网上应用最为广泛的一种网络协议,是一个客户端和服务器端请求和应答的标准,用于从WWW服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少. HT ...

  5. 初次使用git配置以及git如何使用ssh密钥(将ssh密钥添加到github)

    初次安装git配置用户名和邮箱 初次安装git需要配置用户名和邮箱,否则git会提示:please tell me who you are. 你需要运行命令来配置你的用户名和邮箱: $ git con ...

  6. Commonjs规范及Node模块实现

    前面的话 Node在实现中并非完全按照CommonJS规范实现,而是对模块规范进行了一定的取舍,同时也增加了少许自身需要的特性.本文将详细介绍NodeJS的模块实现 引入 nodejs是区别于java ...

  7. Java Stack源码分析

    Stack简介 Stack是栈.它的特性是:先进后出(FILO, First In Last Out).java工具包中的Stack是继承于Vector(矢量队列)的,由于Vector是通过数组实现的 ...

  8. maven学习2,安装插件

    eclipse 安装插件的方式最常见的有两种: 1. 一种是在线安装,这貌似是用的最多的,就是:Help  -->  Install New Software,然后输入 HTTP 地址来安装,但 ...

  9. 如何用C#完成控制台日历?

    本题目的最终要就是根据用户输入的年和月在控制台输出单月的日历信息,附加范围年在1900-2100之间,月的范围在1-12之间,当用户输入不在范围时要给予错误信息提示:已知条件是1900年1月1日为星期 ...

  10. win10下使用nodejs安装及webstorm创建express项目的指导

    title: win10下使用nodejs安装 win10下使用nodejs安装及webstorm创建express项目的指导 windows下nvm的安装 熟悉linux下nodejs开发的朋友应该 ...