uWSGI 的编码问题解决
在把 Flask 写的应用通过 Supervisor+uWSGI
部署到正式服务器上时,出现了这样的错误:
Unable to print the message and arguments - possible formatting error.
或者
UnicodeEncodeError: 'ascii' codec can't encode characters in position 24-25: ordinal not in range(128)
有趣的是,直接在 Python 环境下运行的时候,没有这样的错误。使用 uwsgi uwsgi.ini
这种方式来运行也正常。
由于对 unicode 的支持不够完善,这种报错经常会出现在 Python2 中,但我的所有程序都在 Python3 中写成,不应该再出现这样的错误。况且,所有的 python 文件都在首行设定了编码:
1# -*- coding: utf-8 -*-
我的环境如下:
- Ubuntu 16.04.1 LTS
- Python 3.5.2
- uWSGI 2.0.14 (in python3 pip)
- Supervisor 3.3.1 (in python2 pip)
uwsgi.ini 配置文件内容如下:
1[uwsgi]
2master = true
3
4wsgi-file = manage.py
5callable = app
6
7processes = 2
8threads = 2
9max-requests = 6000
10chmod-socket = 664
11
12uid = app
13gid = app
14
15buffer-size = 32768
16
17venv = {project_dir}/venv
18
19; http = 127.0.0.1:5001
20
21logto = {project_dir}/logs/uwsgi.log
由于直接使用 Python 和 uwsgi 都不会出现这样的错误,因此可以判断应该是环境编码设置导致的问题。查看服务器的编码如下:
1% locale
2LANG=C
3LANGUAGE=C:
4LC_CTYPE="en_US.UTF-8"
5LC_NUMERIC="en_US.UTF-8"
6LC_TIME="en_US.UTF-8"
7LC_COLLATE="en_US.UTF-8"
8LC_MONETARY="en_US.UTF-8"
9LC_MESSAGES="en_US.UTF-8"
10LC_PAPER="en_US.UTF-8"
11LC_NAME="en_US.UTF-8"
12LC_ADDRESS="en_US.UTF-8"
13LC_TELEPHONE="en_US.UTF-8"
14LC_MEASUREMENT="en_US.UTF-8"
15LC_IDENTIFICATION="en_US.UTF-8"
16LC_ALL=en_US.UTF-8
从上面的配置可知 LANG 和 LANGUAGE 环境变量并没有设置。
可以在 uwsgi.ini
中设定这两个环境变量的值。
1env LANG="en_US.UTF-8"
2env LANGUAGE="en_US.UTF-8"
另一个方法,直接修改系统的 local 设置。在 Ubuntu 上,编辑该配置文件:
1/etc/default/locale
2LANG="en_US.UTF-8"
3LANGUAGE="en_US:en:"
还可以直接使用 localectl
来更改配置:
1localectl set-locale LANG=en_US.UTF-8
参考
(全文完)
- 文章ID:2629
- 原文作者:zrong
- 原文链接:https://blog.zengrong.net/post/uwsgi-unicodeencode-error/
- 版权声明:本作品采用 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 进行许可,非商业转载请注明出处(原文作者,原文链接),商业转载请联系作者获得授权。