bvtvd/hyperf-log-viewer

hyperf 日志查看器

2.0.0 2020-07-28 01:47 UTC

This package is auto-updated.

Last update: 2024-09-28 11:32:41 UTC


README

发布配置文件

php bin/hyperf.php vendor:publish bvtvd/hyperf-log-viewer

该命令会在 config/autoload 下发布一个名为 log_viewer.php 的配置文件,并在 storage/view 下发布一个名为 log.blade.php 的视图文件

在 config/routes 文件中自定义查看日志的访问路由,例如

Router::get('/logs', 'bvtvd\HyperfLogViewer\Controller\LogController@index');

注意

  • 该包需要安装 hyperf/view,还需要 duncan3dc/blade 模板引擎提供支持,请谨慎使用。
  • 视图配置如下
use Hyperf\View\Engine\BladeEngine;
use Hyperf\View\Mode;

return [
    'engine' => BladeEngine::class,
    'mode' => Mode::TASK,
    'config' => [
        'view_path' => BASE_PATH . '/storage/view/',
        'cache_path' => BASE_PATH . '/runtime/view/',
    ],
];
  • 需要将日志文件按日志进行分割
  • 可以选择将程序运行异常输出到日志文件,修改 app\Exception\Handler\AppExceptionHandler.php 文件如下
class AppExceptionHandler extends ExceptionHandler
{
    /**
     * @var StdoutLoggerInterface
     */
    protected $logger;

    public function __construct(StdoutLoggerInterface $logger)
    {
        $this->logger = $logger;
    }

    public function handle(Throwable $throwable, ResponseInterface $response)
    {
        ApplicationContext::getContainer()->get(LoggerFactory::class)->make()->error(sprintf("%s[%s] in %s\n[stacktrace]\n%s", $throwable->getMessage(), $throwable->getLine(), $throwable->getFile(), $throwable->getTraceAsString()));

        return $response->withHeader("Server", "Hyperf")->withStatus(500)->withBody(new SwooleStream('Internal Server Error.'));
    }

    public function isValid(Throwable $throwable): bool
    {
        return true;
    }
}