首頁 >後端開發 >Python教學 >詳解uWSGI的編碼問題解決方法

詳解uWSGI的編碼問題解決方法

高洛峰
高洛峰原創
2017-03-26 10:09:152484瀏覽

最近在用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 -*-

#我的環境如下:

  • # #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 設定檔內容如下:###
[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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn