如何解决NGINX与certbot将https URL请求转发到api和dockerized react app
我正在Digital Ocean Droplet的Ubuntu 18.04 LTS Bionix上运行NGINX。我有一个dockerized React应用程序,使用http时可以成功访问并与dockerized Flask / Quart应用程序一起使用。可以在示例:8000处访问React App,在示例:9000处访问Quart。 2沟通很好。
现在,当使用NGINX和常用的certbot方法设置https时(感谢您的教程:Digital Ocean tutorial),我得到的错误并不能完全告诉我发生了什么。
完成本教程并成功显示/var/www/example/index.html中https://www.example.com处的html文件后,我尝试使用https://www.example.com/app来访问可在http 8000和我可以在http 9000上通过标准文档页面访问的/ api网站。
React App在浏览器选项卡中按预期显示标题,但未显示任何内容。从css块中只有404错误说“无法加载资源”。
API也失败,无法加载资源。
根据迄今为止的研究,唯一更改的NGINX配置如下:
# /etc/nginx/sites-enabled/example
server {
root /var/www/example.com/html;
index index.html index.htm index.nginx-debian.html;
server_name example.com www.example.com;
location / {
try_files $uri $uri/ =404;
}
location /app {
proxy_pass http://localhost:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
location /api {
proxy_pass http://localhost:9000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
listen [::]:443 ssl ipv6only=on; # managed by Certbot
listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}
server {
if ($host = www.example.com) {
return 301 https://$host$request_uri;
} # managed by Certbot
if ($host = example.com) {
return 301 https://$host$request_uri;
} # managed by Certbot
listen 80;
listen [::]:80;
server_name example.com www.example.com;
return 404; # managed by Certbot
}
还试图将/添加到api和app(位置/ app /,/ api /)中,结果发生变化,但仍然出错。在这种情况下,它仍然是api的404,但是它说URI不存在。对于react应用,它会根据正在读取的CSS给出语法错误。
任何建议都将不胜感激。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。