在把 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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
[uwsgi]
master = true
wsgi-file = manage.py
callable = app
processes = 2
threads = 2
max-requests = 6000
chmod-socket = 664
uid = app
gid = app
buffer-size = 32768
venv = {project_dir}/venv
; http = 127.0.0.1:5001
logto = {project_dir}/logs/uwsgi.log
```
由于直接使用 Python 和 uwsgi 都不会出现这样的错误,因此可以判断应该是环境编码设置导致的问题。查看服务器的编码如下:

% locale
LANG=C
LANGUAGE=C:
LC_CTYPE=”en_US.UTF-8”
LC_NUMERIC=”en_US.UTF-8”
LC_TIME=”en_US.UTF-8”
LC_COLLATE=”en_US.UTF-8”
LC_MONETARY=”en_US.UTF-8”
LC_MESSAGES=”en_US.UTF-8”
LC_PAPER=”en_US.UTF-8”
LC_NAME=”en_US.UTF-8”
LC_ADDRESS=”en_US.UTF-8”
LC_TELEPHONE=”en_US.UTF-8”
LC_MEASUREMENT=”en_US.UTF-8”
LC_IDENTIFICATION=”en_US.UTF-8”
LC_ALL=en_US.UTF-8

1
2
3
4
从上面的配置可知 LANG 和 LANGUAGE 环境变量并没有设置。
可以在 `uwsgi.ini` 中设定这两个环境变量的值。

env LANG=”en_US.UTF-8”
env LANGUAGE=”en_US.UTF-8”

1
2
另一个方法,直接修改系统的 local 设置。在 Ubuntu 上,编辑该配置文件:

/etc/default/locale
LANG=”en_US.UTF-8”
LANGUAGE=”en_US:en:”

1
2
还可以直接使用 `localectl` 来更改配置:

localectl set-locale LANG=en_US.UTF-8
```

参考

(全文完)

留言

2017-03-23
次访问