所以应用程序没有对缓存做任何事情,我只是使用config.yml中的默认框架设置
framework:
# ...
session: ~
查看
project/app/cache/prod/session
目录我看到6个月前的会话文件,导致DISK FULL错误/问题。
如果我运行命令
df -h
如果我运行命令
,磁盘空间看起来很好df -i
我看到它已满或几乎已满
对于php.ini它是所有默认设置,运行ubuntu 12.04 LTS和PHP 5.3.x
为什么垃圾收集不起作用?当我清除缓存时它很好并且清理但据我所知,会话应该在4小时后删除,有什么想法吗?
答案 0 :(得分:5)
如果其他人有这个问题,请问如何修复它:
以下是
中配置的内容(三者都相同)
session.gc_probability = 0
session.gc_divisor = 1000
session.gc_maxlifetime = 1440
我也参观了
/etc/cron.d/php5
它应该使用此值session.gc_maxlifetime
# /etc/cron.d/php5: crontab fragment for php5
# This purges session files older than X, where X is defined in seconds
# as the largest value of session.gc_maxlifetime from all your php.ini
# files, or 24 minutes if not defined. See /usr/lib/php5/maxlifetime
# Look for and purge old sessions every 30 minutes
09,39 * * * * root [ -x /usr/lib/php5/maxlifetime ] && [ -d /var/lib/php5 ] && find /var/lib/php5/ -depth -mindepth 1 -maxdepth 1 -type f -cmin +$(/usr/lib/php5/maxlifetime) -delete
问题是我的会话不在标准位置,因此没有清理。
将framwerwork会话save_path配置为:
/var/lib/php5
您还可以通过将值设置为null来将此值设置为php.ini的save_path:
# app/config/config.yml
framework:
session:
save_path: null
文档: