Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Session Id in log message missing #11258

Open
gregos22 opened this issue Apr 1, 2016 · 4 comments
Open

Session Id in log message missing #11258

gregos22 opened this issue Apr 1, 2016 · 4 comments
Labels
status:to be verified Needs to be reproduced and validated. type:bug Bug

Comments

@gregos22
Copy link

gregos22 commented Apr 1, 2016

Hello

I have the same problem as @tlanyan in the bug #8036.
I always have the string '[-]' in my log file altought my session is active.
Exemple :
Yii::info('Blablablabla','mhm');
Result :
2016-03-30 13:50:43 [127.0.0.1][XXXXXX][-][info][mhm] Blablablabla

Normaly, the issue was resolved in #8174 with a $this->flush(); (in Logger.php) when the application shutdown.
But, it dosn't work anymore. On the other hand, if I change the statement with the param true like this : $this->flush(true); It's work. Maybe it's a good solution ?

This is my log target configuration :

[
  'class' => 'yii\log\FileTarget',
  'logFile' => dirname(dirname(__DIR__)).'/applicationXXXX/logs/app-journal.log',
  'maxFileSize' => 5120, //5mb
  'logVars' => [],
  'levels' => ['error','warning','info'],
  'categories' => ['mhm'],
],
Q A
Yii version 2.0.7
PHP version 5.6.19
Operating system Windows
@samdark samdark added status:to be verified Needs to be reproduced and validated. type:bug Bug labels Apr 1, 2016
@samdark
Copy link
Member

samdark commented Apr 1, 2016

Do you have active session at the end of request?

@samdark samdark added this to the 2.0.x milestone Apr 1, 2016
@gregos22
Copy link
Author

gregos22 commented Apr 6, 2016

Session is active before Yii::info('Blablablabla','mhm');
Session is active after Yii::info('Blablablabla','mhm');
Session is not active in Target.php line 291 : $sessionID = $session && $session->getIsActive() ? $session->getId() : '-';

I think that session is automatically destroy before log is written

@samdark samdark modified the milestone: 2.0.x Dec 18, 2017
@gattir
Copy link

gattir commented Aug 12, 2018

It seems, that the problem still exists. Steps to reproduce are the following. Installed basic-app. Made 4 actions in SiteController:

`

public function actionSession()
{
    $session = Yii::$app->session;
    $session->open();
    Yii::warning($session->id);
    return $session->id;
}

public function actionNotFound()
{
    $session = Yii::$app->session;
    $session->open();
    Yii::warning($session->id);
    throw new \yii\web\NotFoundHttpException('not found');
}

public function actionFlush()
{
    $session = Yii::$app->session;
    $session->open();
    Yii::warning($session->id);
    Yii::getLogger()->flush();
    return $session->id;
}

public function actionFinalFlush()
{
    $session = Yii::$app->session;
    $session->open();
    Yii::warning($session->id);
    Yii::getLogger()->flush(true);
    return $session->id;
}

`

And got the results respectively:

2018-08-12 10:58:02 [127.0.0.1][-][-][warning][application] osqk2m5mh4oubnobj1fsgs8dam33e7f2
2018-08-12 10:58:06 [127.0.0.1][-][osqk2m5mh4oubnobj1fsgs8dam33e7f2][warning][application] osqk2m5mh4oubnobj1fsgs8dam33e7f2
2018-08-12 10:58:10 [127.0.0.1][-][-][warning][application] osqk2m5mh4oubnobj1fsgs8dam33e7f2
2018-08-12 10:58:13 [127.0.0.1][-][osqk2m5mh4oubnobj1fsgs8dam33e7f2][warning][application] osqk2m5mh4oubnobj1fsgs8dam33e7f2

As you can see the session persists between action calls, but it disappears in logs prefix. So as I understand, if the log isn't final-flushed (as it is during errors like not found exceptions) it places [-], because during the time of log writing, the session already is not active. And I think it's not correct behavior, as you should be able to write in log several times, so it's not correct to call final flush.

Maybe it is needed to save session when log message is created for later use in prefix. And use that saved session instead of calling $session->getIsActive(). That is method getMessagePrefix in yii\log\Target

Btw, the original discussion thread of this feature (for yii1): https://www.yiiframework.com/forum/index.php/topic/2426-session-id-in-the-logger/

@gattir
Copy link

gattir commented Aug 12, 2018

So, as mentioned before when Target tries to get session, it is already closed. This is how it looks like. The order of execution is following:

Logger.init: registering shutdown function - (1)
Session.init: registering shutdown function - Session.close
Application running
Application.run finished
Logger.flush()
(1): registering shutdown function in shutdown function
Session.close
Logger.flush(1)
Target.getMessagePrefix
Target.getMessagePrefix
Target.getMessagePrefix
Target.getMessagePrefix
Target.getMessagePrefix
Target.getMessagePrefix
Target.getMessagePrefix

And when in Target.getMessagePrefix it tries to do this:

        /* @var $session \yii\web\Session */
        $session = Yii::$app->has('session', true) ? Yii::$app->get('session') : null;
        $sessionID = $session && $session->getIsActive() ? $session->getId() : '-';

It sees that there is no session, and it thinks that there were none during all execution (which is wrong). When the reason for that is, that the logging is actually executed after everything is finished.

This order is based on this two pieces of code:

In Session.init:

        register_shutdown_function([$this, 'close']);

In Logger.init:

        register_shutdown_function(function () {
            // make regular flush before other shutdown functions, which allows session data collection and so on
            $this->flush();

            // make sure log entries written by shutdown functions are also flushed
            // ensure "flush()" is called last when there are multiple shutdown functions
            register_shutdown_function([$this, 'flush'], true);
        });

And as mentioned in the comments of code, it is meant to be called last, but unfortunatelly

  1. it has no session record
  2. it messes all other logging before final flush (cause in has no session in the time of execution)
  3. maybe it messes with session, because it executes session tickling in getMessagePrefix

The 3 is a crazy guess, but could that be connected to these long hunted mysteries:
#11401
#9438

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
status:to be verified Needs to be reproduced and validated. type:bug Bug
Projects
None yet
Development

No branches or pull requests

3 participants