macfly/yii2-tracker 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

macfly/yii2-tracker

最新稳定版本:0.2.6

Composer 安装命令:

composer require macfly/yii2-tracker

包简介

Yii2 component to to track request for along all microservices app

README 文档

README

Yii2 tracker try to get or set a unique request id for every request to follow it from service to service mainly for logging, debuging and track which micro-service is doing what on other micro-service app.

Component will try to get from :

  • From every HTTP request the header with name @X-tracker-request-id@, it means that we have been call by another service which already provide us a unique request id
  • From RabbitMQ message header, currently working with mikemadisonweb/yii2-rabbitmq extension
  • If no unique request id is provide create one it means we're the first micro-service to be call
  • If we're doing request to API through yiisoft/yii2-httpclient add the @X-tracker-request-id@ to outgoing request
  • If we're sending RabbitMQ message add to every message a header @X-tracker-request-id@, working with version 2.x of mikemadisonweb/yii2-rabbitmq extension
  • Add header @X-tracker-request-id@ in every HTTP response

Installation

The preferred way to install this component is through composer.

Either run

php composer.phar require --prefer-dist "macfly/yii2-tracker" "*" 

or add to the @require@ section in your composer.json file.

"macfly/yii2-tracker": "*" 

Configure

Configure config/web.php and config/console.php as follows

'bootstrap' => [ 'log', 'tracker', ], 'components' => [ 'tracker' => [ 'class' => 'app\components\Tracker', 'header' => 'X-tracker-request-id', // Name of the header component try to get or set. ], ................ ],

Usage

You can get the unique request id from the component with :

 \Yii::$app->tracker->id;

For example if you want to add it to your log you can change the the target prefix to :

'components' => [ 'log' => [ 'targets' => [ [ 'class' => 'yii\log\FileTarget', 'logVars' => [], 'prefix' => function ($message) { if (Yii::$app === null) { return ''; } $app = Yii::$app->name; $id = Yii::$app->tracker->getId(); $request = Yii::$app->getRequest(); $ip = $request instanceof Request ? $request->getUserIP() : '-'; /* @var $user \yii\web\User */ $user = Yii::$app->has('user', true) ? Yii::$app->get('user') : null; if ($user && ($identity = $user->getIdentity(false))) { $userID = $identity->getId(); } else { $userID = '-'; } /* @var $session \yii\web\Session */ $session = Yii::$app->has('session', true) ? Yii::$app->get('session') : null; $sessionID = $session && $session->getIsActive() ? $session->getId() : '-'; return "[$app][$id][$ip][$userID][$sessionID]"; }, ], ], ],

统计信息

  • 总下载量: 27.58k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固