英文:
Containerized PHP application sessions directory is empty
问题
我们正在将一个PHP网站从旧主机迁移到容器中。旧代码直接在虚拟机上运行,现在我们建立了一个容器来支持PHP网站。新旧PHP网站都在Apache HTTPD上运行,PHP版本为5.4.16。
然而,这个网站有一个特性,它将用户会话保存在/var/lib/php/session
下,但在我们的新容器版本中无法正常工作。即使有活动会话,这个目录似乎总是空的。我们已经检查了以下内容:
- 旧站点和新站点之间的
session
配置似乎相同(以下是配置信息) - 我们已验证
apache
用户是/var/lib/php/session
目录的所有者 - 在PHP错误日志中,似乎没有任何指示为什么会话没有保存的信息
我对PHP不太熟悉,不知道如何进一步调试,只是想看看是否可以得到一些帮助。
- 有没有可能忘记安装任何允许会话持久化的模块?
- 为什么没有任何指示会话未保存的日志?我是否需要启用更多日志记录来观察发生了什么?
- 会话是否未保存,还是超时并被删除?是否有某个设置可以导致这种情况?
我们的配置:
会话支持:已启用
已注册的保存处理程序:文件 用户
已注册的序列化处理程序:php php_binary
session.auto_start:已关闭
session.cache_expire:180
session.cache_limiter:nocache
session.cookie_domain:没有值
session.cookie_httponly:已关闭
session.cookie_lifetime:0
session.cookie_path:/
session.cookie_secure:已关闭
session.entropy_file:/dev/urandom
session.entropy_length:32
session.gc_divisor:1000
session.gc_maxlifetime:1440
session.gc_probability:1
session.hash_bits_per_character:5
session.hash_function:0
session.name:PHPSESSID
session.referer_check:没有值
session.save_handler:文件
session.save_path:/var/lib/php/session
session.serialize_handler:php
session.upload_progress.cleanup:已启用
session.upload_progress.enabled:已启用
session.upload_progress.freq:1%
session.upload_progress.min_freq:1
session.upload_progress.name:PHP_SESSION_UPLOAD_PROGRESS
session.upload_progress.prefix:upload_progress_
session.use_cookies:已启用
session.use_only_cookies:已启用
session.use_trans_sid:0
英文:
We are migrating a PHP website from an old host to a container. The old code runs on VM directly, now we built a container that facilitate the PHP website. Both old and new PHP website run on top of apache httpd with php version 5.4.16.
However, there's a feature of this website that saves user session under /var/lib/php/session
that does not work in our new, containerized version. The directory seems to always be empty even if there are active sessions. We have checked the following:
- The
session
configuration seems identical between the old and new site (pasting the config below) - We verified
apache
user is the owner of/var/lib/php/session
directory - In php error logs, there doesn't seem to be anything indicating why the sessions are not saved
I am not familiar with PHP and don't know how I could debug this further, just checking if I can get some help on this.
- Any chance we forgot to install any module that would allow session persistent?
- Why would there not be any logs indicating the sessions not being saved? Do I need to somehow enable more logging to observe what is happening?
- Was the session not saved or did it timeout and get wiped? Is there such setting somewhere that can cause this?
Our configuration
Session Support: enabled
Registered save handlers: files user
Registered serializer handlers: php php_binary
session.auto_start: Off
session.cache_expire: 180
session.cache_limiter: nocache
session.cookie_domainno value
session.cookie_httponly: Off
session.cookie_lifetime: 0
session.cookie_path: /
session.cookie_secure: Off
session.entropy_file: /dev/urandom
session.entropy_length: 32
session.gc_divisor: 1000
session.gc_maxlifetime: 1440
session.gc_probability: 1
session.hash_bits_per_character: 5
session.hash_function: 0
session.name: PHPSESSID
session.referer_check: no value
session.save_handler: files
session.save_path: /var/lib/php/session
session.serialize_handler: php
session.upload_progress.cleanup: On
session.upload_progress.enabled: On
session.upload_progress.freq: 1%
session.upload_progress.min_freq: 1
session.upload_progress.name: PHP_SESSION_UPLOAD_PROGRESS
session.upload_progress.prefix: upload_progress_
session.use_cookies: On
session.use_only_cookies: On
session.use_trans_sid: 0
答案1
得分: 0
我们的脚本在将容器以root用户运行后修复了/var/lib/php/session
的权限问题。
英文:
Turns out our script messed around the permission of /var/lib/php/session
after having the container run as root it straighten things out
通过集体智慧和协作来改善编程学习和解决问题的方式。致力于成为全球开发者共同参与的知识库,让每个人都能够通过互相帮助和分享经验来进步。
评论