当我我的Symfony2项目cap deploy
,然后登录到我的服务器我看到开发(app_dev.php)运行正常,但prod版本(app.php)没有。资本和目录所有者
的错误是
[Tue Jan 03 14:31:48 2012] [error] [client xxx.xxx.xxx.xxx] PHP Fatal error: Uncaught exception 'RuntimeException' with message 'Failed to write cache file "/var/www/example/prod/releases/20120103202539/app/cache/prod/classes.php".' in /var/www/example/prod/releases/20120103202539/app/bootstrap.php.cache:1079\nStack trace:\n#0 /var/www/example/prod/releases/20120103202539/app/bootstrap.php.cache(1017): Symfony\\Component\\ClassLoader\\ClassCollectionLoader::writeCacheFile('/var/www/example/p...', '<?php ????name...')\n#1 /var/www/example/prod/releases/20120103202539/app/bootstrap.php.cache(682): Symfony\\Component\\ClassLoader\\ClassCollectionLoader::load(Array, '/var/www/example/p...', 'classes', false, false, '.php')\n#2 /var/www/example/prod/releases/20120103202539/web/app.php(10): Symfony\\Component\\HttpKernel\\Kernel->loadClassCache()\n#3 {main}\n thrown in /var/www/example/prod/releases/20120103202539/app/bootstrap.php.cache on line 1079
在最近部署的缓存目录中查找我看到:
drwxrwxrwx 4 root root 4096 Jan 3 14:28 .
drwxrwxr-x 5 root root 4096 Jan 3 14:28 ..
drwxr-xr-x 6 www-data www-data 4096 Jan 3 14:28 dev
drwxrwxr-x 7 root root 4096 Jan 3 14:28 prod
我可以解决这个问题有chown -R www-data.www-data prod/
,但我不知道是否可以从阻止这种情况发生第一名?为什么这些目录有不同的所有者?
谢谢,听起来像我所需要的。我不明白的是为什么开发目录由www-data拥有。 Capifony以服务器上的root用户身份运行,所以我猜php正在尝试创建缓存文件(而不是root用户)? – ed209 2012-01-05 18:47:13
'cache/dev' dir是由运行CLI版本的php创建的,这个版本与运行web服务器的用户不同。 'cache/prod'正在运行,因为它将由网络服务器运行。这是我的理解:) – 2012-01-05 19:25:21
我明白你的意思,虽然看着目录所有者,我会说这是另一种方式,/ prod归root所有,/ dev归属于www-data? – ed209 2012-01-06 14:49:14