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