Microsoft MVP성태의 닷넷 이야기
기타: 77. DataDog APM 간략 소개 [링크 복사], [링크+제목 복사]
조회: 2424
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

DataDog APM 간략 소개

2주 동안 무료로 사용할 수 있어 DataDog을 잠시 설치해 봤는데요,

DataDog
; https://www.datadoghq.com/

DataDog 측에서 수집 및 뷰 서버 자체를 각각 유럽과 미국에 두고 제공하기 때문에 사용자 측은 데이터 수집용 에이전트만 설치하면 됩니다. DataDog의 경우 에이전트가 시스템 정보를 수집하는 것과 PHP, .NET, Java 응용 프로그램 등의 APM 측면에서의 데이터를 수집하는 것으로 나뉘는데요. 우선, 윈도우 서버의 시스템 정보를 수집한다면 다음의 에이전트를 설치합니다.

https://s3.amazonaws.com/ddagent-windows-stable/datadog-agent-7-latest.amd64.msi

설치는 매우 간단한데, 단순히 Free Trial로 받은 API Key와 데이터 서버 주소(datadoghq.com)를 설치 과정 중에 뜨는 대화창에 입력하면 됩니다. 이 정도만 구성하면, 기본적으로 다음과 같은 시스템 메트릭 화면의 수치 등의 정보들을 Dashboards 메뉴를 통해 볼 수 있습니다.

// https://app.datadoghq.com/dash/integration/1/System%20-%20Metrics 화면
data_dog_apm_1.png




DataDog의 APM 기능은 PHP, .NET, Java 등의 응용 프로그램에서는 소스 코드 변경 없이 에이전트만 설치하면 되고 Go 등의 언어에서는 소스 코드를 변경해야 합니다.

일단, .NET을 예로 들면 이를 위한 APM 에이전트를 다음의 github에서 다운로드해,

DataDog / dd-trace-dotnet
; https://github.com/DataDog/dd-trace-dotnet/releases

설치하면 됩니다. 재미있게도 DataDog의 경우 이렇게 소스 코드를 Apache 2.0 라이선스로 공개하고 있는데요,

dd-trace-dotnet/LICENSE
; https://github.com/DataDog/dd-trace-dotnet/blob/master/LICENSE

따라서 여러분들도 .NET 용 APM 도구를 이 소스 코드를 기반으로 쉽게 만들어 낼 수 있습니다. ^^ (실제로 이 혜택을 국내 업체 중 와탭(WhaTap)에서 DataDog의 소스 코드를 사용해 닷넷 버전의 서비스를 하고 있는 듯합니다. - 와탭 측에서 라이선스 명시를 안해 확실하진 않지만 제가 보기로는 소스 코드가 거의 동일했습니다.)

위의 에이전트를 설치한 이후, DataDog에서 제공하는 APM 관련 화면은 아래의 것으로 대표할 수 있습니다.

data_dog_apm_2.png

화면의 좌측 하단을 보면 각종 "필터링 조건"이 있고 그에 따라 우측에 리스트 형식으로 나열됩니다. 따라서, 응답 시간이 5초 이상 걸렸다거나, 오류가 발생한 페이지를 조회한다든가.... 하는 식으로 추적을 할 수 있습니다.

여기서도 한 가지 재미있는 점이 있는데요, 국내의 경우 제니퍼가 X-View라는 형식으로 문제 분석의 직관성을 대표하고 있어 다른 국내 APM 제품도 이에 맞춰 보여주려고 하는데, 해외의 경우 대부분 "목록" 형식으로 필터링하는 식의 뷰를 제공한다는 점입니다. (다들 나름대로의 장단점이 있습니다. ^^)

이글에서 짧게 소개해 아쉬운 분은, 마침 이틀 후에 datadog 측에서 웨비나를 준비하고 있으므로 한 번 참여해 보시는 것도 좋을 듯 합니다. ^^

심도 있는 스페셜 에디션 웨비나에서 Datadog 엔지니어와 알찬 1시간을 보내보세요!
한국어 발표자: Sungwook Lee - 7월 10일 14:00 (한국시간 기준)
; https://www.datadoghq.com/ko/dg/webinars/demo-webinars-se-slo-ko/




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



donaricano-btn



[최초 등록일: ]
[최종 수정일: 8/4/2020

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)
12111정성태1/12/20203368디버깅 기술: 155. C# - KernelMemoryIO 드라이버를 이용해 실행 프로그램을 숨기는 방법(DKOM: Direct Kernel Object Modification) [12]
12110정성태1/11/20202821디버깅 기술: 154. Patch Guard로 인해 블루 스크린(BSOD)가 발생하는 사례 [5]파일 다운로드1
12109정성태1/10/20202313오류 유형: 588. Driver 프로젝트 빌드 오류 - Inf2Cat error -2: "Inf2Cat, signability test failed."
12108정성태1/10/20202098오류 유형: 587. Kernel Driver 시작 시 127(The specified procedure could not be found.) 오류 메시지 발생
12107정성태1/10/20202270.NET Framework: 877. C# - 프로세스의 모든 핸들을 열람 - 두 번째 이야기
12106정성태1/8/20202896VC++: 136. C++ - OSR Driver Loader와 같은 Legacy 커널 드라이버 설치 프로그램 제작 [1]
12105정성태1/8/20202346디버깅 기술: 153. C# - PEB를 조작해 로드된 DLL을 숨기는 방법
12104정성태1/7/20202582DDK: 9. 커널 메모리를 읽고 쓰는 NT Legacy driver와 C# 클라이언트 프로그램 [4]
12103정성태1/7/20204164DDK: 8. Visual Studio 2019 + WDK Legacy Driver 제작- Hello World 예제 [1]파일 다운로드2
12102정성태1/6/20202810디버깅 기술: 152. User 권한(Ring 3)의 프로그램에서 _ETHREAD 주소(및 커널 메모리를 읽을 수 있다면 _EPROCESS 주소) 구하는 방법
12101정성태1/5/20202365.NET Framework: 876. C# - PEB(Process Environment Block)를 통해 로드된 모듈 목록 열람
12100정성태1/3/20201979.NET Framework: 875. .NET 3.5 이하에서 IntPtr.Add 사용
12099정성태1/3/20202570디버깅 기술: 151. Windows 10 - Process Explorer로 확인한 Handle 정보를 windbg에서 조회
12098정성태1/2/20202439.NET Framework: 874. C# - 커널 구조체의 Offset 값을 하드 코딩하지 않고 사용하는 방법 [3]
12097정성태1/2/20201963디버깅 기술: 150. windbg - Wow64, x86, x64에서의 커널 구조체(예: TEB) 구조체 확인
12096정성태12/30/20192352디버깅 기술: 149. C# - DbgEng.dll을 이용한 간단한 디버거 제작
12095정성태12/27/20192682VC++: 135. C++ - string_view의 동작 방식
12094정성태12/26/20192422.NET Framework: 873. C# - 코드를 통해 PDB 심벌 파일 다운로드 방법
12093정성태12/26/20192813.NET Framework: 872. C# - 로딩된 Native DLL의 export 함수 목록 출력파일 다운로드1
12092정성태12/25/20192538디버깅 기술: 148. cdb.exe를 이용해 (ntdll.dll 등에 정의된) 커널 구조체 출력하는 방법
12091정성태12/25/20193560디버깅 기술: 147. pdb 파일을 다운로드하기 위한 symchk.exe 실행에 필요한 최소 파일 [1]
12090정성태12/24/20192410.NET Framework: 871. .NET AnyCPU로 빌드된 PE 헤더의 로딩 전/후 차이점
12089정성태12/23/20192392디버깅 기술: 146. gflags와 _CrtIsMemoryBlock을 이용한 Heap 메모리 손상 여부 체크
12088정성태12/23/20192210Linux: 28. Linux - 윈도우의 "Run as different user" 기능을 shell에서 실행하는 방법
12087정성태12/21/20192142디버깅 기술: 145. windbg/sos - Dictionary의 entries 배열 내용을 모두 덤프하는 방법 (do_hashtable.py) [1]
12086정성태12/20/20192797디버깅 기술: 144. windbg - Marshal.FreeHGlobal에서 발생한 덤프 분석 사례
... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...