Magento 2 控制台记录(logging)

3,442次阅读
没有评论

共计 2644 个字符,预计需要花费 7 分钟才能阅读完成。

Magento 2 控制台记录(logging)

每次开发过程中,你都会想记录一些一些变量或者用户信息,现在我们就来谈谈怎么创建自定义记录。Magento 2 内建了一个记录模块,是基于Monolog库。可以在下面路径找到: “MAGENTO2_ROOT/vendor/monolog“.

在Magento 2 中,Monolog的类(class)是“Magento\Framework\Logger\Monolog“, 在“MAGENTO2_ROOT/app/etc/di.xml”有这样的定义:

[php]
<preference for="Psr\Log\LoggerInterface" type="Magento\Framework\Logger\Monolog" />[/php]

你可以在monolog包中看到“Monolog\Logger”这个类的扩展类。

[php]
<?php
/**
* Copyright © 2015 Magento. All rights reserved.
* See COPYING.txt for license details.
*/

namespace Magento\Framework\Logger;

use Monolog\Logger;

class Monolog extends Logger
{
}
[/php]

在“Monolog\Logger” 类中,有很多种方法可以创建记录(logs)。这些方法中提供两种路径,即Message(string)和 optional array parameter (you can pass instance of object).

方法举例:

[php]
$this->_logger->addDebug($message); // log location: var/log/system.log
$this->_logger->addInfo($message); // log location: var/log/exception.log
$this->_logger->addNotice($message); // log location: var/log/exception.log
$this->_logger->addError($message); // log location: var/log/exception.log
$this->_logger->critical($e); // log location: var/log/exception.log
[/php]

一个很有参考意义的记录php exception的例子:

Magento 1中用静态方法:

[php]
Mage::logException($e);
[/php]

Magento 2 中使用“Magento\Framework\Logger\Monolog”方法和“critical” 来记录 try-catch的exception

[php]
$this->_logger->critical($e);
// instance of $e will be converted to string (magic metod __toString() will be called).[/php]

我们试试从使用你的类获取 Magento\Framework\Logger\Monolog实例开始.

如果你要是用“Magento\Framework\Logger\Monolog”对象,下面是一个案例:

[php]
<?php
namespace Inchoo\Test\Model;

class Example{
protected $_logger;
public function __construct(
\Psr\Log\LoggerInterface $logger, //log injection
array $data = []
) {
$this->_logger = $logger;
parent::__construct($data);
}
public function someExampleMethod() {
/*
some logic of method
*/
//accessing to logger instance and calling log method
$this->_logger->addDebug(‘some text or variable’);
}
}[/php]

这个类从始至终使用“\Psr\Log\LoggerInterface $logger”来传递信息,这样我就可以在类“Inchoo\Test\Model\Example“中使用实例“$this->_logger”。

如果你想在自定义的文件或者位置中写入log,就没有这么容易了。你需要自己创建一个Log handler

Magento 2 已经在 “MAGENTO2_ROOT/app/etc/di.xml”中定义了3个主要的log class handler。这几个Handler分别是 : exception, system and debug.

[php]
<type name="Magento\Framework\Logger\Monolog">
<arguments>
<argument name="name" xsi:type="string">main</argument>
<argument name="handlers" xsi:type="array">
<item name="exception" xsi:type="object">Magento\Framework\Logger\Handler\Critical</item>
<item name="system" xsi:type="object">Magento\Framework\Logger\Handler\System</item>
<item name="debug" xsi:type="object">Magento\Framework\Logger\Handler\Debug</item>
</argument>
</arguments>
</type>[/php]

有时候log object已经存在框架中了,我们就没有比较再在框架中传递log object了。
例如,我们在每个html block中都会碰到的情况:在“\Magento\Framework\View\Element\Template” 或者 “\Magento\Framework\Model\AbstractModel“.

父类中已经有了 $_logger” : Magento\Framework\Logger.

希望这个文章能对你有用!

正文完
 0
评论(没有评论)

空瓶子部落

文章搜索
推荐阅读
坚持原则的质量人,你该学会说“NO”

坚持原则的质量人,你该学会说“NO”

质管之路,需要坚持;质管之路,也有红绿灯,而质量人,则是路口的交通警察。 有很多人、很多公司老总(在人才市场面...
共识不是开会,而是这2个关键动作!

共识不是开会,而是这2个关键动作!

每到年底,季末,月末,老板们最爱干的事就是开会。 战略会、务虚会、复盘会……一群人关在会议室里,对着PPT翻来...
如果是人为操作失误,如何回答客户的8D报告?

如果是人为操作失误,如何回答客户的8D报告?

前言:本文转自 资深质量管理人 张晓霜老师,版权归张晓霜老师所有。 转录下来,供仔细体会学习。 —...
免维护IPTV聚合工具肥羊AllInOne

免维护IPTV聚合工具肥羊AllInOne

什么是 youshandefeiyang/allinone ? allinone 是斗鱼,虎牙,抖音等直播平台...
T型能力结构升级——π型?井型?

T型能力结构升级——π型?井型?

T型能力结构升级——π型?井型? 随着个人职业的不断发展和市场需求的变化,单一的T型能力结构可能不再完全适应。...
最新文章
Free TV:全球免费电视频道 M3U 播放列表,狂揽数万 Star

Free TV:全球免费电视频道 M3U 播放列表,狂揽数万 Star

https://github.com/Free-TV/IPTV 项目简介 Free TV 是一个精心维护的开源...
群晖 Let’s Encrypt 泛域名证书自动更新

群晖 Let’s Encrypt 泛域名证书自动更新

目前acme协议版本更新,开始支持泛域名(wildcard),也就是说,可以申请一个类似*.domain.co...
可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

还在为找优秀片源难、广告多、平台会员太贵而烦恼?今天给大家挖到一款真正的影视宝藏工具——小猫影视! 作为开源免...
【收藏】一次性解决TV点播/直播自由

【收藏】一次性解决TV点播/直播自由

很多时候,资源就在面前,但是我们视而不见,因为长久的安逸,已经让人失去动手的兴趣。但是每次我需要挨个切换APP...
OpenWrt 存储空间扩容的两种方案

OpenWrt 存储空间扩容的两种方案

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
热门文章
提高过程能力指数(CP/CPK)的途径

提高过程能力指数(CP/CPK)的途径

编者按:过程能力指数(CP/CPK)想必各位质量人都耳熟能详、运用自如,质量工程师之家前期也共享过数篇关于过程...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
测量高手放大招:圆跳动测量技巧总结

测量高手放大招:圆跳动测量技巧总结

01. 前言 在五金机加工厂实际的测量工作中,经常碰到要求测量两个要素的圆跳动问题, 利用不同的测量辅件及夹具...
过程能力分析(CP&cpk)

过程能力分析(CP&cpk)

引入过程能力分析的目的? 在我们现有的管理过程中,我们经常会遇到有些具体指标总是不尽人意,存在许多需要改进的地...
新能源汽车 “两会”精神宣贯会

新能源汽车 “两会”精神宣贯会

此次和大家分享新能源汽车相关政策: [embeddoc url=”https://www.ctro...
最新评论
多乐士 多乐士 通过摸索发现ssh拉取会报错,直接网页访问下载会报404错误,不知道原因;但是可以通过群晖CM注册表访问下载,其方法如下: Container Manager-注册表-设置-新增-注册表名称随便写,注册表URL填你的加速地址,勾选信任的SSL自我签署证书,登录信息不填-应用-使用你的地址,这是注册表会显示了,在搜索栏中输入映像名称,搜索结果在每一页的最后一个,你需要划到最后一个进行下载,实测可正常下载安装。 以上供网友参考。
多乐士 多乐士 还有一个比较简单的方法,只是需要一些外部工具。 1、讲损毁硬盘取出,装入外部移动硬盘 2、打开Diskgenius,定位到硬盘 3、格式化系统分区 4、重新插入硬盘 5、存储池->修复存储池即可
多乐士 多乐士 写的不错的文章
辞了老衲 辞了老衲 这个确实有帮助。
渋驀 渋驀 当然任何时候都可以用curl命令和crontab来实现动态更新DDNS的ip地址: 1、安装crontab之后为root用户创建文件/var/spool/cron/root 2、创建并配置ddnsupdate.sh,放到/usr/bin/文件下,文件内容(以he.net为例): Autodetect my IPv4/IPv6 address: IPV4:curl -4 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" IPV6:curl -6 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" 3、添加执行权限chomod +x /usr/bin/ddnsupdate.sh 4、编辑root用户的crontab:*/10 * * * * /usr/binddnsupdate.sh,每10分钟执行一次。好了,可以享受你的DDNS了
21410 21410 请问下载链接在那里?
madkylin madkylin 不错,不错,谢谢分享了,好东西啊 :lol:
feilung feilung 求方法
zengsuyi zengsuyi 应该挺不错的
zise zise 看看是怎么操作的。。 :oops: