Hyperf フレームワークを使用してログを記録する方法

PHPz
リリース: 2023-10-20 10:27:11
オリジナル
991 人が閲覧しました

Hyperf フレームワークを使用してログを記録する方法

Hyperf フレームワークをログ記録に使用する方法

はじめに:
ソフトウェア開発において、ログ記録は非常に重要な機能であり、開発者がエラーを追跡し、分析するのに役立ちます。問題を解決し、システムの健全性を監視します。 Hyperf フレームワークを使用して開発する場合、その組み込みのログ コンポーネントを使用して、柔軟なログ機能を実装できます。この記事では、ログ記録に Hyperf フレームワークを使用する方法を説明し、詳細なコード例を示します。

1. ログ コンポーネントの構成
Hyperf フレームワークでは、構成ファイル config/autoload/logger.php でログ コンポーネントを構成できます。以下は簡単な参考例です:

return [
    'default' => [
        'handlers' => [
            [
                'class' => MonologHandlerStreamHandler::class,
                'constructor' => [
                    'stream' => BASE_PATH . '/runtime/logs/hyperf.log',
                    'level' => MonologLogger::DEBUG,
                ],
            ],
        ],
    ]
];
ログイン後にコピー

上の例では、StreamHandler を使用してログを記録し、ログは /runtime/logs/hyperf に書き込まれます。 .log ファイル。ログ プロセッサに関する設定情報の詳細については、Monolog コンポーネントのドキュメントを参照してください。

2. ログ コンポーネントを使用する
コードでは、コンテナ オブジェクト $container を通じてログ コンポーネント インスタンスを取得し、それが提供するログ記録用のメソッドを使用できます。

  1. 一般情報の記録
    info() メソッドを使用して、システム ステータス、操作記録などの一般情報を記録できます。以下に例を示します。

    $logger = $container->get(PsrLogLoggerInterface::class);
    $logger->info('系统启动成功');
    ログイン後にコピー
  2. 警告情報を記録する
    開発者の注意が必要な警告情報に遭遇した場合、warning() メソッド Record を使用できます。 。以下に例を示します。

    $logger = $container->get(PsrLogLoggerInterface::class);
    $logger->warning('数据库连接失败');
    ログイン後にコピー
  3. エラー情報を記録する
    アプリケーションでエラーが発生した場合、error() メソッドを使用してエラー情報を記録できます。エラー情報を追加し、例外オブジェクトを追加情報として渡します。以下は例です:

    try {
     // Some code that may throw an exception
    } catch (Exception $e) {
     $logger = $container->get(PsrLogLoggerInterface::class);
     $logger->error('发生异常', ['exception' => $e]);
    }
    ログイン後にコピー

3. コンテキスト情報の使用
ログを記録するときに、要求された URL、セッション情報などのコンテキスト情報を添付する必要がある場合があります。 。 Hyperf フレームワークは、この関数を実装するための Logger::pushProcessor() メソッドを提供します。以下は例です:

$container->get(PsrLogLoggerInterface::class)->pushProcessor(function ($record) {
    $record['extra']['url'] = $_SERVER['REQUEST_URI'];
    $record['extra']['sessionId'] = session_id();
    return $record;
});

$logger->info('请求完成');
ログイン後にコピー

上の例では、リクエスト URL とセッション ID という 2 つのコンテキスト情報をログ レコードに追加しました。

結論:
この記事では、ログ記録に Hyperf フレームワークを使用する方法を紹介し、具体的なコード例を示します。適切な構成と使用により、Hyperf フレームワークの組み込みログ コンポーネントの機能を最大限に活用し、柔軟で効率的なログを実現できます。この記事が Hyperf フレームワークの開発者に役立つことを願っています。

以上がHyperf フレームワークを使用してログを記録する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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