技术解析

遭遇离奇的 Nginx 错误
0
2021-05-25 15:10:00
idczone

最近把 VPS 上的 Apache 换成了 Nginx 。 VPS 上有两个网站,其中一个是 Ghost+Nginx 反代,没有任何问题。还有一个 WordPress ,假设域名是 www.example.com ,访问的时候一直都会跳转到 www.example.com/mail ,然后返回 404.如果建一个 mail 目录。把网站放进去,就可以正常访问。但是就是搞不懂为什么会跳转到 /mail 。
这是我的配置文件:

server {
    listen 45.117.100.000:80;
    listen 45.117.100.000:443 ssl;
    server_name www.example.com;

    ssl_certificate /path/to/cert.crt;
    ssl_certificate_key /path/to/private.key;
    ssl_protocols SSLv3 TLSv1;
    ssl_ciphers ALL:-ADH:+HIGH:+MEDIUM:-LOW:-SSLv2:-EXP;

    root /var/www/html;

    location / {
        index index.html index.htm index.php;

        if (!-e $request_filename) {
            rewrite . /index.php last;
        }
    }

loc抗投诉服务器ation ~ \.php$ {
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME /var/www/html$fastcgi_script_name;
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
    }

还有,电脑上任何浏览器都访问正常,但是手机上访问 https 却提示无法建立安全的连接。

是不是 wordpress 设置了 mail 是首页?

没有。但是如果设置了 mail 是首页倒是可以正常打开。

curl -I 域名
然后查 nginx 日志

你后端是 PHP ? index.php?里面写的是啥 ?

你是放到 root /var/www/html 目录下么?

ssl_protocols SSLv3 TLSv1;
ssl_ciphers ALL:-ADH:+HIGH:+MEDIUM:-LOW:-SSLv2:-EXP;
这 2 行配置可以删了,并没有什么好处。

server {
listen 80;
server_name www.tntsec.com;
root /var/www/html/tntsec;
index index.php index.html index.htm;
location ~ .*\.php(\/.*)*$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}

和 SSL 没有关系
在你这个 conf 里面没有看到任何地方和 mail 有关,建议检查下 nginx.conf 有没嵌套别的东西

我估计 LZ 曾经装过类似 squirrelmail 或者 roundcube 之类的东西,它们有时会在 nginx.conf 里添加 include ,建议检查下 nginx.conf 嵌套的所有配置文件

fastcgi_param SCRIPT_FILENAME /var/www/html$fastcgi_script_name
这一行改成 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

是的
就是 WordPress 自带的 index.php

以前用 Apache 的时候装过,后来删了。现在重新编译安装 Nginx 了,还会自动在 Nginx 里 include 吗?

html 目录下要给个网站建个独立文件夹,还有 ls 站点配置文件到对应的目录是否正确?

/var/www/html$fastcgi_script_name;

检查一下配置文件

问题出在 nginx 或者 php ( Wordpress )身上,但是 nginx 本身不是很好调试,所以先排除是不是 php 的问题
在 /var/www/html 下的 index.php 最前面添加
然后用命令行 curl 或者其它别的可以看网络连接的浏览器(如 firefox firebug 或 chrome 的调试窗口),记住千万不要用之前的浏览器,因为 301 跳转会被浏览器缓存下来,最好用 curl ,看一下返回的状态码是否为 200(curl -i http://www.example.com), 如果不是 200 ,那么在 Wordpress 中找原因,如果是 200 ,重新编译一个--with-debug 的 nginx ,然后将 debug 日志打印出来看 nginx 哪里配置有问题

建议检查一下 php 的配置文件。如果 OS 是 ubuntu ,文件是 /etc/php5/fpm/pool.d/www.conf
看一下 chroot 这一行。

数据地带为您的网站提供全球顶级IDC资源