Symfony2:跳转到生产环境失败

Symfony2:跳转到生产环境失败,symfony,deployment,Symfony,Deployment,部署到生产环境失败,我在app/log/prod.log中看到一个空白页面,没有登录 我预热了prod缓存,并将cahce dirs的所有权授予了www数据,也没有php日志记录,但这可能是一个管理错误,我要求对其进行检查,因为我没有访问权限 < >我改变了我的HTAccess,省略了APPYDEV.PHP并考虑了APP.PHP,这是我的.HTAccess: # Use the front controller as index file. It serves as fallback solut

部署到生产环境失败,我在app/log/prod.log中看到一个空白页面,没有登录

我预热了prod缓存,并将cahce dirs的所有权授予了www数据,也没有php日志记录,但这可能是一个管理错误,我要求对其进行检查,因为我没有访问权限

< >我改变了我的HTAccess,省略了APPYDEV.PHP并考虑了APP.PHP,这是我的.HTAccess:

# Use the front controller as index file. It serves as fallback solution when
# every other rewrite/redirect fails (e.g. in an aliased environment without
# mod_rewrite). Additionally, this reduces the matching process for the
# startpage (path "/") because otherwise Apache will apply the rewritting rules
# to each configured DirectoryIndex file (e.g. index.php, index.html, index.pl).
DirectoryIndex app.php
#DirectoryIndex app_dev.php

<IfModule mod_rewrite.c>
    RewriteEngine On

    # Redirect to URI without front controller to prevent duplicate content
    # (with and without `/app.php`). Only do this redirect on the initial
    # rewrite by Apache and not on subsequent cycles. Otherwise we would get an
    # endless redirect loop (request -> rewrite to front controller ->
    # redirect -> request -> ...).
    # So in case you get a "too many redirects" error or you always get redirected
    # to the startpage because your Apache does not expose the REDIRECT_STATUS
    # environment variable, you have 2 choices:
    # - disable this feature by commenting the following 2 lines or
    # - use Apache >= 2.3.9 and replace all L flags by END flags and remove the
    #   following RewriteCond (best solution)
    RewriteCond %{ENV:REDIRECT_STATUS} ^$
    #RewriteRule ^app_dev\.php(/(.*)|$) %{CONTEXT_PREFIX}/$2 [R=301,L]
    RewriteRule ^app\.php(/(.*)|$) %{CONTEXT_PREFIX}/$2 [R=301,L]

    # If the requested filename exists, simply serve it.
    # We only want to let Apache serve files and not directories.
    RewriteCond %{REQUEST_FILENAME} -f
    RewriteRule .? - [L]


    RewriteCond %{REQUEST_FILENAME} -f
    #RewriteRule ^(.*)$ app_dev.php [QSA,L]
    RewriteRule ^(.*)$ app.php [QSA,L]

    # The following rewrites all other queries to the front controller. The
    # condition ensures that if you are using Apache aliases to do mass virtual
    # hosting, the base path will be prepended to allow proper resolution of the
    # app.php file; it will work in non-aliased environments as well, providing
    # a safe, one-size fits all solution.
    RewriteCond %{REQUEST_URI}::$1 ^(/.+)(.+)::\2$
    RewriteRule ^(.*) - [E=BASE:%1]
    #RewriteRule .? %{ENV:BASE}app_dev.php [L]
    RewriteRule .? %{ENV:BASE}app.php [L]
</IfModule>

<IfModule !mod_rewrite.c>
    <IfModule mod_alias.c>
        # When mod_rewrite is not available, we instruct a temporary redirect of
        # the startpage to the front controller explicitly so that the website
        # and the generated links can still be used.
        #RedirectMatch 302 ^/$ /app_dev.php/
        RedirectMatch 302 ^/$ /app.php/
        # RedirectTemp cannot be used instead
    </IfModule>
</IfModule>
#将前控制器用作索引文件。当发生以下情况时,它可作为后备解决方案:
#每隔一次重写/重定向都会失败(例如,在没有
#修改(重写)。此外,这还减少了对象的匹配过程
#startpage(路径“/”),否则Apache将应用重写规则
#到每个配置的DirectoryIndex文件(例如index.php、index.html、index.pl)。
DirectoryIndex app.php
#DirectoryIndex应用程序_dev.php
重新启动发动机
#重定向到不带前端控制器的URI以防止重复内容
#(带或不带“/app.php”)。仅在初始路径上执行此重定向
#由Apache重写,而不是在后续周期中重写。否则我们会被解雇
#无休止的重定向循环(请求->重写到前端控制器->
#重定向->请求->…)。
#所以,如果你得到一个“太多重定向”错误或你总是得到重定向
#因为您的Apache没有公开重定向的状态
#环境变量,您有两种选择:
#-通过注释以下两行或两行禁用此功能
#-使用Apache>=2.3.9,用结束标志替换所有L标志,并删除
#第二步(最佳解决方案)
RewriteCond%{ENV:REDIRECT_STATUS}^$
#重写规则^app_dev\.php(/(.*)|$)%{CONTEXT_PREFIX}/$2[R=301,L]
重写规则^app\.php(/(.*)|$)%{CONTEXT_PREFIX}/$2[R=301,L]
#如果请求的文件名存在,只需提供它即可。
#我们只想让Apache服务于文件,而不是目录。
RewriteCond%{REQUEST_FILENAME}-f
重写规则[L]
RewriteCond%{REQUEST_FILENAME}-f
#重写规则^(.*)$app_dev.php[QSA,L]
重写规则^(.*)$app.php[QSA,L]
#下面将所有其他查询重写到前端控制器。这个
#条件确保,如果您使用Apache别名进行大规模虚拟
#宿主时,将预先设置基本路径,以允许正确解析
#php文件;它也可以在无别名的环境中工作,提供
#一个安全、一刀切的解决方案。
RewriteCond%{REQUEST_URI}:$1^(/.+)(.+):\2$
重写规则^(.*)-[E=基:%1]
#重写规则.?%{ENV:BASE}app_dev.php[L]
重写规则.?%{ENV:BASE}app.php[L]
#当mod_rewrite不可用时,我们指示临时重定向
#将起始页显式地发送到前端控制器,以便网站
#生成的链接仍然可以使用。
#重定向匹配302^/$/app_dev.php/
重定向匹配302^/$/app.php/
#不能改为使用RedirectTemp

有什么线索吗?

这是一个假设,但如果您的开发环境正常工作,而不是您的产品(在同一个项目和机器上),这是因为您忘记在web/app.php中添加“umask(0000);”

PHP致命错误:require():无法打开required “/var/www/symfony/app/cache/prod/doctrine/orm/Proxies/\u CG\u MyProjectPanelBundleEn‌​tityAlgoritmo.php' (包括_path='。:/usr/share/php:/usr/share/pear') /var/www/symfony/vendor/doctrine/common/lib/doctrine/common/Proxy/AbstractProxyF‌​actory.php 在线165

这显然是文件夹app/cache(和app/logs)的权限和所有权问题

我将cahce目录的所有权授予了www数据

根据您使用ACL的实际情况,您不能这样做,请检查。有很多解决方案可以解决这个问题,在灰色框架中解释

如果您不使用ACL,要解决您的问题,我认为最简单的方法是在app.php中添加“umask(0000);”(您可能在app_dev.php中这样做了),在文件的开头和“use”声明之后添加“umask(0000);”。(请参见灰色框架中的“3.不使用ACL”)。否则,请阅读灰色框架的其他说明

现在,该框架将来将能够在缓存文件夹中进行写操作但如果不使用ACL,则还需要更正当前的应用程序/缓存和应用程序/日志文件夹配置:

考虑到您的用户名是“user”,请在root中说用户组“user”(通常与Linux计算机上的用户名相同)的用户“user”是这些文件夹(以及子文件夹/文件)的所有者:

然后清除这些文件夹,以确保没有损坏或丢失的文件(作为“用户”):

授予文件夹777权限,以便框架能够在其中写入:

chmod 777 -R app/cache app/logs

此外,即使您可能这样做了,也要检查您的应用程序/控制台文件是否包含umask(0000);未注释,因为如果您错过它,symfony控制台将以www数据的形式写入文件,并且您无法读取缓存文件文件夹(您将遇到相同的错误)

您的数据库架构是最新的吗

php app/console doctrine:schema:update --dump-sql
我对类似的情况进行了两次试验,并以相同的方式解决了问题:

我在同一个项目的另一个捆绑包中有一个正在进行的工作,与发生错误的部分没有交互。实际上,我没有更新我的数据库模式


希望这能有所帮助

apache错误日志中的错误是什么?PHP致命错误:require():无法打开required'/var/www/symfony/app/cache/prod/doctrine/orm/Proxies/\uuuuuuuuucg\uuuMyProjectPanelBundleEntityAgoritmo.PHP'(include\u path=':/usr/share/PHP:/usr/share/pear')在第165I行的/var/www/symfony/vendor/doctor/common/lib/doctor/common/Proxy/AbstractProxyFactory.php中,我没有ACL,我已经有了
umask(0000)
在3个文件的开头,我做了
chown
chmod
这是我在日志中看到的新错误:>php致命错误:未捕获异常“Refle”
chmod 777 -R app/cache app/logs
php app/console doctrine:schema:update --dump-sql