Nginx HHVM Wordpress 在一个中间子目录中执行 PHP 的问题

Nginx HHVM Wordpress 在一个中间子目录中执行 PHP 的问题

我的一个网站出现了奇怪的情况,仍在 AWS 上开发。我在 t2.micro 上安装了 nginx 1.9.9 和 HHVM 3.6.6-1.amzn1.x86_64。它不可公开访问。

我在域的根目录中有一个自定义网站,在 /blog 目录中有 Wordpress,Wordpress 管理员在 /blog/wp-admin 中。自定义网站有各种文件,包括 index.php。Wordpress 在博客目录中有 index.php 和各种其他内容,wp-admin 也使用 index.php。

我可以加载自定义网站,它完全正常运行。Wordpresss 管理员完全正常运行。Wordpress 博客主屏幕/故事列表完全正常运行。问题当我点击任何博客文章链接查看全文时,它会显示自定义网站主页索引。换句话说

http://www.example.com/index.php  - custom website works
http://www.example.com/blog/index.php  - blog index works
http://www.example.com/blog/2015/storyname - story load doesn't work with permalink %postname% regardless of text in post name - http://www.example.com/index.php loads
http://www.example.com/blog/2015/?p=96 - story load works
http://www.example.com/blog/wp-admin/ - admin works

当我点击故事链接时,我得到的页面内容与我点击http://www.example.com/index.php但图片无法加载,因为它们是用相对 URL 加载的

http://www.example.com/blog/2015/storyname

当我加载站点根目录 /index.php 时,我会得到以下调试标头(请参阅下面的配置以了解它们是如何生成的)

Z_LOCATION: PHP MAIN
URI: /index.php
Z_DOCUMENT_ROOT: /var/www/hr
Z_FASTCGI_SCRIPT_NAME: /index.php
Z_REQUEST_FILENAME: /var/www/hr/index.php

当我加载 /wp-admin/ 时,我会得到这些标头

Z_LOCATION: PHP MAIN
URI: /blog/wp-admin/index.php
Z_DOCUMENT_ROOT: /var/www/hr
Z_FASTCGI_SCRIPT_NAME: /blog/wp-admin/index.php
Z_REQUEST_FILENAME: /var/www/hr/blog/wp-admin/index.php

当我加载博客主页 /blog/index.php 时,我会得到这些标题

Z_LOCATION: PHP MAIN
URI: /blog/index.php
Z_DOCUMENT_ROOT: /var/www/hr
Z_FASTCGI_SCRIPT_NAME: /blog/index.php
Z_REQUEST_FILENAME: /var/www/hr/blog/index.php

当我尝试加载此 URL 时http://www.example.com/blog/2015/storyname我收到了以下标题。Z_REQUEST_FILENAME(以上)显示正在加载错误的 URL。

Z_LOCATION: PHP MAIN
URI: /index.php
Z_DOCUMENT_ROOT: /var/www/hr
Z_FASTCGI_SCRIPT_NAME: /index.php
Z_REQUEST_FILENAME: /var/www/hr/index.php

我不知道为什么当我单击该 URL 时它会尝试加载站点根目录 index.php。线索:

  • 将 Wordpress 永久链接结构从 %postname% 更改为 ?p=123 修复问题
  • 其他永久链接结构都毫无帮助

为什么仅仅查看博客文章就会出现这个问题?我想知道这是否与 try_files 有关?

hhvm 错误日志中没有任何内容,nginx 错误日志中也没有任何内容。当我请求最后一个 URL 时,访问日志显示以下内容

(IP removed) - - [10/Jan/2016:08:22:19 +0000] "GET /blog/2015/storyname HTTP/1.1" 200 4424 "http://www.example.com/blog/" "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:43.0) Gecko/20100101 Firefox/43.0" "-" "0.050"

这是我的 nginx 站点配置。我没有包含主 nginx.conf,因为我认为它不相关。注意:我已更新了这项工作的工作代码。

server {
  server_name www.example.com;
  root /var/www/hr;
  access_log      /var/log/nginx/hr.access.log main;

  # Default location to serve
  location / {
    try_files $uri $uri/ /blog/index.php?$args;
    add_header Z_LOCATION "hr_root"; add_header URI $uri; # DEBUG
  }

  location ~*      \.(jpg|jpeg|png|gif|css|js)$ {
    log_not_found off; access_log off;
    add_header Z_LOCATION "STATIC RESOURCES REGEX"; add_header URI $uri;      # DEBUG
  }

  # Send HipHop and PHP requests to HHVM
  location ~ \.(hh|php)$ {
    fastcgi_keep_conn on;
    fastcgi_intercept_errors on;
    fastcgi_pass       php;
    include                        fastcgi_params;
    fastcgi_param      SCRIPT_FILENAME $document_root$fastcgi_script_name;

    # DEBUGGING
    add_header Z_LOCATION "PHP MAIN"; add_header URI $uri;
    add_header Z_DOCUMENT_ROOT "$document_root"; add_header Z_FASTCGI_SCRIPT_NAME "$fastcgi_script_name";
    add_header Z_REQUEST_FILENAME "$request_filename";
  }
}

# Forward non-www requests to www
server {
  listen 0;
  server_name example.com;
  return 302 http://www.example.com$request_uri;
}

任何想法、意见或帮助都值得感激。对我来说,这是一个相当棘手的问题,但我认为只需进行简单的更改即可解决。

答案1

WordPress 内容交付由脚本执行。据推测,由于中的子句,/blog/index.php当您发送 URI 时会调用此脚本。但是对于以 开头的任何其他 URI,您没有规则可以调用。/blog/$uri/try_files/blog/index.php/blog/...

一种选择是将 WorkPress 设为默认设置:

location / {
    try_files $uri $uri/ /blog/index.php?$args;
    ...
}

或者,添加另一个位置块来仅处理以 开头的 URI /blog/...

location /blog {
    try_files $uri $uri/ /blog/index.php?$args;
    ...
}

相关内容