請容許我解釋一下我的問題。我有一個運行 18.04 的 Ubuntu VPS 伺服器 我已經使用 php-fpm 安裝了 Nginx 和 Apache 我已將 Nginx 配置為我的 WordPress 部落格的反向代理,位於https://mydomainname.com/blog這一切都工作正常。但是我無法讓我的永久連結為我的伺服器區塊工作我的配置:
server {
listen 80;
return 301 https://%host$request_uri;
}
server {
listen 443 ssl;
root /var/www/mydomain.com/;
server_name mydomain.com www.mydomain.com;
ssl_certificate /etc/letsencrypt/live/mydomain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/mydomain.com/privkey.pem;
ssl on;
ssl_session_cache builtin:1000 shared:SSL:10m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
ssl_prefer_server_ciphers on;
access_log /var/log/nginx/site.access.log;
location /blog/ {
index index.php index.html index.htm;
try_files $uri $uri/ /blog/index.php?q=$uri&$args =404;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# Fix the “It appears that your reverse proxy set up is broken" error.
proxy_pass http://127.0.0.1:8080;
proxy_read_timeout 90;
proxy_redirect off;
}
}
我的 Apache 虛擬主機配置:
<VirtualHost 127.0.0.1:8080>
ServerName mydoamin.com
ServerAlias www.mydomain.com
DocumentRoot /var/www/mydomain.com
<FilesMatch "\.php$">
SetHandler "proxy:unix:///var/run/php7.2-fpm-mydomain.sock|fcgi://127.0.0.1/"
</FilesMatch>
<Directory /var/www/mydomain.com>
Options Indexes FollowSymLinks MultiViews
Require all granted
AllowOverride All
</Directory>
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
我的 .htaccess 文件
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /blog/
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /blog/index.php [L]
</IfModule>
任何幫助表示讚賞。
答案1
我現在已經解決了這個問題。問題是我忘記為 Apache 啟用 Mod-ReWrite。我還將我的 Nginx Conf 更新為:
server {
listen 80;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl;
root /var/www/mydomain.com/;
#index index.html index.htm index.php;
server_name mydomain.com www.mydomain.com;
ssl_certificate /etc/letsencrypt/live/mydomain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/mydomain.com/privkey.pem;
ssl on;
ssl_session_cache builtin:1000 shared:SSL:10m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
ssl_prefer_server_ciphers on;
access_log /var/log/nginx/mydomain.access.log;
location / {
return 301 https://$host/blog/;
}
location /blog/ {
index index.php index.html index.htm;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# Fix the “It appears that your reverse proxy set up is broken" error.
proxy_pass http://127.0.0.1:8080;
proxy_read_timeout 90;
proxy_redirect off;
}
}