内容简介:今天 针对公司自己框架 简单写个日志类 主要使用分隔符是为了写入 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 日志类》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 日志与日志不一样:五种不能忽略的日志源
- 从简单日志到全链路日志 我们应该怎么打日志
- iOS关于日志模式及日志级别
- Logback 之 MDC 日志跟踪、日志自定义
- Logback 之 MDC 日志跟踪、日志自定义
- 使用 logstash 作为 Docker 日志驱动收集日志
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法设计与应用
迈克尔 T. 古德里奇(Michael T. Goodrich)、罗伯特·塔马契亚(Roberto Tamas / 乔海燕、李悫炜、王烁程 / 机械工业出版社 / 2017-11-20 / CNY 139.00
本书全面系统地介绍算法设计和算法应用的各个领域,内容涵盖经典数据结构、经典算法、算法分析方法、算法设计方法以及算法在各个领域的应用,还包含一些高级主题。本书采用应用驱动的方法引入各章内容,内容编排清晰合理,讲解由浅入深。此外,各章都附有巩固练习、创新练习和应用练习三种类型的题目,为读者理解和掌握算法设计和应用提供了很好的素材。 本书可作为高等院校计算机及相关专业“数据结构和算法”课程的本科生......一起来看看 《算法设计与应用》 这本书的介绍吧!