Windows部分: --------------------------------------------------------
https://pecl.php.net/package/SeasLog/1.6.9/windows
根据PHP版本 是否线程安全 进行选择 这些都可以在phpinfo里查得到
下载之后 把里面的php_seaslog.dll拷贝到PHP的安装目录下的ext里
然后打开php.ini进行配置
extension=php_seaslog.dll
Linux部分: ------------------------------------------------------------ 下载地址 https://pecl.php.net/package/seaslog
将包用ftp传到Linux上 然后移走 mv SeasLog-1.6.9.tgz /usr/local/SeasLog.tgz
进入目录解压 cd /usr/local tar -zxvf SeasLog.tgz
执行PHP安装目录下的phpize /usr/local/php7/bin/phpize
搜索php-config路径 find /usr/local/php7/ -name php-config 得到/usr/local/php7/bin/php-config
配置 ./configure --with-php-config=/usr/local/php7/bin/php-config
编译 make
安装 make install
出现Installing shared extensions: /usr/local/php7/lib/php/extensions/no-debug-non-zts-20160303/ 则成功
打开php.ini进行配置 找到一排extension的地方 加上extension=seaslog.so
公共部分: --------------------------------------------------------------- 在php.ini中 extension下面接着配置以下信息:
seaslog.default_basepath = 'D:/WWW/log' ;默认log根目录 记着 是目录 seaslog.default_logger = default ;默认日志目录 位于default_basepath目录下的小目录 seaslog.disting_type = 1 ;是否以type分文件 1是 0否(默认) 若是 则每种级别都会单独生成日志文件 seaslog.disting_by_hour = 0 ;是否每小时划分一个文件 1是 0否(默认) 若是 则每个小时都会生成新文件 seaslog.use_buffer = 1 ;是否启用buffer 1是 0否(默认) 默认关闭,当开启此项时,日志预存于内存,当请求结束时(或异常退出时)一次写入文件。 seaslog.buffer_size = 100 ;buffer中缓冲数量 默认0(不使用) seaslog.level = 0 ;记录日志级别 默认0(所有日志)
第二条配置seaslog.default_logger我选择在项目的入口文件中再指定Seaslog::setLogger('...') 这样就可以每个项目一个日志目录了
SeasLog 日志8个级别 debug -> info -> notice -> warning -> error -> critical -> alert -> emergency
保存退出 重启Apache 打个phpinfo()出来找找有没有SeasLog扩展
以下是PHP中的seaslog函数:
basepath 设置:Seaslog::setBasePath('/log/base_test'); 获取:Seaslog::getBasePath();
logger 设置:Seaslog::setLogger('app'); 获取:Seaslog::getLastLogger();
写日志: Seaslog::debug('...') Seaslog::info('...') Seaslog::notice('...') 八个级别都可以记录
日志内容格式为:级别-pid-时间戳-格式化时间-日志内容
读取日志条数 Seaslog::analyzerCount('{日志级别}');//如果不填参数 则代表统计全部级别 Seaslog::analyzerCount('{日志级别}','20170914');指定统计某一天的日志
读取日志 Seaslog::analyzerDetail('{日志级别}','20170914');//也有两个参数 日志级别和指定时间 第一个日志级别参数必填 时间可选
输出info级别的日志: echo "<pre>"; print_r(Seaslog::analyzerDetail('info')); echo "</pre>";
某些PHP框架默认为当前控制器命名空间 所以会报Seaslog not found 只需在前面指定根命名空间就OK: \Seaslog::debug('...')
|
请发表评论