在项目目录中保存php会话时出错

问题描述 投票:1回答:3

在我的项目配置文件中,我有:

session:
        handler_id:  session.handler.native_file
        save_path:   "%kernel.root_dir%/../var/sessions/%kernel.environment%"

"%kernel.root_dir%/../var/sessions属于wwww-data(是的,php-fpm正在运行www-data)。

当项目运行时,在该目录中创建(空)会话文件,但显然php / symfony实际上无法读取/写入它,尽管能够正确创建它。这是刚创建的空会话文件(此请求后没有其他进程运行):

session file, created

该请求死于引发异常:

会话数据文件不是由您的uid创建的。

我发现这个answer(和this一个),并通过这样做(将我的会话的save_path设置为"/var/lib/php/sessions"我能够继续(我可以看到我的会话文件不仅被创建,但其内容实际上已到位) ,但我试图理解为什么它无法在自定义位置保存会话文件。

在我的PHP配置中,我看到我将session.save_path设置为/var/lib/php/session,但我希望我能够在执行时覆盖它。

真正让我感到困惑的是会话文件被创建(因此文件权限应该没问题),但是没有写入。

我在nginx + php-fpm(7.0)之上运行Symfony 3.2.2。

为什么会这样?有没有我应该使用的其他设置,所以PHP可以覆盖此配置并将其会话文件写在别处?

从跟踪中我看到:

  • NativeSessionStorage ->start()被调用,并执行session_start(返回true)
  • 然后调用SessionHandlerProxy ->read($sessionId),并在调用$this->handler->read($sessionId);时抛出异常。
php session symfony fpm
3个回答
3
投票

我能够重现相同的确切错误,创建会话文件,但抛出“会话数据文件不是由你的uid创建的。”,但我不确定这是不是你的情况。

无论如何,我的猜测是你使用nfs服务器来保存你的代码,但你在本地开发和运行nginx。您对服务器目录进行了nfs安装,以将您的代码同步到服务器(我之前的工作中也有相同的内容)。

因此,您将nfs服务器目录挂载到本地目录。会发生什么是php用用户www-data创建你的会话文件,但是这个用户在服务器上有一个不同于本地机器的uid。所以创建文件,你看到正确的所有者,但它的uid是不同的。

校验:

link

link

这只是我最好的猜测。如果是这样,请告诉我,也许我可以帮助nfs用户映射。希望能帮助到你。


-1
投票

如果要使用文件来保存会话,最佳做法是在与Web文件相同的所有者的目录中进行,而不是在“common”文件夹中。例如,这可能意味着从web root开始的一个目录:

  • /家/ myuser的/会话/
  • /家/ myuser的/的public_html /

这样,您的会话是安全的(无法从Web访问),与同一服务器中其他Web的会话分开,您确信可以管理该目录中的文件。


-1
投票

使用标准文件夹,即:/var/lib/php/session

避免使用/tmp

© www.soinside.com 2019 - 2024. All rights reserved.