简单的swoole 日志类

栏目: PHP · 发布时间: 6年前

内容简介:今天 针对公司自己框架 简单写个日志类 主要使用分隔符是为了写入 worker ID 及 worker PID 及 唯一标识

今天 针对公司自己框架 简单写个日志类 主要使用 __callStatic 静态魔术方法 Swoole 脚本中调用该日志.

<?php

use Config\Log;

/**
 * Created by PhpStorm.
 * User: Len
 * Date: 2018/12/13
 * Time: 13:05
 * Desc:
 */
class Loger
{
    const SPLIT_CHAR = '--';

    private static $unique_log_id = '-';


    /**
     * @return string
     */
    public static function getUniqueLogId(): string
    {
        return self::$unique_log_id;
    }

    /**
     * @param string $unique_log_id
     */
    public static function setUniqueLogId(string $unique_log_id): void
    {
        self::$unique_log_id = $unique_log_id;
    }

    /**
     * @desc 魔术方法静态方法不存在下调用
     * @param $name
     * @param $arguments
     * ------------------------------------------------------------
     */
    public static function __callStatic($name, $arguments)
    {
        // TODO: Implement __call() method.
        self::wlog($arguments, $name);
    }

    /**
     * @desc work进程内日志 仅限work 进程内使用
     * @author len
     * @param $msg
     * @param string $name
     *------------------------------------------------------
     */
    public static function wlog($msg, $name = Log::MATCH)
    {
        $str = '';
        if (is_array($msg)) {
            foreach ($msg as $key => $val) {
                if (is_array($val))
                    $val = json_encode($val);
                $str .= " {$key} {$val}";
            }
        } else {
            $str .= $msg;
        }

        $worker_id = APP::getWorkerId();
        if (is_null($worker_id)) {
            $worker_id = 'task';
        }
        $date = date('Y/m/d H:i:s');
        $no = date('Ymd');
        $file_name = LOG_PATH . DS . $name . '_' . $worker_id . '_' . $no . '.log';
        $data = $date . self::SPLIT_CHAR;

        // 当前日志唯一标识
        $data .= APP::getUniqueLogId() . self::SPLIT_CHAR;

        // 当前worker 进程PID
        $data .= APP::getWorkerPid() . self::SPLIT_CHAR;

        $data .= $worker_id . self::SPLIT_CHAR . $str . " \n";

        file_put_contents($file_name, $data, FILE_APPEND);
    }

    /**
     * @param $msg
     * @param string $name
     * ------------------------------------------------------------
     */
    public static function log($msg, $name = Log::DEBUG)
    {
        $str = '';
        if (is_array($msg)) {
            foreach ($msg as $key => $val) {
                if (is_array($val))
                    $val = json_encode($val);
                $str .= " {$key} {$val}";
            }
        } else {
            $str .= $msg;
        }

        $date = date('Y/m/d H:i:s');
        $no = date('Ymd');
        $file_name = LOG_PATH . DS . $name . '_' . $no . '.log';
        $data = $date . self::SPLIT_CHAR;

        $worker_id = APP::getWorkerId();
        if (is_null($worker_id)) {
            $worker_id = 'task';
        }

        // 获取唯一标识
        $data .= APP::getUniqueLogId() . self::SPLIT_CHAR;

        // 当前worker 进程PID
        $data .= APP::getWorkerPid() . self::SPLIT_CHAR;

        $data .= $worker_id . self::SPLIT_CHAR . $str . " \n";

        file_put_contents($file_name, $data, FILE_APPEND);
    }
}

分隔符是为了 logtail 查看日志

写入 worker ID 及 worker PID 及 唯一标识

通过静态方法实现动态创建日志名称的效果.

性能如何暂不考虑, 能输出日志即可, 不喜勿喷.

最后更新于 2018-12-13 05:22:20 并被添加「」标签,已有 1 位童鞋阅读过。


以上所述就是小编给大家介绍的《简单的swoole 日志类》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

深入理解计算机系统(原书第2版)

深入理解计算机系统(原书第2版)

(美)Randal E.Bryant、David O'Hallaron / 龚奕利、雷迎春 / 机械工业出版社 / 2011-1-1 / 99.00元

本书从程序员的视角详细阐述计算机系统的本质概念,并展示这些概念如何实实在在地影响应用程序的正确性、性能和实用性。全书共12章,主要内容包括信息的表示和处理、程序的机器级表示、处理器体系结构、优化程序性能、存储器层次结构、链接、异常控制流、虚拟存储器、系统级I/O、网络编程、并发编程等。书中提供大量的例子和练习,并给出部分答案,有助于读者加深对正文所述概念和知识的理解。 本书的最大优点是为程序......一起来看看 《深入理解计算机系统(原书第2版)》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换