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 & 放到後臺執行即可

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章