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 <[email protected]>
// +----------------------------------------------------------------------
// | 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 & 放到后台执行即可

发布了31 篇原创文章 · 获赞 8 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/oZuoYu123/article/details/102499934