PHP Garbage Collection clarification

后端 未结 3 956
终归单人心
终归单人心 2020-12-30 19:04

From the PHP manual, session.gc_probability and session.gc_divisor state that gc will occur based on this probability. I get that.

What I\'m not clear on is whether

相关标签:
3条回答
  • 2020-12-30 19:28

    I'm not an expert on this, but from reading the manual, I'd draw your attention to another setting, session.gc_maxlifetime. From the docs:

    session.gc_maxlifetime specifies the number of seconds after which data will be seen as 'garbage' and potentially cleaned up. Garbage collection may occur during session start (depending on session.gc_probability and session.gc_divisor).

    So if you set this setting to a suitable value (60 * 60 * 24 * 365 / 2 for half a year, so 15768000), then the appropriate data won't be eligible for garbage collection, no matter what the other settings are.

    0 讨论(0)
  • 2020-12-30 19:36

    last time I looked at the source each call to session_start() "rolled the dice" so to speak, using the divisor and probability. If you hit, then it would delete all files from the session.save_path directory that were older than session.gc_maxlifetime. I forget if it used modification or access time of the file, although it shouldn't matter in normal curcumstances because php overwrites the session file by default at the end of script execution, so mod and access times should almost always match very closely.

    // Rough psuedo code of how php's session_start() function works regarding garbage collection.
    function session_start() {
        $percentChanceToGC = 100 * ini_get('session.gc_probability') / ini_get('session.session.gc_divisor');
        $shouldDoGarbageCollection = rand(1, 100) < $percentChanceToGC;
        if ($shouldDoGarbageCollection) {
            $expiredCutoffTime = time() - ini_get('session.gc_maxlifetime');
            foreach (scandir(ini_get('session.save_path')) as $sessionFile) {
                if (filemtime($sessionFile) < $expiredCutoffTime) {
                    unlink($sessionFile);
                }
            }
        }
    
        // ... rest of code ....
    }
    

    I don't know how many session files you're going to end up having hang around if you want them to live for a minimum of 6 months. Consider it may take a little while for php to stat many thousands of files to determine their age. Maybe consider other options for durable storage of this data. Or you could disable php gc and just run a cron job to delete stale session files. Otherwise, that 1% of requests are gonna trigger gc and have to wait for php; in other words it could possibly lag.

    0 讨论(0)
  • 2020-12-30 19:44

    Every time a PHP script is executes and starts session there is a probability that it will sweep through the session folder killing off old session.

    Cleanup will only delete sessions which were not accessed within a certain time. However PHP does not guarantee that the session WILL be destroyed within that time.

    Your long-term session strategy should work just fine, but you might want to reduce 1% to something like 0.1%

    Another thing to look out for is that operating system might clean up your /tmp folder during reboot so even if PHP won't do it.

    0 讨论(0)
提交回复
热议问题