解決uWSGI的編碼問題詳解
發(fā)現(xiàn)問題
最近工作中遇到一個(gè)問題,在把 Flask 寫的應(yīng)用通過 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 這種方式來運(yùn)行也正常。
由于對 unicode 的支持不夠完善,這種報(bào)錯(cuò)經(jīng)常會出現(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 都不會出現(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)過測試,發(fā)現(xiàn)實(shí)際起作用的是 LANGUAGE 。
env LANG="en_US.UTF-8" env LANGUAGE="en_US.UTF-8"
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者使用python能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
教你如何用一行Python代碼實(shí)現(xiàn)GUI圖形界面
GUI(圖形用戶界面),顧名思義就是用圖形的方式,來顯示計(jì)算機(jī)操作的界面,更加方便且直觀。本文將用一行代碼實(shí)現(xiàn)GUI界面的制作,需要的可以參考一下2022-05-05python目標(biāo)檢測數(shù)據(jù)增強(qiáng)的代碼參數(shù)解讀及應(yīng)用
這篇文章主要為大家介紹了python目標(biāo)檢測數(shù)據(jù)增強(qiáng)的代碼參數(shù)解讀及應(yīng)用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05python利用openpyxl拆分多個(gè)工作表的工作簿的方法
這篇文章主要介紹了python利用openpyxl拆分多個(gè)工作表的工作簿的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09Python 2種方法求某個(gè)范圍內(nèi)的所有素?cái)?shù)(質(zhì)數(shù))
這篇文章主要介紹了Python 2種方法求某個(gè)范圍內(nèi)的所有素?cái)?shù)(質(zhì)數(shù)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01