최근 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를 사용하여 이런 방식으로 실행하는 것도 일반적입니다.
유니코드에 대한 지원 부족으로 인해 Python2에서는 이런 오류가 자주 발생하는데, 제가 사용하는 프로그램은 모두 Python3으로 작성되어 있어서 이런 오류가 다시는 발생하지 않아야 합니다. 또한 모든 Python 파일의 첫 번째 줄에는
# -*- coding: utf-8 -*-
내 환경은 다음과 같습니다.
Ubuntu 16.04.1 LTS
Python 3.5.2
uWSGI 2.0.14(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 라는 것을 알았습니다.
아아아아위 내용은 uWSGI 인코딩 문제 해결 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!