Flask + React + Nginx: pages showing 404 not found for all routes with port number 80
I thought I would be able to access react's index page with localhost:80 and apis with localhost/api/example, but am instead seeing a '404 page not found' error for these pages.
However, i am able to render the react's index page with localhost:3000, and the api urls with localhost:5000/api/example.
nginx.conf
events {
worker_connections 1024;
}
http {
# include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
upstream nodeweb {
server localhost:3000;
}
upstream flaskapp {
server localhost:5000;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
# try_files $uri /index.html; -> adding this line gives 500 Internal Server Error
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;
proxy_set_header Host $host;
# enable EventSource
proxy_set_header Connection '';
proxy_http_version 1.1;
chunked_transfer_encoding off;
proxy_buffering off;
proxy_cache off;
proxy_pass http://nodeweb$is_args$args;
}
location ~ /api/(?<section>.*) {
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;
proxy_buffering off;
proxy_set_header Host $host;
proxy_pass http://flaskapp/$section$is_args$args;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
reactjs nginx flask web-deployment
add a comment |
I thought I would be able to access react's index page with localhost:80 and apis with localhost/api/example, but am instead seeing a '404 page not found' error for these pages.
However, i am able to render the react's index page with localhost:3000, and the api urls with localhost:5000/api/example.
nginx.conf
events {
worker_connections 1024;
}
http {
# include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
upstream nodeweb {
server localhost:3000;
}
upstream flaskapp {
server localhost:5000;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
# try_files $uri /index.html; -> adding this line gives 500 Internal Server Error
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;
proxy_set_header Host $host;
# enable EventSource
proxy_set_header Connection '';
proxy_http_version 1.1;
chunked_transfer_encoding off;
proxy_buffering off;
proxy_cache off;
proxy_pass http://nodeweb$is_args$args;
}
location ~ /api/(?<section>.*) {
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;
proxy_buffering off;
proxy_set_header Host $host;
proxy_pass http://flaskapp/$section$is_args$args;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
reactjs nginx flask web-deployment
add a comment |
I thought I would be able to access react's index page with localhost:80 and apis with localhost/api/example, but am instead seeing a '404 page not found' error for these pages.
However, i am able to render the react's index page with localhost:3000, and the api urls with localhost:5000/api/example.
nginx.conf
events {
worker_connections 1024;
}
http {
# include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
upstream nodeweb {
server localhost:3000;
}
upstream flaskapp {
server localhost:5000;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
# try_files $uri /index.html; -> adding this line gives 500 Internal Server Error
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;
proxy_set_header Host $host;
# enable EventSource
proxy_set_header Connection '';
proxy_http_version 1.1;
chunked_transfer_encoding off;
proxy_buffering off;
proxy_cache off;
proxy_pass http://nodeweb$is_args$args;
}
location ~ /api/(?<section>.*) {
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;
proxy_buffering off;
proxy_set_header Host $host;
proxy_pass http://flaskapp/$section$is_args$args;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
reactjs nginx flask web-deployment
I thought I would be able to access react's index page with localhost:80 and apis with localhost/api/example, but am instead seeing a '404 page not found' error for these pages.
However, i am able to render the react's index page with localhost:3000, and the api urls with localhost:5000/api/example.
nginx.conf
events {
worker_connections 1024;
}
http {
# include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
upstream nodeweb {
server localhost:3000;
}
upstream flaskapp {
server localhost:5000;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
# try_files $uri /index.html; -> adding this line gives 500 Internal Server Error
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;
proxy_set_header Host $host;
# enable EventSource
proxy_set_header Connection '';
proxy_http_version 1.1;
chunked_transfer_encoding off;
proxy_buffering off;
proxy_cache off;
proxy_pass http://nodeweb$is_args$args;
}
location ~ /api/(?<section>.*) {
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;
proxy_buffering off;
proxy_set_header Host $host;
proxy_pass http://flaskapp/$section$is_args$args;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
reactjs nginx flask web-deployment
reactjs nginx flask web-deployment
edited Nov 22 '18 at 8:49
doyz
asked Nov 22 '18 at 8:43
doyzdoyz
264415
264415
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
I think you have some misunderstanding about the setting in nginx.Since you have set proxy_pass ,it's the Reverse Proxy setting.It means listening to 80 port and proxy all the request to proxy_pass,so you can only get response in 3000.
Here are some documents.Hope to help you.http://nginx.org/en/docs/http/server_names.html
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53426906%2fflask-react-nginx-pages-showing-404-not-found-for-all-routes-with-port-numb%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
I think you have some misunderstanding about the setting in nginx.Since you have set proxy_pass ,it's the Reverse Proxy setting.It means listening to 80 port and proxy all the request to proxy_pass,so you can only get response in 3000.
Here are some documents.Hope to help you.http://nginx.org/en/docs/http/server_names.html
add a comment |
I think you have some misunderstanding about the setting in nginx.Since you have set proxy_pass ,it's the Reverse Proxy setting.It means listening to 80 port and proxy all the request to proxy_pass,so you can only get response in 3000.
Here are some documents.Hope to help you.http://nginx.org/en/docs/http/server_names.html
add a comment |
I think you have some misunderstanding about the setting in nginx.Since you have set proxy_pass ,it's the Reverse Proxy setting.It means listening to 80 port and proxy all the request to proxy_pass,so you can only get response in 3000.
Here are some documents.Hope to help you.http://nginx.org/en/docs/http/server_names.html
I think you have some misunderstanding about the setting in nginx.Since you have set proxy_pass ,it's the Reverse Proxy setting.It means listening to 80 port and proxy all the request to proxy_pass,so you can only get response in 3000.
Here are some documents.Hope to help you.http://nginx.org/en/docs/http/server_names.html
answered Nov 22 '18 at 9:41
RootRoot
1,523129
1,523129
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53426906%2fflask-react-nginx-pages-showing-404-not-found-for-all-routes-with-port-numb%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown