Laravel 重写日志,让日志更优雅

2 篇文章 0 订阅

更改目的:

  • 重写了日志格式
  • 加入trace,一次请求的唯一标识
  • 加入error级别信息推送,事例中使用企业微信群助手
  • 让我们可以更及时、更优雅、更方便追踪日志信息
  • 有助于初学者了解Laravel框架
  1. 将文件 AppTool.phpLogger.phpLogServiceProvider.php复制到 app/Providers文件夹下,
    将文件BaseCommand.php复制到App\Console

  2. config/app.php→providers中加入

    'providers' => [
      ……
      // 注册日志
       App\Providers\LogServiceProvider::class
      ……
      ];
    
  3. 在项目中使用如下方式调用

    // php-fpm方式调用 日志路径 /opt/logs/xxx.log /opt/logs/xxx.error
    \Log::info("info");
    \Log::debug("debug");
    \Log::error("error");
    // 在cli方式调用 日志路径 /opt/clogs/xxx.log /opt/clogs/xxx.error
    app('cLog')->info("info");
    app('cLog')->debug("debug");
    app('cLog')->error("error");
    
  4. 在日志级别为error时,会执行推送,本事例中采用企业微信群推送

        /**
         * 推送错误信息
         * @param $message
         */
        public function pushErrorMessage($message)
        {
            $content = "app:". static::getAppName() ."  
    src: ". static::getRequestSource() ."
    trace:". self::getTrace() ."
    url:". static::$uri_info ." 
    error: ". $message ."
    time:". date("Y-m-d H:i:s");
            // 测试群
            $url = "xxxxxxxxxxxx";
            $result = app('\GuzzleHttp\Client')->request('POST', $url, [
                \GuzzleHttp\RequestOptions::JSON=>[
                    "msgtype"=> "text",
                    "text"=> [
                        "content" => $content
                    ]
                ]
            ]);
            $body = \GuzzleHttp\json_decode($result->getBody()->getContents(), true);
        }
    
  5. 日志内容

// cli模式下的
[2019-11-11 17:50:01] local.INFO: [app:partner-counselor src:127.0.0.1 time:406 trace:20ba14b9 url:App\Console\Commands\TrailPushMessage@handle href:N] 推送未锁定商机信息-未锁定: 结束执行

// php-fpm模式下
[2019-11-08 18:58:57] local.INFO: [app:partner-counselor src:127.0.0.1 time:36 trace:3633ccee url:GEThttp://127.0.0.1:50111/api/customers/348 href:N] 请求的数据为:{"token":"bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC8xMjcuMC4wLjE6NTAxMTFcL2FwaVwvYXV0aFwvbG9naW4iLCJpYXQiOjE1NzMyMDQwMzAsImV4cCI6MTU3MzgwODgzMCwibmJmIjoxNTczMjA0MDMwLCJqdGkiOiJZV2RsMU9PdFBOMTV3ZmNZIiwic3ViIjo2LCJwcnYiOiIyNTE5NzdjOTQ4NzExYTE4NDQyNGQ1ZDFmNjQ4Y2U0Mjg1NzQ5YmQwIn0.KTA7a8v5jw80O2WrXMHeVsJSeiv194hsTYHQEn_2KCo"}

注意事项:

  1. 修改如下代码不同版本bind部分会有所不同,具体根据\Illuminate\Foundation\Application::registerCoreContainerAliaseslog信息修改。
    如laravel6.x中为'log' => [\Illuminate\Log\LogManager::class, \Psr\Log\LoggerInterface::class],,修改方式就如下方代码
        ……
        // 注入全局容器
        $app->instance('Log', $logger);
        $app->bind('Psr\Log\LoggerInterface', function (Application $app) {
            return $app['log']->getLogger();
        });
        $app->bind('\Illuminate\Log\LogManager', function (Application $app) {
            return $app['log'];
        });
        ……
  1. 有关console中使用时,建议重写\Illuminate\Console\Command::info\Illuminate\Console\Command::line\Illuminate\Console\Command::error,然后所有console继承BaseCommand
    demo代码块:
use App\Console\BaseCommand;

class Demo extends BaseCommand
{
    protected $signature = 'command:demo';
    protected $description = 'demo';
    public function __construct()
    {
        parent::__construct();
    }
    public function handle()
    {
        $this->info('this is info!');
        $this->line('this is line!');
        $this->error('this is error!!!');
    }
}

demo 命令行输出:

命令行输出信息

具体文件请移步github
github项目地址

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值