Microsoft MVP성태의 닷넷 이야기
글쓴 사람
홈페이지
첨부 파일
 

Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog

윈도우 응용 프로그램을 개발하다 보면 OutputDebugString을 심심치 않게 사용하게 되는데요. 리눅스로 오면 저 API를 뭘로 대체해야 할지 고민하게 됩니다. 제 생각에는 가장 적합한 것이 바로 syslog였습니다.

#include <syslog.h> 
#include <stdarg.h> 

void syslog(int priority, const char *format, ...);
void vsyslog(int priority, const char *format, va_list ap); 

보는 바와 같이 포매팅도 기본적으로 제공하기 때문에 사용법도 편리합니다. 일단 저걸로 로그를 남겼으면 "Dbgview.exe"처럼 확인을 할 수 있어야 하는데요, 이를 위해 tail 명령어를 사용할 수 있습니다.

tail 명렁어로 log를 보는 법
; https://jusunglee.tistory.com/entry/%EB%A1%9C%EA%B7%B8%EB%A5%BC-%EB%B3%B4%EB%8A%94%EB%B2%95-log

$ cd /var/log
$ tail -f syslog

게다가 syslog/vsyslog는 프로세스 명을 자동으로 붙여주기 때문에 grep을 함께 연동하는 것이 좋습니다. 가령 .NET Core로 만들어진 응용 프로그램이라면 프로세스 명이 "dotnet"일 것이므로 다음과 같이 연결하면 됩니다.

$ tail -f syslog | grep dotnet




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





[최초 등록일: ]
[최종 수정일: 5/17/2019 ]

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

비밀번호

댓글 쓴 사람
 



2019-05-24 06시08분
하루 지나고 나니 "tail -f" 명령어의 출력이 없습니다. 회사 동료가 ^^ "tail -F"를 추천하는데, "even if the file is rotated" 상황에서도 잘 동작하는 거라고 합니다.

https://tldr.ostera.io/tail


정성태

1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
11917정성태5/24/2019685Math: 52. MathNet을 이용한 간단한 통계 정보 처리 - 분산/표준편차파일 다운로드1
11916정성태5/24/2019484Math: 51. MathNET + OxyPlot을 이용한 간단한 통계 정보 처리 - Histogram파일 다운로드1
11915정성태5/24/2019467Linux: 11. 리눅스의 환경 변수 관련 함수 정리 - putenv, setenv, unsetenv
11914정성태5/24/2019684Linux: 10. 윈도우의 GetTickCount와 리눅스의 clock_gettime파일 다운로드1
11913정성태5/24/2019602.NET Framework: 838. C# - 숫자형 타입의 bit(2진) 문자열, 16진수 문자열 구하는 방법파일 다운로드1
11912정성태5/23/2019520VS.NET IDE: 137. Visual Studio 2019 버전 16.1부터 리눅스 C/C++ 프로젝트에 추가된 WSL 지원
11911정성태5/23/2019507VS.NET IDE: 136. Visual Studio 2019 - 리눅스 C/C++ 프로젝트에 인텔리센스가 동작하지 않는 경우
11910정성태5/24/2019952Math: 50. C# - MathNet.Numerics의 Matrix(행렬) 연산파일 다운로드1
11909정성태5/25/2019885.NET Framework: 837. C# - PLplot 사용 예제 [1]파일 다운로드1
11908정성태5/22/2019570.NET Framework: 836. C# - Python range 함수 구현파일 다운로드1
11907정성태6/4/2019438오류 유형: 541. msbuild - MSB4024 The imported project file "...targets" could not be loaded
11906정성태5/21/2019447.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/2019512.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/2019794.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보파일 다운로드1
11903정성태5/21/2019631오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/2019403오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/2019639오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태5/18/2019580오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/2019810Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/20/2019670VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/20191065오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우
11896정성태5/15/2019712개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/2019770.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/12/2019946VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [1]
11893정성태5/10/2019700오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/2019572웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...