当前位置: 首页 > 工具软件 > SeasLog > 使用案例 >

php 日志本,seaslog 日志

胡泓
2023-12-01

>[info]高性能的php日志系统 --seaslog,学习使用之前我们首先要搞明白,日志能给我们解决什么问题

- 自己搭建web日志系统,可以看项目中是咋弄的

- 什么是日志系统??

1、记录系统运行时的信息

2、记录日志、应用程序、安全日志

3、日志功能不应该影响到用户的正常使用

- 为什么需要日志系统??

1、了解系统运行情况

2、记录用户操作信息

3、收集数据(如 500错误,出现了多少次)

- 为什么选择seaslog??

1、高性能(C语言写的)

2、无需配置(先写闪存,达到一定量才写到文件里)

3、功能完善使用简单

- 实际项目中使用seaslog的场景??

1、记录有人来了

2、记录用户看没看到,看到后记录看到哪些

...

[toc]

## :-: **Win安装**

>[info] 下载扩展地址:https://pecl.php.net/package/SeasLog/1.6.9/windows

- 根据PHP版本 是否线程安全 进行选择 这些都可以在phpinfo里查得到

- 下载之后 把里面的php_seaslog.dll拷贝到PHP的安装目录下的ext里

- 然后打开php.ini进行配置

extension=php_seaslog.dll

## :-: **linux的安装**

>[warning]他是php的一个扩展,不是普通类库

>[info]http://pecl.php.net/ 安装php扩展来这个网站找包,或直接访问:https://pecl.php.net/package/seaslog

![](https://box.kancloud.cn/8d4e6c1a12382410df5b117772b0095a_1031x123.png)

![](https://box.kancloud.cn/0242b612aef8614e89cdbc32d49fa441_619x71.png)

1、解压,切换进去

2、输入phpize

3、./configure --with-php-config=/www/server/php/54/bin/php-config (你php-config所在的绝对路径)

4、make && make install

![](https://box.kancloud.cn/709ef89e77a00b4513fc70855e21b5b7_622x62.png)

5、修改php.ini,最后一行加入extension=seaslog.so

![](https://box.kancloud.cn/0870075bb6003503fa9c6d318a3bed60_575x196.png)

>[warning]打印phpinfo()在浏览器查看是安装成功了,但是在linux上执行php -m 没有,我暂时也不知道是为什么,希望知道的大佬给我留言补充下

6、配置 seaslog

~~~

配置详解:http://php.net/manual/en/seaslog.configuration.php

seaslog.default_basepath = /home/wwwlogs/seaslog #默认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.trace_error = 1

seaslog.trace_exception = 0

seaslog.default_datetime_format = "Y:m:d H:i:s

~~~

第二条配置seaslog.default_logger我选择在项目的入口文件中再指定Seaslog::setLogger('...')

这样就可以每个项目一个日志目录了

7、SeasLog 日志8个级别

debug -> info -> notice -> warning -> error -> critical -> alert -> emergency

## :-: **常用方法**

![](https://box.kancloud.cn/9d448c800b69bb53c1828baa55efc9b6_502x134.png)

- 这些方法都是静态方法,可以直接调用。测试时拿浏览器访问,或php -f 要执行的php文件

``` php

basepath:存日志的路径

设置:Seaslog::setBasePath('/log/base_test');

获取:Seaslog::getBasePath();

```

``` php

logger:同模块存到不同路径下

设置:Seaslog::setLogger('app');

获取:Seaslog::getLastLogger();

SeasLog::setLogger('ms/normaltest'); //示例

```

``` php

写日志:

Seaslog::debug('...')

Seaslog::info('...')

SeasLog::info('计费接口结果:' . json_encode($bossResult,JSON_UNESCAPED_UNICODE));

```

``` php

Seaslog::notice('...')

八个级别都可以记录

日志内容格式为:级别-pid-时间戳-格式化时间-日志内容

```

``` php

读取日志条数

Seaslog::analyzerCount('{日志级别}');//如果不填参数 则代表统计全部级别

Seaslog::analyzerCount('{日志级别}','20170914');指定统计某一天的日志

```

``` php

读取日志

Seaslog::analyzerDetail('{日志级别}','20170914');//也有两个参数 日志级别和指定时间 第一个日志级别参数必填 时间可选

```

``` php

输出info级别的日志:

echo "

";

print_r(Seaslog::analyzerDetail('info'));

echo "

";

analyzerCount:日志统计

```

## :-: **在框架中使用**

- 某些PHP框架默认为当前控制器命名空间 所以会报Seaslog not found

只需在前面指定根命名空间就OK: \Seaslog::debug('...')

- 第1种:安装php扩展(win装win的,linux装linux的),直接调函数

- 第2种:将该类库从github上,使用composer或其他手法加载到框架中

然后就和使用普通类库一样

思路1、在控制器 直接调用

思路2、改log的配置文件

![](https://box.kancloud.cn/06ad98daa0b9be66f1e1aeb274d17844_497x100.png)

然后自己封装(和思路1一样,也是在控制器或模型的方法中直接调用)

![](https://box.kancloud.cn/03469f9b779ba8ed06772a013fc84000_764x284.png)

 类似资料: