thinkphp5下redis记录日志

behavior\Log.php  在tag.php里配置

'app_init'     => [
    'app\\index\\behavior\\Log',
],
<?php
namespace app\index\behavior;

use think\Request;
// 初始化钩子信息
class Log
{
    // 行为扩展的执行入口必须是run
    public function run(Request $request = null)
    {
        // 获取信息
        $m['module'] = $_SERVER['DOCUMENT_URI'];
        $m['c_id'] = $request->param('c_id', 0);
        $m['func_name'] = $request->param('func_name', '');
        $m['IP'] =  $_SERVER["REMOTE_ADDR"];
        $m['agent'] = $_SERVER['HTTP_USER_AGENT'];
        $m['body'] = serialize(input('param.'));
        $m['time'] = date('Y-m-d H:i:s', time());
        // 加入 redis 队列
        $redis = new \Redis();
        $redis -> connect('127.0.0.1', 6379);
        // 完毕
        $redis -> rPush('api_shell_log', serialize($m));

    }
}

log_daemon.php 守护进程

<?php
// +----------------------------------------------------------------------
// | Author: Liu Xiaoyu <ytliuxiaoyu@foxmail.com>
// +----------------------------------------------------------------------
// | Date: 2019/10/11 11:13
// +----------------------------------------------------------------------
$redis = new \Redis();
$redis -> connect('127.0.0.1', 6379);
while (true) {
    try {
        $value = $redis -> lPop('api_shell_log');
        if (!$value) {
            sleep(5);
            continue;
        }
        $m = unserialize($value);
        $content = <<<EOL

module: {$m['module']}    c_id: {$m['c_id']}    time: {$m['time']}
func_name: {$m['func_name']}
IP: {$m['IP']}
agent: {$m['agent']}
body: {$m['body']}
===================================================
EOL;
        file_put_contents('log-'.date('Y-m-d',time()).'.txt', $content,FILE_APPEND);
//        var_dump($value);
    } catch (Exception $e) {
        echo $e -> getMessage();
    }
}



记得要给权限, 然后 php log_daemen.php & 放到后台执行即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值