最近在用Flask 寫的應用程式透過Supervisor+uWSGI 部署到正式伺服器上時出現了錯誤,透過尋找相關的資料終於解決了,所以想著分享出來給大家,下面這篇文章主要介紹了解決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 檔案都在首行設定了編碼:
# -*- coding: utf-8 -*-
#我的環境如下:
############################################################ #####Supervisor 3.3.1 (in python2 pip)############uwsgi.ini 設定檔內容如下:###
[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##########發現 LANG 和 LANGUAGE 環境變數並沒有設定。 ############可以在 uwsgi.ini 中設定這兩個環境變數的值。經過測試,發現實際上起作用的是 LANGUAGE 。 ###
env LANG="en_US.UTF-8" env LANGUAGE="en_US.UTF-8"
以上是詳解uWSGI的編碼問題解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!