我正在运行 Discourse 的自托管实例 forum.embeetle.com。它已经运行了好几年了。
今天早上,我注意到浏览器中与论坛的所有键盘和鼠标交互都停止工作了。我可以加载论坛的任何页面,但无法滚动、登录、搜索……
我尝试了 Firefox 和 Chromium:问题相同。
Firefox 开发者工具显示此错误:
Content-Security-Policy: 页面设置阻止了内联资源(“script-src”)的加载。forum.embeetle.com:362:10
我最近没有进行任何更新或安装任何新插件。
有什么建议可以帮助我调试和修复这个问题吗?
据我所知,我有一个标准的基于 docker 的安装,除了我将它运行在一个 Nginx 反向代理后面。Nginx 配置如下(不确定它是否相关):
server {
server_name forum.embeetle.com;
listen 443 ssl http2;
listen [::]:443 ssl http2;
ssl_certificate /etc/letsencrypt/live/embeetle/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/embeetle/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf;
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
access_log /var/log/nginx/forum.embeetle.access.log;
error_log /var/log/nginx/forum.embeetle.error.log;
location / {
proxy_pass http://unix:/srv/embeetle_forum/discourse/shared/standalone/nginx.http.sock:;
proxy_set_header Host $http_host;
proxy_http_version 1.1;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Real-IP $remote_addr;
error_page 502 =502 /error/offline.html;
proxy_intercept_errors on;
}
location /error/ {
alias /srv/embeetle_forum/error/;
}
}
server {
server_name forum.embeetle.com;
listen 80;
listen [::]:80;
return 301 https://$host$request_uri;
}



