关于PHP中Session⽂件过多的问题及session⽂件保存位
置
PHP的默认机制:每⼀次php请求,会有1/100的概率(默认值)触发“session回收”。如果“session回收”发⽣,那就会检
查/tmp/sess_*的⽂件,如果最后的修改时间到现在超过了1440秒(gc_maxlifetime的值),就将其删除,意味着这些session 过期失效
⼀、session⽂件是什么
⽂件⼀般为 /tmp/sessions/sess_4b1e384ad74619bd212e236e52a5a174If
username|s:9:"test";admin|s:1:"0";
⼆、session回收何时发⽣
默认情况下,每⼀次php请求,就会有1/100的概率发⽣回收,所以可能简单的理解为“每100次php请求就有⼀次回收发⽣”。这个概率是通过以下参数控制的
#概率是gc_probability/gc_divisor
<_probability = 1
<_divisor = 100
假设这种情况gc_maxlifetime=120,如果某个session⽂件最后修改时间是120秒之前,那么在下⼀次回收(1/100的概率)发⽣前,这个session仍然是有效的。
如果你的session使⽤session.save_path中使⽤别的地⽅保存session,session回收机制有可能不会⾃动处理过期session⽂件。这时需要定时⼿动(或者crontab)的删除过期的session
三、设置session存储⽬录
使⽤php5-fpm的话, 修改/etc/php5/fpm/php.ini, 修改或添加下⾯⼀⾏:
session.save_path = 3;600:/tmp/sessions
四、session清除脚本
#!/bin/sh
find /tmp/php-session -cmin +24 -name "sess_*" -and -size 0 -delete > /dev/null 2>&1
find /tmp/php-session -cmin +1440 -name "sess_*" -delete > /dev/null 2>&1
这⾥的时间我们可以通过 _maxlifetime 来获取,放到定时任务⾥⾯即可(crontab)
其他⽅式
使⽤memcache 等,(session.save_handler = memcache)
使⽤cookie,但是cookie得加密
五、使⽤tmfs存储session
1、将/tmp挂载为 tmpfs⽂件系统
修改/etc/fstab,在最后⼀⾏添加如下内容:/tmp/sessions tmpfs defaults,size=5120m 0 0
mount -a
2、创建session存储⽂件夹
php并不会⾃动去创建这些⽂件夹,不过在源⽂件中提供了⼀些创建⽂件夹的脚本。下⾯这个脚本也好⽤,脚本内容如下
#!/bin/sh
dir="0 1 2 3 4 5 6 7 8 9 a b c d e f"
for levela in $dir;
do
for levelb in $dir;
do
for levelc in $dir;
do
mkdir -p /tmp/sessions/$levela/$levelb/$levelc;
done
done;
done
chown -R root:webgrp /tmp/sessions && chmod -R 1777 /tmp/sessions
因为/tmp/sessions是⽤的内存,服务器重启后,⾥⾯的所有⽂件都会丢失,所以,需要把上⾯的脚本加⼊到 /etc/rc.local中,并且要放在启动php之前
3、将session存储到不同的⽬录中
php本⾝⽀持session的多级散列,在php.ini中,将 ;session.save_path = /tmp 改为
session.save_path = "3;/tmp/sessions
4、session的回收
使⽤上⾯的脚本即可
下⾯给⼤家说下php session 数据保存在哪⾥?
当然是在服务器端,但不是保存在内存中,⽽是保存在⽂件或数据库中。
默认情况下,php.ini 中设置的 SESSION 保存⽅式是 files(session.save_handler = files),即使⽤读写⽂件的⽅式保存SESSION 数据,⽽ SESSION ⽂件保存的⽬录由 session.save_path 指定,⽂件名以 sess_ 为前缀,后跟 SESSION ID,如:sess_c72665af28a8b14c0fe11afe3b59b51b。⽂件中的数据即是序列化之后的 SESSION 数据了。
session如何设置和读取如果访问量⼤,可能产⽣的 SESSION ⽂件会⽐较多,这时可以设置分级⽬录进⾏ SESSION ⽂件的保存,效率会提⾼很多,设置⽅法为:session.save_path="N;/save_path",N 为分级的级数,save_path 为开始⽬录。
当写⼊ SESSION 数据的时候,PHP 会获取到客户端的 SESSION_ID,然后根据这个 SESSION ID 到指定的 SESSION ⽂件保存⽬录中到相应的 SESSION ⽂件,不存在则创建之,最后将数据序列化之后写⼊⽂件。读取 SESSION 数据是也是类似的操作流程,对读出来的数据需要进⾏解序列化,⽣成相应的 SESSION 变量。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论