Microsoft MVP성태의 닷넷 이야기
스크립트: 46. 파이썬 - uvicorn의 콘솔 출력을 UDP로 전송 [링크 복사], [링크+제목 복사],
조회: 13635
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

파이썬 - uvicorn의 콘솔 출력을 UDP로 전송

(uvicorn과는 다르게) uwsgi의 경우 재미있는 옵션이 하나 있습니다.

Basic logging (connected UDP mode)
; https://uwsgi-docs.readthedocs.io/en/latest/Logging.html#basic-logging-connected-udp-mode

바로 출력 내용을 UDP로 전송하는 "--logto" 옵션인데요,

$ ./uwsgi -s :3031 -w simple_app --logto 192.168.100.50:65000

아쉽게도 저 기능이 uvicorn에는 없습니다. 그래서 처음에는 Python의 Logger를 이용해 보려고 했는데,

파이썬 - uvicorn 사용자 정의 Logger 작성
; https://www.sysnet.pe.kr/2/0/13264

이것도 좀 아쉽습니다. 왜냐하면 print 같은 유의 출력은 Logger 재정의로는 잡을 수 없기 때문입니다. 뭐... 그래도 괜찮습니다. nc를 이용하면 되는데요,

$ uvicorn --loop asyncio --host 0.0.0.0 --port 3031 main:app | nc -u 192.168.100.50 65000

그런데 위와 같이 했더니 표준 출력은 전송되는 반면 표준 에러는 nc로 전달되지 않습니다. 따라서 그것까지 우회하려면 다음과 같이 추가 처리를 해주면 됩니다. ^^

$ uvicorn --loop asyncio --host 0.0.0.0 --port 3031 main:app 2>&1 | nc -u 192.168.100.50 65000




위와 같이 UDP 전송 처리를 한 경우, 간단하게 서버 측 테스트가 필요하다면 역시나 nc를 이용하면 됩니다.

다음의 옵션은 nc 프로그램을 UDP 서버로 동작시키는데,

$ nc -ul 0.0.0.0 65000

유사한 테스트를 uwsgi를 이용해서도 할 수 있습니다.

$ uwsgi --udp 0.0.0.0:65000

리눅스는 은근히 ^^ 이런 테스트하기가 좋군요.




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







[최초 등록일: ]
[최종 수정일: 2/23/2023]

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

비밀번호

댓글 작성자
 




... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13501정성태12/25/202311601개발 환경 구성: 700. WSL + uwsgi - IPv6로 바인딩하는 방법
13500정성태12/24/202312284디버깅 기술: 194. Windbg - x64 가상 주소를 물리 주소로 변환
13498정성태12/23/202313429닷넷: 2186. 한국투자증권 KIS Developers OpenAPI의 C# 래퍼 버전 - eFriendOpenAPI NuGet 패키지
13497정성태12/22/202312129오류 유형: 885. Visual Studiio - error : Could not connect to the remote system. Please verify your connection settings, and that your machine is on the network and reachable.
13496정성태12/21/202311315Linux: 66. 리눅스 - 실행 중인 프로세스 내부의 환경변수 설정을 구하는 방법 (gdb)
13495정성태12/20/202311793Linux: 65. clang++로 공유 라이브러리의 -static 옵션 빌드가 가능할까요?
13494정성태12/20/202311695Linux: 64. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) - 두 번째 이야기
13493정성태12/19/202312275닷넷: 2185. C# - object를 QueryString으로 직렬화하는 방법
13492정성태12/19/202311468개발 환경 구성: 699. WSL에 nopCommerce 예제 구성
13491정성태12/19/202310298Linux: 63. 리눅스 - 다중 그룹 또는 사용자를 리소스에 권한 부여
13490정성태12/19/202311434개발 환경 구성: 698. Golang - GLIBC 의존을 없애는 정적 빌드 방법
13489정성태12/19/202311091개발 환경 구성: 697. GoLand에서 ldflags 지정 방법
13488정성태12/18/202310397오류 유형: 884. HTTP 500.0 - 명령행에서 실행한 ASP.NET Core 응용 프로그램을 실행하는 방법
13487정성태12/16/202312116개발 환경 구성: 696. C# - 리눅스용 AOT 빌드를 docker에서 수행 [1]
13486정성태12/15/202310521개발 환경 구성: 695. Nuget config 파일에 값 설정/삭제 방법
13485정성태12/15/202310102오류 유형: 883. dotnet build/restore - error : Root element is missing
13484정성태12/14/202311607개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법
13483정성태12/14/202311483닷넷: 2184. C# - 하나의 resource 파일을 여러 프로그램에서 (AOT 시에도) 사용하는 방법파일 다운로드1
13482정성태12/13/202313155닷넷: 2183. C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법 [2]파일 다운로드1
13481정성태12/13/202312042개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법파일 다운로드1
13480정성태12/12/202313992개발 환경 구성: 692. Windows WSL 2 + Chrome 웹 브라우저 설치
13479정성태12/11/202310747개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정
13477정성태12/8/202311505닷넷: 2182. C# - .NET 7부터 추가된 Int128, UInt128 [1]파일 다운로드1
13476정성태12/8/202311840닷넷: 2181. C# - .NET 8 JsonStringEnumConverter의 AOT를 위한 개선파일 다운로드1
13475정성태12/7/202312410닷넷: 2180. .NET 8 - 함수 포인터에 대한 Reflection 정보 조회파일 다운로드1
13474정성태12/6/202311648개발 환경 구성: 690. 닷넷 코어/5+ 버전의 ilasm/ildasm 실행 파일 구하는 방법 - 두 번째 이야기
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...