我的一个网站出现了奇怪的情况,仍在 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;
...
}