Python中nginx配置问题:为什么127.0.0.1可以访问,但127.0.0.1:8000被拒绝访问?

我想部署在本地,系统是 Ubuntu16.04 ,所以 server_name 是 127.0.0.1

网页提示

Try:
Checking the connection
Checking the proxy and the firewall

这是我的 ngnix 的配置文件

server {
listen 80;
server_name 127.0.0.1;

    root /home/www/blog;
    access_log /home/www/blog/logs/access.log;
    error_log /home/www/blog/logs/access.log;
location / {  
    proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;  
    proxy_set_header Host $http_host;  
    proxy_redirect off;  
    if (!-f $request_filename) {  
        proxy_pass http://127.0.0.1:8000;  
        break;  
    }  
}  

}


Python中nginx配置问题:为什么127.0.0.1可以访问,但127.0.0.1:8000被拒绝访问?

40 回复

试一下 127.0.0.1:80 就知道了


这个问题通常是因为你的Nginx配置里没有正确监听8000端口,或者代理设置没指向你Python应用实际运行的地址。

检查你的Nginx配置文件(通常在/etc/nginx/sites-available/下),确保有类似这样的配置:

server {
    listen 8000;
    server_name 127.0.0.1;

    location / {
        proxy_pass http://127.0.0.1:5000;  # 这里要改成你Python应用的实际端口
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
}

关键点:

  1. listen 8000 确保Nginx在8000端口监听
  2. proxy_pass 要指向你Python应用实际运行的地址和端口(比如Flask默认的127.0.0.1:5000)

修改后重启Nginx:sudo systemctl restart nginx

另外,确保你的Python应用确实在运行,并且防火墙没有阻止8000端口。

总结:检查Nginx配置中的端口监听和代理指向。

是 Welcome to nginx!的页面

你这个配置应该是代理 8000 端口吧,你在 8000 端口是上开了什么服务这应该不关 Nginx 的事吧

观察地址栏变化撒…

你确认下你 8000 端口的服务起了没

没有,我用的 flask,gunicorn,不知道该怎么办

gunicorn -b 127.0.0.1:8000


我的启动文件名字是 manage,里面是使用了 flask_script 的 manager.run()启动,不是 app.run ,不知道这个有没有影响

我用的 gunicorn 配置文件,方便的话,帮我看看有什么不对的
[program:blog]

command=/home/blog/env/bin/gunicorn manage:manager -c /home/blog/gunicorn.conf

directory=/home/blog
user=www
autostart=true
autorestart=true
stdout_logfile=/home/blog/logs/gunicorn_supervisor.log
environment = MODE=“PRODUCTION”

查看端口开启状态和文件夹访问权限

不懂 nginx,大概把 listen 的改为 8000,重新运行一下就行了

我试试,我也很纳闷,为什么都是用的 8000,而那里 listen 的是 80

这个 nginx 也没看到配置 8000 端口,直接访问肯定拒绝了吧

回报 “ sudo netstat -ntpl ” 的输出结果


Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 127.0.0.1:3306 0.0.0.0:* LISTEN 1895/mysqld
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 1574/nginx -g daemo
tcp 0 0 127.0.1.1:53 0.0.0.0:* LISTEN 1429/dnsmasq
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 5102/cupsd
tcp6 0 0 :::80 :::* LISTEN 1574/nginx -g daemo
tcp6 0 0 ::1:631 :::* LISTEN 5102/cupsd
这个查询厉害,真没有 8000

Flask 默认端口是 5000 啊
你有改成 8000 吗


server = Server(host=“127.0.0.1”, port=8000)
manager.add_command(“runserver”, server)
这样修改了,试了一下还是不行,是不是不能使用 manageer.run?

什么意思?在哪里修改?

你这个配置的意思是开放 80 端口访问,对不存在的文件转发到 8000 端口。也就是在 nginx 后面需要有一个服务在跑,监听端口是 8000。

listen 8000 ;然后重启 nginx

启动 supervision 的时候,提示
niceblog: ERROR (spawn error)

试了一下,不是提示无法访问,而是 502 bad gateway,感觉 说的挺对的,我目前是 supervision 启动不了

你本地后端有 8000 端口的服务存在吗?

nginx 好像是要与 uwsgi 配合搞吧?你 uwsgi 配置了吗?

netstat -an | grep 8000

截个图看看

这楼感觉乱得一批啊,特别是那位不懂的大佬,不懂就别来添乱了好不好求你们了。

=====

首先这里有俩程序,一个叫 nginx,一个叫 gunicorn。

nginx
它的作用是向外提供服务,是面向用户的窗口,所以 listen 需要写 80,root 需要写网站的静态文件目录地址,proxy_pass 需要写后端的监听地址。

gunicorn
它的作用是起来你的程序,是面向代码的窗口,对外与 nginx 相连接,所以 listen 写 8000,和上方 proxy_pass 的地址对应。

=====

首先,你访问的地址应该是 127.0.0.1,而不是 8000 端口。
然后,两个程序要同时运行,才能访问到网站。
至于出现 welcome to nginx,可能是(1)你修改完配置没重载,(2)你写的这段配置没有被执行,(3)你写了其他虚拟主机配置,导致访问时访问了另一个虚拟主机,(4)预装的静态页面你没有删除。

自己好好查一下吧。

最后贴两个链接:
http://gunicorn.org/#quickstart
http://gunicorn.org/#deployment

端口没被占了?

老哥,通透,我去学习一下,十分感谢,说实话


使用 supervisorctl reread 如果不加 sudo 的话提示是这个,我使用的是 pyenv 创建的 3.6.4,我感觉这个出问题了,修改权限可以 reread,但是那个 python2.7 感觉不对,是不是应该改一下,怎么改?

[Errno 13] Permission denied: file: /usr/lib/python2.7/socket.py line: 228

日志日志 先看日志。

首先 8000 端口的服务没起来

然后你 nginx 里配置的难道不是文件不存在才转发到 8000 上? 所以访问存在的最多就是 welcome 了吧 根本没转发

0.0.0.0:8000 和 127.0.0.1:8000 什么区别?你搞清楚就知道为什么了

没有关系,只要你指定的是你所想要启动的 Flask 实例就行。你这里没有指定绑定的地址,就像我说的,你可以尝试加 -b 127.0.0.1:8000,这样才会监听到 8000 端口

1、首页是 Welcome to nginx 可以看看 /etc/nginx/sites-enabled/路径下是不是只有 default,如果你单独写了配置文件,那么删掉 default,首页就不是“ Welcome to nginx ”了;
2、检查防火墙有没有允许 8000 端口(不过就算没允许,你 nginx 反向代理后,访问 127.0.0.1:80 应该是能运行的,允许后访问 127.0.0.1:8000 和 80 端口的结果一样,如果有问题那么就先不要管 nginx 这一层,在 gunicorn 和程序上找原因);
3、如果上面没解决 运行 gunicorn wsgi -c bind = ‘0.0.0.0:2000’ pid = ‘/tmp/manager.pid’ 现在就相当于在运行你的程序,再有问题就是你程序 bug,第三步的前提是你程序配置了 wsgi.py ,这个很简单,百度一下就有。

希望能帮到你~

第三步的 gunicorn wsgi -c bind = ‘0.0.0.0:2000’ pid = ‘/tmp/manager.pid’ 端口 8000 是这样的
gunicorn wsgi -c bind = ‘0.0.0.0:8000’ pid = ‘/tmp/manager.pid’ 具体细节可百度,大概是这个思路,不过我一般是三二一,每一步没问题了才下一步。。

这句改一下,server = Server(host=“0.0.0.0”, port=8000) ,试试

话说,@sevenQu 你虽然用了 gunicorn 但是你 nginx 没用 wsgi 协议诶,nginx 配置的是假设 8000 为 http 协议。

https://docs.nginx.com/nginx/admin-guide/web-server/app-gateway-uwsgi-django/


很开心,按照你的 321 的步骤走,gunicorn 使用命令行启动成功了,ngnix 也可以了,网站成功走起
但是 gunicorn 命令行启动后,那个命令窗口好像不能继续使用了

我之前看的教程是使用 supervision 通过 gunicorn 配置文件启动的,不知道为什么用配置文件启动不了,我很纳闷,这是 supervision 的配置文件

[program:niceblog]
command=/home/seven/.pyenv/versions/daily/bin/gunicorn run:app -c /home/seven/Desktop/niceblog/gunicorn.conf
diretory=/home/seven/Desktop/niceblog
user=root
autostart=true
autorestart=true
tdout_logfile=/home/seven/Desktop/niceblog/logs/gunicorn_supervisor.log


gunicorn 的配置文件很简单
workers=3
bind='127.0.0.1:8000’

感觉关键是 supervision 的 command 那一行
/home/seven/.pyenv/versions/daily/bin/gunicorn 这是我用 pyenv 搭建的 flask 环境,gunicorn 所在位置

求解,谢谢

你要从非本机访问的话,gunicorn 要 bind 0.0.0.0:8000 吧。127.0.0.1 只能从服务器本机访问。

前两天正好在写在 CentOS 上跑 Node/Express 应用的一个快速指南,本来想可能大家都知道就不写了,看来我们都是从小白白赤手空拳过来的,还是有这类需求的是吧,哈哈

回到顶部