ホームページ > バックエンド開発 > PHPチュートリアル > composer - php-fig psr-3 日志接口 怎么理解?monolog有什么牛逼之处?

composer - php-fig psr-3 日志接口 怎么理解?monolog有什么牛逼之处?

WBOY
リリース: 2016-06-06 20:40:40
オリジナル
1184 人が閲覧しました

看这个 PSR 中文版,https://github.com/PizzaLiu/PHP-FIG

或英文原版:http://www.php-fig.org/

其中 PRS-0,PSR-1,PSR-2,PSR-4 都比较好理解,

但是不明白,PSR-3 是什么意思,是说如果写日志类,最好要继承那个接口 还是什么意思?
http://www.php-fig.org/psr/psr-3/


还有,看这里 https://packagist.org/explore/

其中“Popular Packages”第一的是 PSR 的日志类,

第二的是 monolog 这个日志类,怎么这么屌?
https://packagist.org/packages/monolog/monolog

如果用了 monolog 是不是不用管 PSR-3 了?

回复内容:

看这个 PSR 中文版,https://github.com/PizzaLiu/PHP-FIG

或英文原版:http://www.php-fig.org/

其中 PRS-0,PSR-1,PSR-2,PSR-4 都比较好理解,

但是不明白,PSR-3 是什么意思,是说如果写日志类,最好要继承那个接口 还是什么意思?
http://www.php-fig.org/psr/psr-3/


还有,看这里 https://packagist.org/explore/

其中“Popular Packages”第一的是 PSR 的日志类,

第二的是 monolog 这个日志类,怎么这么屌?
https://packagist.org/packages/monolog/monolog

如果用了 monolog 是不是不用管 PSR-3 了?

monolog是符合PSR-3标准的日志类的一种实现

PSR-3要求继承LoggerInterface主要是处于统一各种组件中日志记录模块接口的意图,理想是所有的第三方模块涉及“记录日志”的都通过接受一个LoggerInterface实例然后按接口来记日志,而无需每个模块各自搞一套“如果要记文件,配置XXX,记db配置YYY,日志文件定期删除配ZZZ”之类的东西

所以说题主的最后一句话可能倒过来说更好,要求以PSR-3规范记录日志的地方可以用monolog库的实例作为具体实现
用monolog而不通过LoggerInterface借口的话,达不到PSR-3的初衷


但这是以“写开源模块”“写第三方组件”为前提的(题主可以查查FIG的全称:)) 实际的业务项目中,确实不管PSR-3也不会怎样

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート