시스템 튜토리얼 리눅스 Slack에서 발생하는 SQL 쿼리 모니터링

Slack에서 발생하는 SQL 쿼리 모니터링

Jan 17, 2024 pm 07:45 PM
linux 리눅스 튜토리얼 레드햇 리눅스 시스템 리눅스 명령 리눅스 인증 빨간 모자 리눅스 리눅스 비디오

Slack에서 발생하는 SQL 쿼리 모니터링

느린 쿼리, 예상치 못한 오류 및 기타 중요한 로그에 대한 알림을 받을 수 있는 간단한 Go 팁입니다.

내 Slack 봇이 장기 실행 SQL 쿼리에 대한 메시지를 표시했습니다. 최대한 빨리 고쳐야겠습니다.

측정할 수 없는 것은 관리할 수 없습니다. 모든 백엔드 애플리케이션은 데이터베이스 성능을 모니터링해야 합니다. 데이터 양이 증가함에 따라 특정 쿼리의 속도가 느려지는 경우 너무 느려지기 전에 쿼리를 최적화해야 합니다.

Slack이 업무의 중심이 되면서 시스템을 모니터링하는 방식도 바뀌고 있습니다. 이미 꽤 좋은 모니터링 도구가 있지만 Slack 봇이 시스템의 어떤 것이 추세를 벗어나는지 알려주도록 하는 것도 좋은 생각입니다. 예를 들어 SQL 쿼리를 완료하는 데 시간이 너무 오래 걸리거나 특정 Go 패키지에서 치명적인 오류가 발생합니다.

이 블로그 게시물에서는 이 목표를 달성하기 위해 이미 이러한 기능을 지원하는 간단한 로깅 시스템과 기존 데이터베이스 라이브러리를 설정하는 방법을 알려 드리겠습니다.

로거 사용

logger는 Go 라이브러리 및 애플리케이션에서 사용하도록 설계된 작은 라이브러리입니다. 이 예에서는 세 가지 중요한 기능을 사용합니다.

성능 측정을 위한 간단한 타이머를 제공합니다.
복잡한 출력 필터를 지원하므로 지정된 패키지에서 로그를 선택할 수 있습니다. 예를 들어, 데이터베이스 패킷에서만 출력하고 500ms보다 긴 타이머 로그만 출력하도록 로거에 지시할 수 있습니다.
Slack 후크가 있어 로그를 필터링하고 Slack에 공급할 수 있습니다.
이 예에서 타이머를 사용하는 방법을 살펴보겠습니다. 나중에 필터도 사용할 것입니다.

으아악

이 프로그램을 실행할 때 출력이 없습니다:

로거는 기본적으로 무음이므로 도서관 내부에서 사용할 수 있습니다. 간단히 환경 변수를 사용하여 로그를 봅니다. 예:

으아악

위의 예에서는 데이터베이스@timer 필터를 사용하여 데이터베이스 패키지의 타이머 로그 출력을 확인했습니다. 다음과 같은 다른 필터를 사용해 볼 수도 있습니다.

LOG=*: 모든 로그
LOG=users@error,database: 사용자의 모든 오류 로그, 데이터베이스의 모든 로그
LOG=*@timer,database@info: 모든 패키지의 타이머 로그 및 오류 로그, 데이터베이스의 모든 로그
LOG=*,users@mute: 사용자를 제외한 모든 로그

Slack에 로그 보내기

콘솔 로그는 개발 환경을 위한 로그이지만, 친숙한 인터페이스를 제공하기 위해서는 제품이 필요합니다. slack-hook 덕분에 위의 예에서 Slack을 사용하여 쉽게 통합할 수 있습니다.

으아악

위의 예에서 수행한 작업을 설명해 보겠습니다.

5번째 줄: 인바운드 웹훅 URL을 설정합니다. URL은 여기로 연결됩니다.
6행: 흐름 로그의 항목 채널을 선택합니다.
7행: 보낸 사람의 사용자 이름이 표시됩니다.
라인 #11: 스트림 필터를 사용하여 200ms보다 오래된 타이머 로그만 출력합니다.
이 예가 여러분에게 일반적인 아이디어를 제공할 수 있기를 바랍니다. 더 궁금한 점이 있으면 로거 설명서를 확인하세요.

실제 예: CRUD

crud는 Go 데이터베이스용 ORM 스타일 라이브러리입니다. 숨겨진 기능 중 하나는 내부 로깅 시스템이 로거를 사용한다는 것입니다. 이를 통해 실행 중인 SQL 쿼리를 쉽게 모니터링할 수 있습니다.

쿼리

다음은 특정 이메일에 대한 사용자 이름을 반환하는 간단한 쿼리입니다.

으아악

알겠습니다. 너무 짧아서 뭔가 빠진 것 같습니다. 전체 맥락을 추가해 보겠습니다.

으아악

환경 변수 DATABASE_URL을 통해 MySQL 데이터베이스에 연결된 crud 인스턴스가 있습니다. 이 프로그램을 실행하면 다음과 같은 출력 줄이 표시됩니다.

으아악

앞서 언급했듯이 로깅은 기본적으로 자동입니다. crud의 내부 로그를 살펴보겠습니다:

으아악

이것은 우리 개발 환경에서 쿼리가 어떻게 실행되는지를 이해하기에 간단하고 충분합니다.

CRUD 및 Slack 통합

Logger는 애플리케이션 수준 "내부 로깅 시스템"의 구성 관리를 위해 설계되었습니다. 이는 애플리케이션 수준에서 로거를 구성하여 crud 로그가 Slack으로 흐르도록 할 수 있음을 의미합니다.

으아악

위 코드에서:

로거 및 logger-slack-hook 라이브러리를 가져왔습니다.
Slack으로 흐르도록 로거 로그를 구성합니다. 이 구성에는 타사 종속성을 포함하여 코드 베이스의 로거 사용이 모두 포함됩니다.
우리는 MySQL 패키지에서 250ms보다 긴 타이머 로그만 출력하기 위해 스트림 필터를 사용했습니다.
이 사용법은 느린 쿼리 보고 이상으로 확장될 수 있습니다. 저는 개인적으로 특정 패키지의 중요한 오류를 추적하고 새로운 사용자 로그인이나 결제 생성 로그와 같은 통계를 위해 이를 사용합니다.

이 게시물에 언급된 팩

크러드

로거

로거-슬랙-훅

질문이나 제안사항이 있으면 알려주세요

위 내용은 Slack에서 발생하는 SQL 쿼리 모니터링의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Centos와 Ubuntu의 차이 Centos와 Ubuntu의 차이 Apr 14, 2025 pm 09:09 PM

Centos와 Ubuntu의 주요 차이점은 다음과 같습니다. Origin (Centos는 Red Hat, Enterprise의 경우, Ubuntu는 Debian에서 시작하여 개인의 경우), 패키지 관리 (Centos는 안정성에 중점을 둡니다. Ubuntu는 APT를 사용하여 APT를 사용합니다), 지원주기 (Ubuntu는 5 년 동안 LTS 지원을 제공합니다), 커뮤니티에 중점을 둔다 (Centos Conciors on ubuntu). 튜토리얼 및 문서), 사용 (Centos는 서버에 편향되어 있으며 Ubuntu는 서버 및 데스크탑에 적합), 다른 차이점에는 설치 단순성 (Centos는 얇음)이 포함됩니다.

Centos를 설치하는 방법 Centos를 설치하는 방법 Apr 14, 2025 pm 09:03 PM

CentOS 설치 단계 : ISO 이미지를 다운로드하고 부팅 가능한 미디어를 실행하십시오. 부팅하고 설치 소스를 선택하십시오. 언어 및 키보드 레이아웃을 선택하십시오. 네트워크 구성; 하드 디스크를 분할; 시스템 시계를 설정하십시오. 루트 사용자를 만듭니다. 소프트웨어 패키지를 선택하십시오. 설치를 시작하십시오. 설치가 완료된 후 하드 디스크에서 다시 시작하고 부팅하십시오.

유지 보수를 중단 한 후 Centos의 선택 유지 보수를 중단 한 후 Centos의 선택 Apr 14, 2025 pm 08:51 PM

Centos는 중단되었으며 대안은 다음과 같습니다. 1. Rocky Linux (Best Compatibility); 2. Almalinux (Centos와 호환); 3. Ubuntu 서버 (구성 필수); 4. Red Hat Enterprise Linux (상업용 버전, 유료 라이센스); 5. Oracle Linux (Centos 및 Rhel과 호환). 마이그레이션시 고려 사항은 호환성, 가용성, 지원, 비용 및 커뮤니티 지원입니다.

Docker Desktop을 사용하는 방법 Docker Desktop을 사용하는 방법 Apr 15, 2025 am 11:45 AM

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).

Docker 원리에 대한 자세한 설명 Docker 원리에 대한 자세한 설명 Apr 14, 2025 pm 11:57 PM

Docker는 Linux 커널 기능을 사용하여 효율적이고 고립 된 응용 프로그램 실행 환경을 제공합니다. 작동 원리는 다음과 같습니다. 1. 거울은 읽기 전용 템플릿으로 사용되며, 여기에는 응용 프로그램을 실행하는 데 필요한 모든 것을 포함합니다. 2. Union 파일 시스템 (Unionfs)은 여러 파일 시스템을 스택하고 차이점 만 저장하고 공간을 절약하고 속도를 높입니다. 3. 데몬은 거울과 컨테이너를 관리하고 클라이언트는 상호 작용을 위해 사용합니다. 4. 네임 스페이스 및 CGroup은 컨테이너 격리 및 자원 제한을 구현합니다. 5. 다중 네트워크 모드는 컨테이너 상호 연결을 지원합니다. 이러한 핵심 개념을 이해 함으로써만 Docker를 더 잘 활용할 수 있습니다.

Centos 후해야 할 일은 유지 보수를 중단합니다 Centos 후해야 할 일은 유지 보수를 중단합니다 Apr 14, 2025 pm 08:48 PM

Centos가 중단 된 후 사용자는 다음과 같은 조치를 취할 수 있습니다. Almalinux, Rocky Linux 및 Centos 스트림과 같은 호환되는 분포를 선택하십시오. Red Hat Enterprise Linux, Oracle Linux와 같은 상업 분포로 마이그레이션합니다. Centos 9 Stream : 롤링 분포로 업그레이드하여 최신 기술을 제공합니다. Ubuntu, Debian과 같은 다른 Linux 배포판을 선택하십시오. 컨테이너, 가상 머신 또는 클라우드 플랫폼과 같은 다른 옵션을 평가하십시오.

Docker 이미지가 실패하면해야 할 일 Docker 이미지가 실패하면해야 할 일 Apr 15, 2025 am 11:21 AM

실패한 Docker 이미지 빌드에 대한 문제 해결 단계 : Dockerfile 구문 및 종속성 버전을 확인하십시오. 빌드 컨텍스트에 필요한 소스 코드 및 종속성이 포함되어 있는지 확인하십시오. 오류 세부 사항에 대한 빌드 로그를보십시오. -표적 옵션을 사용하여 계층 적 단계를 구축하여 실패 지점을 식별하십시오. 최신 버전의 Docker Engine을 사용하십시오. -t [image-name] : 디버그 모드로 이미지를 빌드하여 문제를 디버깅하십시오. 디스크 공간을 확인하고 충분한 지 확인하십시오. 빌드 프로세스에 대한 간섭을 방지하기 위해 Selinux를 비활성화하십시오. 커뮤니티 플랫폼에 도움을 요청하고 Dockerfiles를 제공하며보다 구체적인 제안을 위해 로그 설명을 구축하십시오.

VSCODE에 필요한 컴퓨터 구성 VSCODE에 필요한 컴퓨터 구성 Apr 15, 2025 pm 09:48 PM

대 코드 시스템 요구 사항 : 운영 체제 : Windows 10 이상, MacOS 10.12 이상, Linux 배포 프로세서 : 최소 1.6GHz, 권장 2.0GHz 이상의 메모리 : 최소 512MB, 권장 4GB 이상의 저장 공간 : 최소 250MB, 권장 1GB 및 기타 요구 사항 : 안정 네트워크 연결, Xorg/Wayland (LINUX)

See all articles