解決uWSGI的編碼問題詳解
發(fā)現(xiàn)問題
最近工作中遇到一個(gè)問題,在把 Flask 寫的應(yīng)用通過(guò) Supervisor+uWSGI 部署到正式服務(wù)器上時(shí),出現(xiàn)了這樣的錯(cuò)誤:
Unable to print the message and arguments – possible formatting error.
或者
UnicodeEncodeError: ‘a(chǎn)scii' codec can't encode characters in position 24-25: ordinal not in range(128)
有趣的是,直接在 Python 環(huán)境下運(yùn)行的時(shí)候,沒有這樣的錯(cuò)誤。使用 uwsgi uwsgi.ini 這種方式來(lái)運(yùn)行也正常。
由于對(duì) unicode 的支持不夠完善,這種報(bào)錯(cuò)經(jīng)常會(huì)出現(xiàn)在 Python2 中,但我的所有程序都在 Python3 中寫成,不應(yīng)該再出現(xiàn)這樣的錯(cuò)誤。況且,所有的 python 文件都在首行設(shè)定了編碼:
# -*- coding: utf-8 -*-
我的環(huán)境如下:
- 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 配置文件內(nèi)容如下:
[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 都不會(huì)出現(xiàn)這樣的錯(cuò)誤,因此可以判斷應(yīng)該是環(huán)境編碼設(shè)置導(dǎo)致的問題。
查看服務(wù)器的編碼如下:
% 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
發(fā)現(xiàn) LANG 和 LANGUAGE 環(huán)境變量并沒有設(shè)置。
可以在 uwsgi.ini 中設(shè)定這兩個(gè)環(huán)境變量的值。經(jīng)過(guò)測(cè)試,發(fā)現(xiàn)實(shí)際起作用的是 LANGUAGE 。
env LANG="en_US.UTF-8" env LANGUAGE="en_US.UTF-8"
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者使用python能帶來(lái)一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Python中往列表中插入字典時(shí),數(shù)據(jù)重復(fù)問題
這篇文章主要介紹了Python中往列表中插入字典時(shí),數(shù)據(jù)重復(fù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
python 實(shí)現(xiàn)列表的切片操作允許索引超出范圍
這篇文章主要介紹了python 實(shí)現(xiàn)列表的切片操作允許索引超出范圍,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05
python編程培訓(xùn) python培訓(xùn)靠譜嗎
現(xiàn)在大家都知道,比較火的編程語(yǔ)言就是python了,很多朋友都想學(xué)習(xí)python編程,想上一個(gè)好的python培訓(xùn)班,小編今天給大家全面分析一下關(guān)于python編程培訓(xùn)方面的問題,希望能給你答疑解惑。2018-01-01
卡爾曼濾波數(shù)據(jù)處理技巧通俗理解及python實(shí)現(xiàn)
這篇文章主要為大家介紹了卡爾曼濾波數(shù)據(jù)處理技巧的通俗理解及python實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
Python os模塊中的isfile()和isdir()函數(shù)均返回false問題解決方法
這篇文章主要介紹了Python os模塊中的isfile()和isdir()函數(shù)均返回false問題解決方法,返回false的原因是路徑使用了相對(duì)路徑,使用絕對(duì)路徑就可以解決這個(gè)問題,需要的朋友可以參考下2015-02-02
用python實(shí)現(xiàn)的去除win下文本文件頭部BOM的代碼
windows環(huán)境下新建或編輯文本文件,保存時(shí)會(huì)在頭部加上BOM。使用ftp上傳到linux下,在執(zhí)行時(shí)第一行即報(bào)錯(cuò)。以下方法可以去除BOM頭,有需要的朋友可以參考下2013-02-02
python opencv圖片編碼為h264文件的實(shí)例
今天小編就為大家分享一篇python opencv圖片編碼為h264文件的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12

