PHP删除Session的随机数的方式是通过session.gc_probability和session.gc_divisor这两个配置参数来实现的。默认情况下,它们的值分别为1和100,表示有1%的概率在每个请求中执行Session垃圾回收操作。也就是说,当一个用户请求到达时,PHP会随机生成一个0~session.gc_divisor之间的整数gc_divisor_rand,如果gc_divisor_rand小于session.gc_probability,则执行Session垃圾回收操作。
具体实现方式如下:
PHP先通过opendir()函数打开Session文件存储目录,并遍历其中的所有文件。
对于每个Session文件,PHP通过filemtime()函数获取其最后一次访问的时间戳,并与当前时间相减得到Session文件的存活时间。
如果Session文件的存活时间超过了session.gc_maxlifetime参数设定的值,则认为该Session已经过期,PHP会调用unlink()函数将该Session文件删除。
需要注意的是,由于PHP的Session垃圾回收操作是在请求处理之前执行的,因此它可能会对性能产生一定的影响。为了减小这种影响,可以调整session.gc_probability和session.gc_divisor这两个参数的值,使得垃圾回收操作只在一部分请求中执行,而不是每个请求都执行。另外,也可以通过使用专门的Session存储后端来减少Session垃圾回收操作对性能的影响。