macfly/yii2-tracker

Yii2 component to to track request for along all microservices app

Installs: 24 178

Dependents: 0

Suggesters: 0

Security: 0

Stars: 3

Watchers: 2

Forks: 0

Type:yii2-component

0.2.6 2019-09-12 06:58 UTC

This package is auto-updated.

Last update: 2024-04-12 16:34:16 UTC


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]";
                },
            ],
        ],
    ],