Zipkin과 Scouter v2.5를 연동해보자.

이미지
Scouter v2.5 에 Zipkin 지원 기능이 추가되었다. 지난 9월말에 Scouter의 버전을 1.x에서 2.x로 올리며 v2의 방향을 다양한 오픈소스와의 통합으로 정하였는데 v2.5는 inbound로의 통합이 어느 정도 진행된 버전이다. (v2.0 telegraf 호환 서버 기능, v2.5 zipkin-scouter storage 기능) 그림. Scouter 구성 Zipkin과의 통합을 위해서는 Zipkin server의 storage를 scouter로 설정한 후 Zipkin server를 구동하면된다. 이때 필요에 따라 scouter의 collector의 IP등을 설정할 수 있다. 그러면 Zipkin server로 수집되는 span들은 scouter server로 저장되고 scouter의 client를 통해 이를 확인할 수 있다. 그럼 이제 Zipkin을 통하여 서비스의 Trace 데이터 수집하고 이를 Scouter의 XLog로 모니터링 해보도록 하자. 0. scouter server (v2.5) 실행 본 예제에서는 Scouter server v2.5가 실행된 vm과 동일한 vm에 zipkin server를 실행하는 것으로 가정하고 진행한다. 아래 Step들을 진행하기 전에 먼저 Scouter server v2.5+를 다운로드 받고 기동시킨다. Scouter를 처음 사용한다면 Scouter 설치하기 를 참고한다. 1. zipkin-scouter-storage를 포함하여 Zipkin server 실행하기 최신버전의 zipkin을 다운로드 받는다. wget -O zipkin.jar 'https://search.maven.org/remote_content?g=io.zipkin.java&a=zipkin-server&v=LATEST&c=exec' 최신버전의 zipkin-storage-scouter를 다운로드 받는다. wget -O zipk...

Scouter APM 소소한 시리즈 #5 - 사용자 정의 알림

이미지
Scouter is an APM optimized for developers. 사용자 정의 알림 설정하기  제가 Scouter에 대해 강조하는 것 중 하나가 "scouter는 개발자가 가장 잘 활용 할 수 있는 APM이다" 인데요, 그 이유가 압축 해제만으로 설치가 끝나고 소규모 장비의 일부 자원으로도 잘 돌아간다는 점도 있지만 가장 중요하게 생각하는 부분은 바로 개발자에게 주어진 자유도입니다. 특히 스크립트 방식의 플러그인을 통하면 개발자가 원하는 정보를 소스의 수정없이 scouter의 프로파일이나 xlog에 남길 수 있는데요, 이번 장에서는 이와 유사한 방식으로 스크립트를 통해 자유도 높은 알림 설정할 수 있는 기능을 소개하고자 합니다. (스크립트 방식의 플러그인 활용에 대해서는 다음에 다른 지면을 통해 다뤄보도록 하겠습니다.) 1. 알림 플러그인 설치 Scouter의 알림은 클라이언트 화면에서도 볼 수 있지만 플러그인을 설치하여 이메일이나 메신저로 확인하는 것이 좋습니다. Scouter는 email, slack, line 메신저등의 확장 플러그인을 가지고 있으며 scouter-project의 github 페이지에서 확인할 수 있습니다. 확장 플러그인 설치는 아래 순서로 진행합니다. 플러그인 릴리즈 제공하는 파일들을 모두 다운로드 받는다. 예를 들어 slack 플러그인을 설치하려면 scouter-server-plugin-alert-slack의 릴리즈 페이지에 있는 파일을 모두 다운로드 받는다.  https://github.com/scouter-project/scouter-plugin-server-alert-slack/releases/tag/v1.0.0 scouter collector server가 설치된 디렉토리 아래의 lib 디렉토리로 받은 파일들을 모두 복사한다. scouter collector를 재기동 한다. 설치된 plugin이 제대로 적용되는지는 collector 시작시 남는 로그를...

Scouter APM 소소한 시리즈 #4 - XLog 활용 - 상세기능

이미지
Scouter is an APM optimized for developers. XLog 활용 Scouter 개발시 가장 중점을 두었던 것 중 하나가 " XLog 차트 안에서 모든 문제를 다 해결할 수 있도록 하자 " 였습니다. 그래서 XLog 차트는 상당히 많은 기능을 가지고 있으며 그중 중요한 기능들에 대해 설명하도록 하겠습니다. 1. XLog의 조작 (1) 키보드를 통한 간편 이동 실시간 XLog 차트에서 키보드를 사용하여 XLog 차트의 시간을 이동시킬수 있습니다. 이를 통해 가까운 과거 시점으로 빠르게 이동이 가능합니다. (큰 시간을 이동하여야 하면 Load History 메뉴를 사용하여야 합니다.) 좌우 화살표 : 한번 누르는 경우 10초를 이동합니다. 상하 화살표 : 한번 누르는 경우 일정한 비율로 Y축의 스케일을 조절합니다. (2) Y축 항목 변경 <그림. XLog Y축 항목 변경> Y축 항목을 응답시간(ElapsedTime)이 아닌 다른 값으로 변경할 수 있습니다. 현재 서비스가 CPU bound인지 혹은 SQL이나 Api call bound인지를 한눈에 파악할때 주로 사용하게 됩니다. 혹은 SQL 호출 회수가 많은 서비스를 골라내거나, 메모리 사용량이 많은 서비스를 골라낼때 사용하기도 합니다. (3) Load History 과거 특정 시점의 XLog 차트를 로드하기 위해 사용합니다. (4) Summary <그림. XLog 통계> 화면에 표현된 XLog 점들에 대한 통계를 바로 확인할 수 있는 기능입니다. 예를 들면 각 서비스에 대한 총 호출 건수 및 총 응답시간, 평균 응답시간, SQL 및 API 호출에 대한 평균 응답시간 등을 확인할 수 있습니다. (5) Filter XLog를 통한 분석시 가장 많이 사용되는 기능중의 하나입니다. 원하는 조건의 XLog 점들만 보여지도록 하는 기...

Scouter APM 소소한 시리즈 #3 - Active Service와 XLog

이미지
Scouter is an APM optimized for developers. APM이 다른 모니터링 도구와의 차이점 중 하나는 발생한 문제의 결과가 아닌 원인에 접근할 수 있다는 것입니다. 이를 위해 Scouter에서는 어플리케이션이 지금 어떤 코드를 실행하고 어디서 지연되고 있는지를 파악할 수 있는 "Active Server 모니터링"과 이미 응답한 요청에 대해 상세 분석할 수 있는 Scatter 형식의 차트인 "XLog"를 제공합니다. 1. Active Service 모니터링 "Active service"란 현재 시점에 어플리케이션에서 수행되고 있는 요청을 나타냅니다. 이에 대한 모니터링은 주로 "Active Service EQ" 차트로 하게되는데, 서비스 지연으로 인한 장애를 가장 먼저 발견할 수 있는 차트이기도 합니다. <그림. Active Service EQ> 위 그림은 다섯개의 인스턴스를 모니터링하고 있으며 숫자는 현재 동시에 실행중인 서비스의 개수를 의미합니다. 지연되는 서비스는 3초 이후에는 노란색, 7초 이후에는 빨간색으로 표시가 됩니다. 여기서 실행중인 서비스의 정보를 알고 싶다면 상세히 보고싶은 인스턴스를 더블클릭하면 "Active Service List" 화면이 열리게 됩니다. <그림. Active Service List> 여기서는 호출된 서비스명과 현재까지 수행중인 시간(ms), 요청자 IP, 쿼리나 다른 서비스를 호출하고 대기중이라면 해당 쿼리나 서비스의 이름, Thread의 상태와 이름등이 보여집니다.  Service - 요청한 서비스의 이름 Elapsed - 현재 시점까지 수행중인 시간 Note - 현재 수행중인 쿼리 혹은 원격 호출하고 대기중인 다른 서비스 CPU - Thread가 생성된 후 현재까지 사용한 CPU IP - 요청자 IP State /...

SCOUTER 써드파티 UI인 "PAPER" 릴리즈 기념 빠르게 설치해보기

이미지
이미 Scouter의 코어나 Web API를 통해서 UI를 만드신다는 소식은 몇 번 접하였고, 몇몇 회사에서는 특정 제품의 APM 엔진으로 사용되거나 또는 기업 내부에서 사용하는 자체 APM으로 개발된 것도 보았습니다만 오픈 소스로 공개된 적은 없었습니다. 드디어 오픈소스로 개발된 스카우터의 첫번째 3rd party UI인 PAPER 가 나왔네요. 케빈님 감사합니다!! 호주 케빈님이 아닌 카카오 케빈님 이십니다. mindplates(마음판??) 또는 beperson(인간이되거라??)이라는 닉으로 주로 활동하십니다. 아 그리고 Paper를 같이 개발하실 분들 대모집 이라고 합니다. 관심 있으신 분들 컨택해 보시길.. 제가 연결해 드릴수도 있습니다. React로 개발되어 있으니 이쪽 관심있으신 분들이 많이 참여하셨으면 좋겠습니다.(전 UI알못이라...) 출시 기념으로 제가 설치를 한번 해보도록 하겠습니다. Paper를 사용하기 위해서는 scouter v1.8.4.1 이상을 사용하여야 합니다. 1. scouter demo 설치 여기서는 데모 환경을 설치하며 운영 환경에 설치할 경우는 정식 버전 설치 방법 에 따라 설치하여야 합니다. SCOUTER DEMO를 다운로드하고 압축을 풉니다. wget https://github.com/scouter-project/scouter-demo/releases/download/v1.8.4.1/demo-env1.tar.gz ... tar -xvzf demo-env1.tar.gz ... Scouter Server, Host Agent, 데모 환경(jpetstore)를 차례로 실행시킵니다. cd ./demo-env1 ./start-scouter-server.sh ... ./start-scouter-host.sh ... ./start-tomcat.sh ... 데모 환경에서는 가상의 부하를 줄수 있는 기능이 있습니다. 필요하다면 이를 실행합니다. 5분간 실행되며 종료시 이 script를 다시 실...

Scouter 스프린트 세션 사전 준비사항

Scouter 스프린트 세션 사전 준비사항 1. Notice 당일 13시20분까지 노트북을 지참하고 참석하여야 합니다. Tutorial 1시간, Sprint 2시간 진행됩니다. 노트북에는 Sprint를 원활히 진행할 수 있도록 Scouter 개발 환경이 설치되어 있어야 합니다. 당일에 설치해도 되지만 설치에 1시간 가량은 소모되므로, 커미터의 도움을 받아 진행하는 Sprint의 진행이 원할치 않을 수 있습니다. 2. Sprint를 진행 준비 및 사전 설치 프로그램 목록 JDK 8   GitHub 가입 Scouter 소스를 체크아웃 받고 PR를 올리기 위해 필요 Git 설치 아래 사이트에서 참고하여 설치하면 됩니다. https://goo.gl/up6rYq Windows의 경우는 아래 사이트에서 git bash 를 설치합니다. https://git-for-windows.github.io/ GitHub을 사용한 개발 흐름이 생소하다면 아래 사이트를 읽어 보시면 좋습니다. GitHub을 사용한 개발 전체 흐름 이해하기 https://goo.gl/dFUevj Maven 3 설치 https://maven.apache.org/install.html 개발 IDE 설치 Eclipse Neon 또는 IntelliJ Eclipse download : h ttp://www.eclipse.org/downloads/packages/eclipse-ide-java-ee-developers/neon3   IntelliJ  (커뮤니티버전) download :  https://www.jetbrains.com/idea/download/ 3. Scouter 개발환경 구성 아래 글을 참고하여 개발환경을 구성합니다. Scouter APM 개발환경 구성하기 : https://goo.gl/z5QisM 위 글의 내용 중 Scouter Clien...

Scouter APM 개발환경 구성하기

이미지
Scouter 개발 환경을 구성해보자. 사전 준비 사항 먼저 Java 8, Maven 3, Git 이 설치되어 있어야 하며 GitHub 계정이 있어야 한다. 당연히 PC에 Eclipse (Neon)나 IntelliJ 같은 개발 도구도 설치되어 있어야 한다. 1. GitHub에서 Fork 하기 Scouter Github 저장소에서 내 저장소로 Fork 한다. Scouter 저장소 : https://github.com/scouter-project/scouter (물론 당연히 예의상 Fork를 누르기 전에 Star를 먼저 눌러준다!) 개발환경을 구성하기 위해 좀 전에 Fork한 저장소를 내 PC로 Clone 한다. 필자의 경우는   git clone https://github.com/gunlee01/scouter.git develop branch로 변경한다. git checkout develop 2. Eclipse에 개발환경 구성하기  여기서는 Eclipse Neon3를 기준으로 설명한다.  현재 시점 최신버전인 Scouter 1.7.x 의 클라이언트 개발을 위해서는 Eclipse Neon이 필요하다. (1) Eclipse Neon을 Java 8로 실행한다. 기본 Java가 Java 8 JDK가 아닌경우에는 eclipse.ini에 vm 경로를 PC에 설치되어 있는 java 8 JDK로 설정한다. (2) git clone 받은 위치의 scouter project 소스를 eclipse로 import 한다. 우리는 이미 local PC에 소스를 받아놓은 상태이므로 " Existing Maven Project "로 import 받는다. 정상적으로 import되면 자동으로 빌드가 수행되는데 scouter.server 와 scouter.webapp 이 빌드가 되지 않을 수 있다. scouter.webapp은 ...

이 블로그의 인기 게시물

Scouter APM 소소한 시리즈 #1 - 설치하기

Scouter APM 소소한 시리즈 #4 - XLog 활용 - 상세기능

Scouter APM 소소한 시리즈 #2 - 기본 항목 모니터링(1/2)