现在是周六的晚上11点半,博主用了1个小时来解决一个自认为神奇的问题,关于Nginx 502的问题,现在记录一下解决的流程。

网站首页正常访问,跳转到登录页时502 bad gateway

博主是在自己家里的虚拟机上重新移植了flask项目,部署成功后,成功访问了首页,但是跳转登录的时候失败了,这时候求助了csdn和百度blablabla各种,显示查看error_log,看到如下内容。
这里写图片描述
然后又去查这个错误,然而并没有解决问题,不过发现了一篇不错的博文,大家可以看看
https://www.cnblogs.com/succour/p/6305574.html

关闭Nginx和supervisor,开发模式启动

然后博主关闭了Nginx和supervisor,使用开发模式启动flask应用这里写图片描述
结果在跳转登录的时候报错了:

nicodeDecodeError: ‘ascii’ codec can’t decode byte 0xe6 in position 0: ordinal not in range(128)

看到这里博主就恍然大悟了,印象中自己在公司部署的时候也碰到过,这是因为python的str默认是ascii编码,和unicode编码冲突,就会报这个错误。解决办法是修改了manage.py代码增加以下内容

import sys
reload(sys)
sys.setdefaultencoding('utf8')

所以现在的manage.py代码如下:

#coding=utf-8
#!/home/changge/Desktop/flask/venv python
'''
Created on 2017/11/9
@author: changge
Project:
'''
import os
from app import create_app

from flask_script import Manager, Shell
import sys
reload(sys)
sys.setdefaultencoding('utf8')

app = create_app(os.getenv('FLASK_CONFIG') or 'default')
manager = Manager(app)
def make_shell_context():
    return dict(app=app)
manager.add_command("shell", Shell(make_context=make_shell_context))
@manager.command
def deploy():
    """Run deployment tasks."""
    pass
#manager = Manager(app)
if __name__ == '__main__':
    manager.run(
    #app.run()

调试并部署

修改完代码之后,调试模式下启动应用,跳转登录时正常弹出登陆框,然后再启动Nginx和supervisor成功打开登录页面
这里写图片描述

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐