uwsgi php,详解uWSGI的编码问题解决方法
最近在用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"
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的uwsgi php,详解uWSGI的编码问题解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 削怎么读?
- 下一篇: php 执行效率,PHP 函数执行效率的