Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법

(2021-12-18 업데이트: 이 글의 내용을 적용하지 말고, 새롭게 쓴 "WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법 (2)"를 참고하는 것을 권장합니다.)



WSL로 Ubuntu 20.04를 최초 설치한 순간부터 시작해 볼까요? ^^

우선, 패지키 repo 먼저 업데이트하고,

$ sudo apt update
$ sudo apt upgrade -y

기본적으로 python3는 설치되어 있으므로 pip3를 설치한 다음,

$ sudo apt install python3-pip -y

uwsgi와 파이썬 plug-in을 설치합니다.

$ sudo apt install uwsgi-core -y
$ sudo apt install uwsgi-plugin-python3 -y

그런데. 이렇게 하고 지난 글에서 설명한 명령을 실행해 보면,

$ uwsgi --http :18091 --chdir /mnt/d/pycharm/work/myapp --wsgi-file ./myapp/wsgi.py
uwsgi: option '--http' is ambiguous; possibilities: '--http-socket' '--http-socket-modifier1' '--http-socket-modifier2' '--http11-socket' '--https-socket' '--https-socket-modifier1' '--https-socket-modifier2'
getopt_long() error

오류가 발생합니다. 그새 뭔가 변한 것인지, 아마도 좀 더 세세하게 프로토콜을 지정해야 하는 것 같은데요, 일단 --http-socket으로 지정하면 해결이 되지만,

$ uwsgi --http-socket :18091 --chdir /mnt/d/pycharm/work/myapp --wsgi-file ./myapp/wsgi.py
uwsgi: unrecognized option '--wsgi-file'
getopt_long() error

그래도 오류가 발생하는군요. ^^; 검색해 보면 분명히 uwsgi-plugin-python3을 설치하면 된다고 하는데 저렇게 오류가 발생합니다. 실제로 로드된 플러그인 목록도 비어 있는데요,

$ uwsgi --plugins-list

*** uWSGI loaded generic plugins ***

*** uWSGI loaded request plugins ***
--- end of plugins list ---
...[생략]...

그렇다고 플러그인 설치가 안 된 것은 아닙니다. 왜냐하면 find 명령으로 이렇게 위치하고 있기 때문입니다.

$ find / -path /mnt -prune -o  -name python3_plugin.so 2>/dev/null
/mnt
/usr/lib/uwsgi/plugins/python3_plugin.so

음... 할 수 없군요. 강제로 경로를 지정해서 로드를 시도하면,

$ uwsgi --plugin /usr/lib/uwsgi/plugins/python3_plugin.so --plugins-list

*** uWSGI loaded generic plugins ***

*** uWSGI loaded request plugins ***
0: python
--- end of plugins list ---
...[생략]...

다행히 파이썬 플러그인이 올라옵니다. 따라서, 이제는 테스트를 위한 명령어가 이렇게 복잡해졌습니다. ^^;

$ uwsgi --plugin /usr/lib/uwsgi/plugins/python3_plugin.so --http-socket :18091 --chdir /mnt/d/pycharm/work/myapp --wsgi-file ./myapp/wsgi.py




재미있는 것은, /usr/bin에 uwsgi가 설치되어 있는데요, 그 외에 uwsgi_python3도 있습니다.

/usr/bin$ ls uw*
uwsgi  uwsgi-core  uwsgi_python3  uwsgi_python38

그리고 그걸로 실행하면 별다르게 플러그인을 지정하지 않아도 /usr/lib/uwsgi/plugins/ 경로에 있는 python3_plugin.so 파일을 잘 로드해 실행합니다.

$ uwsgi_python3 --http-socket :18091 --chdir /mnt/d/pycharm/work/myapp --wsgi-file ./myapp/wsgi.py
[uwsgi] implicit plugin requested python3
...[생략]...

아마도 uwsgi는 python_plugin.so를, uwsgi_python3는 python3_plugin.so를 로드하는 듯한데... 어쨌든 이상하군요, 예전에는 저런 절차 없이 잘 사용을 했는데. ^^;




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/22/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
227정성태4/13/200617373Team Foundation Server: 2. TFS 빌드 오류 유형 - MSBUILD: warning : Specified cast is not valid
226정성태4/13/200615342Team Foundation Server: 1. TFS 오류 유형 - TF50608: Unable to retrieve information for security object
225정성태10/17/200614894.NET Framework: 67. VS.NET 2005 도구 상자에 있는 Workflow Activity 항목의 아이콘 변경
223정성태4/13/200626160.NET Framework: 66. Microsoft .NET Framework 2.0 Configuration 수동 설치파일 다운로드1
224정성태4/13/200619718    답변글 .NET Framework: 66.1. "Microsoft .NET Framework 2.0 Configuration" MSI 설치 파일 버전파일 다운로드1
222정성태4/13/200618724.NET Framework: 65. VS.NET 2005: 파일 기반 웹 프로젝트의 "Virtual Path" 제거
220정성태4/13/200616446.NET Framework: 64. ClickOnce - 배포 시 오류 : "Error: An unexpected error occurred -- The parameter is incorrect."
219정성태4/13/200631258.NET Framework: 63. ClickOnce - 최초 실행 시 보안 경고창 없애는 방법 [1]
216정성태4/13/200618311스크립트: 8. 3월 1일 ActiveX Patch 적용 후, JS 로 수정한 임베딩 컨트롤이 여전히 비활성화 되는 문제 [2]
215정성태4/13/200619655.NET Framework: 62. ASP.NET 웹 컨트롤 렌더링 가로채기
214정성태4/13/200618995.NET Framework: 61. DateTime - DateTime = 사이의 "Month" 수 계산 [2]
213정성태4/13/200621262.NET Framework: 60. localhost 이외의 컴퓨터에서 asmx 테스트 페이지 호출 [1]
218정성태4/13/200619618    답변글 .NET Framework: 60.1. asmx 테스트 페이지를 보여주고 싶지 않을 때
211정성태4/13/200617501VS.NET IDE: 38. VS.NET 2005 - "Export Template" 메뉴
210정성태4/13/200616984.NET Framework: 59. EXE 참조 가능 - VS.NET 2005 [2]
209정성태4/13/200616476스크립트: 7. 4월 12일 ActiveX 패치 문제를 해결할 수 있는 가장 간단한 방법 [6]파일 다운로드1
208정성태10/21/200616205Windows: 1. 성태도 ^^ Vista 설치 해봤습니다.
212정성태10/20/200615739    답변글 Windows: 1.1. Vista 에서 WinFX 런타임 구동
207정성태4/13/200624716VC++: 23. VC++ RGS 파일에 사용자 정의 파라미터 추가
205정성태4/13/200621788VS.NET IDE: 37. devenv.exe를 이용한 Command Line 컴파일 [1]
204정성태5/8/200617006웹: 2. Server Unavailable - Server Application Unavailable
203정성태4/13/200615858웹: 1. IIS 설정 옵션: Verify(Check) that file exists
202정성태4/13/200615571VS.NET IDE: 36. Automatically synchronize with an Internet time server
201정성태4/13/200618606기타: 12. XMLHTTP Failure and SUS Admin
200정성태4/13/200617992.NET Framework: 58. 웹 서비스 메서드 호출 오류 유형 - text/html; charset=xxx, but expected 'text/xml'
199정성태4/13/200619351스크립트: 6. XHTML or HTML 4.01 표준 준수
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...