Silex(Monolog)のロギングを変更する

2014/09/21

PHP 開発

t f B! P L
記事内に広告が含まれています。
Homepage - Silex - The PHP micro-framework based on Symfony2 Components のロギングとして、MonologServiceProvider | Japan Symfony Groupというものがあり、通常はこれを使う。
しかしこのロギング、指定したファイルに延々と書き続けるもので、日ごとにファイルをわけたり、ファイル以外の所に書き出したりできない。
元となる Seldaek/monolog · GitHubには、 Handlerという形で、メールに飛ばしたり、DBに書き込んだりする機能が用意されているので、それらを使う方法はないだろうか?

MonologServiceProvider 設定に変更する例が載っていたので、pushHandler()でRotatingFileHandlerを登録してみた。
確かに、日ごとにログファイルが分割されるのだが、相変わらず分割されないファイルにもログが書き出される。これは、変更ではなく、追加だ。

結局
$app[monolog.handler] = function() use ($app){ return new XXXhandler();};
として、無理矢理書き換えているのだが、イマイチな感じがする。

RotatingFileHandlerを使わずに外部のログのローテーションの仕組みを使え!と書いてあるのだが、今回、Windowsで動かすので、そういった当たり前の機能が見当たらない。外部コマンドで用意すべきなんだろうけど、そこはWindowsと*nixの思想の違いということで。

人気の投稿

ブログ アーカイブ

自己紹介

ストックオプションを半分しか行使していなかったけど、パワハラをなぁなぁで済まそうとする会社から転職。アーリーリタイアを目指し、自分で稼ぐ術を模索中。

改正電気通信事業法に関する表記

・掲載内容

当サイトでは成果報酬型広告/クリック型広告の効果測定のため、利用者の方のアクセス情報を外部事業者に送信しております。
当該の情報は個人を特定する情報ではございません。また当該の情報が目的外利用される事は一切御座いません。

1.送信される情報の内容
  • 広告の表示日時
  • 広告のクリック日時
  • 広告の計測に必要なクッキー情報
  • 広告表示時及び広告クリック時のIPアドレス
  • 広告表示時及び広告クリック時に使用されたインターネット端末およびインターネットブラウザの種類
2.送信先となる事業者の氏名又は名称
  • グーグル合同会社
  • 楽天グループ株式会社
  • アマゾンジャパン合同会社
  • ヤフー株式会社
  • 株式会社ファンコミュニケーションズ
  • 株式会社もしも
3.利用目的

成果報酬型広告/クリック型広告の効果測定および不正防止のため

QooQ