如何解决通过Nginx Web服务器上的子域代理的Nextcloud Docker容器上的502错误网关错误 第一个解决方案:第二个解决方案:
我正在RaspBerry Pi 4上运行Nginx Web服务器。我正在尝试在子域上为Nextcloud Docker容器配置反向代理。但是,当我尝试在浏览器中访问此容器时,出现了502 Bad Gateway错误。我已经确定要为要在其上托管Nextcloud的子域生成SSL证书。
这是我的子域的服务器块的样子:
server {
listen 443 ssl;
server_name subdomain.domain.tld;
ssl_certificate /pathtokey/subdomain.domain.tld/fullchain.pem;
ssl_certificate_key /pathtokey/subdomain.domain.tld/privkey;
location / {
proxy_pass https://127.0.0.1:9000/;
proxy_ssl_server_name on;
}
}
这是我用于Nextcloud的docker-compose.yml文件的样子:
version: '2'
volumes:
nextcloud:
db:
services:
db:
image: linuxserver/mariadb
# command: --transaction-isolation=READ-COMMITTED --binlog-format=ROW
restart: always
volumes:
- db:/var/lib/MysqL
environment:
- MysqL_ROOT_PASSWORD=<rootPassword>
- MysqL_PASSWORD=<MysqLPassword>
- MysqL_DATABASE=nextcloud
- MysqL_USER=nextcloud
app:
image: nextcloud:fpm
ports:
- 127.0.0.1:9000:9000
links:
- db
volumes:
- /mnt/hdd/nextcloud:/var/www/html
restart: always
更改.yml文件后,请确保运行docker-compose up -d。 更改Nginx.conf文件后,我运行sudo systemctl重新启动Nginx。我还运行了sudo Nginx -t。
Nginx: the configuration file /etc/Nginx/Nginx.conf Syntax is ok
Nginx: configuration file /etc/Nginx/Nginx.conf test is successful
我不确定这些配置在哪里出错。对于如何解决此问题,我将不胜感激。
解决方法
您正在使用nextcloud:apache
映像,该映像只是一个不带Web服务器的php fpm实例。
您的nginx代理配置很好,但是将不起作用,因为您将需要nginx {{1}}才能将请求代理到后端php实例。
这是一个简单的例子:
nginx(fastcgi) php-fpm(nextcloud)数据库
第一个解决方案:
有关如何配置nginx或仅复制配置,请参考nextcloud官方文档:nginx configuration
第二个解决方案:
使用{{1}}图片代替。该图像已经包含一个apache Web服务器,您无需其他nginx实例即可直接访问它。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。