php中session过期时间设置及session回收机制介绍


Posted in PHP onMay 05, 2014

网上很多人给出了解答:修改配置文件中的session.gc_maxlifetime。如果想了解更多session回收机制,继续阅读。(本文环境php5.2)

概述:每一次php请求,会有1/100的概率(默认值)触发“session回收”。如果“session回收”发生,那就会检查/tmp/sess_*的文件,如果最后的修改时间到现在超过了1440秒(gc_maxlifetime的值),就将其删除,意味着这些session过期失效。

1. session在端(一般是 with PHP module)如何存在的?

默认的,php会将session保存在/tmp目录下,文件名为这个样子:sess_01aab840166fd1dc253e3b4a3f0b8381。每一个文件对应了一个session(会话)。
more /tmp/sess_01aab840166fd1dc253e3b4a3f0b8381
username|s:9:”jiangfeng”;admin|s:1:”0″;
#变量名|类型:长度:值

删除这里的session文件,就表示对应的session失效了。

2. session在client端(一般是浏览器)如何存在的?

session在浏览器端,只需要保存session ID(由server端生成的唯一ID)就可以了。有两种保存方式:在cookie中、在url里面。如果cookie中保存session ID,就可以看到浏览器的cookie中有一个PHPSESID变量。如果是URL传递的,就可以看到形如:
index.php?PHPSESID=01aab840166fd1dc253e3b4a3f0b8381的URL。(在server端通过session.use_cookies来控制使用哪一种方式)

3. 在server端,php如何判断session文件是否过期?

如果”最后的修改时间”到”现在”超过了gc_maxlifetime(默认是1440)秒,这个session文件就被认为是过期了,在下一次session回收的时候,如果这个文件仍然没有被更改过,这个session文件就会被删除(session就过期了)。

简单的说,如果我登录到某网站,如果在1440秒(默认值)内没有操作过,那么对应的session就认为是过期了。

所以,修改php.ini文件中的gc_maxlifetime变量就可以延长session的过期时间了:(例如,我们把过期时间修改为86400秒)
session.gc_maxlifetime = 86400

然后,重启你的web服务(一般是apache)就可以了。

注意:php5里面session过期使用了回收机制。这里设置时间为86400秒,如果session在86400秒内没有被修改过,那么在下一次“回收”时才真的被删除。

3. session“回收”何时发生?

默认情况下,每一次php请求,就会有1/100的概率发生回收,所以可能简单的理解为“每100次php请求就有一次回收发生”。这个概率是通过以下参数控制的
#概率是gc_probability/gc_divisor
session.gc_probability = 1
session.gc_divisor = 100

注意1:假设这种情况gc_maxlifetime=120,如果某个session文件最后修改时间是120秒之前,那么在下一次回收(1/100的概率)发生前,这个session仍然是有效的。

注意2:如果你的session使用session.save_path中使用别的地方保存session,session回收机制有可能不会自动处理过期session文件。这时需要定时手动(或者crontab)的删除过期的session:cd /path/to/sessions; find -cmin +24 | xargs rm

4. 一些特殊情况

因为回收机制会检查文件的“最后修改时间”,所以如果某个会话是活跃的,但是session的内容没有改变过,那么对应的session文件也就没有改变过,回收机制会认为这是一个长时间没有活跃的session而将其删除。这是我们不愿看到的,可以通过增加如下的简单代码解决这个问题:

<?phpif(!isset($_SESSION['last_access'])||(time()-$_SESSION['last_access'])>60) $_SESSION['last_access'] = time();?>

代码会每隔60秒,尝试修改修改一次session。

总结:如果想修改session过期时间,修改变量gc_maxlifetime就可以了。php5的session采用被动的回收机制(garbage collection)。过期的session文件不会自己消失,而是通过触发“回收”来处理过期的session。

PHP 相关文章推荐
WINDOWS下php5.2.4+mysql6.0+apache2.2.4+ZendOptimizer-3.3.0配置
Mar 28 PHP
php 无限级缓存的类的扩展
Mar 16 PHP
Wordpress php 分页代码
Oct 21 PHP
PHP 创建标签云函数代码
May 26 PHP
php foreach循环中使用引用的问题
Nov 06 PHP
php读取csv实现csv文件下载功能
Dec 18 PHP
php教程之魔术方法的使用示例(php魔术函数)
Feb 12 PHP
PHP文件读取功能的应用实例
May 08 PHP
一个非常实用的php文件上传类
Jul 04 PHP
PHP+Ajax实现的博客文章添加类别功能示例
Mar 29 PHP
laradock环境docker-compose操作详解
Jul 29 PHP
一文看懂PHP进程管理器php-fpm
Jun 01 PHP
使用php语句将数据库*.sql文件导入数据库
May 05 #PHP
PHP判断是否有Get参数的方法
May 05 #PHP
php快递单号查询接口使用示例
May 05 #PHP
JS异常处理try..catch语句的作用和实例
May 05 #PHP
php生成短网址示例
May 05 #PHP
PHP zip扩展Linux下安装过程分享
May 05 #PHP
PHP常用的缓存技术汇总
May 05 #PHP
You might like
php实现的一个很好用HTML解析器类可用于采集数据
2013/09/23 PHP
easyui的tabs update正确用法分享
2014/03/21 PHP
PHP 用session与gd库实现简单验证码生成与验证的类方法
2016/11/15 PHP
老生常谈文本文件和二进制文件的区别
2017/02/27 PHP
Thinkphp结合AJAX长轮询实现PC与APP推送详解
2017/07/31 PHP
js prototype 格式化数字 By shawl.qiu
2007/04/02 Javascript
JS学习之一个简易的日历控件
2010/03/24 Javascript
JQuery动态给table添加、删除行 改进版
2011/01/19 Javascript
无缝滚动js代码通俗易懂(自写)
2013/06/19 Javascript
如何使用Jquery获取Form表单中被选中的radio值
2013/08/09 Javascript
基于JavaScript实现手机短信按钮倒计时(超简单)
2015/12/30 Javascript
AngularJS 最常用的功能汇总
2016/02/17 Javascript
js表单验证实例讲解
2016/03/31 Javascript
require.js 加载 vue组件 r.js 合并压缩的实例
2016/10/14 Javascript
AngularJS实现动态编译添加到dom中的方法
2016/11/04 Javascript
详细讲解vue2+vuex+axios
2017/05/27 Javascript
使用JavaScript实现链表的数据结构的代码
2017/08/02 Javascript
Mac下安装vue
2018/04/11 Javascript
如何利用@angular/cli V6.0直接开发PWA应用详解
2018/05/06 Javascript
微信小程序上传图片功能(附后端代码)
2020/06/19 Javascript
vue动态改变背景图片demo分享
2018/09/13 Javascript
layui 点击重置按钮, select 并没有被重置的解决方法
2019/09/03 Javascript
解决Element中el-date-picker组件不回填的情况
2020/11/07 Javascript
[01:51]2014DOTA2国际邀请赛 这个赛场没有失败者VGTi5再见
2014/07/23 DOTA
python解析xml文件操作实例
2014/10/05 Python
Python实现字典的key和values的交换
2015/08/04 Python
python基础教程之匿名函数lambda
2017/01/17 Python
python微信跳一跳系列之棋子定位颜色识别
2018/02/26 Python
批量将ppt转换为pdf的Python代码 只要27行!
2018/02/26 Python
python 处理dataframe中的时间字段方法
2018/04/10 Python
Django利用cookie保存用户登录信息的简单实现方法
2019/05/27 Python
芬兰灯具网上商店:Nettilamppu.fi
2018/06/30 全球购物
迪卡侬波兰体育用品商店:Decathlon波兰
2020/03/31 全球购物
2016年小学生寒假总结
2015/10/10 职场文书
Go 在 MongoDB 中常用查询与修改的操作
2021/05/07 Golang
Node与Python 双向通信的实现代码
2021/07/16 Javascript