ホームページ システムチュートリアル Linux Slack 上で発生する SQL クエリの監視

Slack 上で発生する SQL クエリの監視

Jan 17, 2024 pm 07:45 PM
linux Linuxチュートリアル レッドハット Linuxシステム Linuxコマンド Linux 認定 レッドハットリナックス Linuxビデオ

Slack 上で発生する SQL クエリの監視

遅いクエリ、予期しないエラー、その他の重要なログに関する通知を取得するための簡単な Go ヒント。

Slack ボットから、長時間実行されている SQL クエリについてのメッセージが表示されました。できるだけ早く直さなければなりません。

測定できないものを管理することはできません。すべてのバックエンド アプリケーションでは、データベース上のパフォーマンスを監視する必要があります。データ量の増加に伴って特定のクエリの速度が低下する場合は、速度が低下しすぎる前にクエリを最適化する必要があります。

Slack が私たちの仕事の中心となるにつれて、システムを監視する方法も変わりつつあります。私たちはすでに非常に優れた監視ツールを持っていますが、システム内の何かが減少傾向にあるかどうかを Slack ボットに知らせてもらうことも素晴らしいアイデアです。たとえば、SQL クエリの完了に時間がかかりすぎたり、特定の Go パッケージで致命的なエラーが発生したりします。

このブログ投稿では、この目標を達成するために、これらの機能と既存のデータベース ライブラリをすでにサポートしている単純なログ システムをセットアップする方法について説明します。

ロガーを使用する

logger は、Go ライブラリおよびアプリケーションで使用するために設計された小さなライブラリです。この例では、次の 3 つの重要な機能を使用します。

パフォーマンスを測定するためのシンプルなタイマーを提供します。

複雑な出力フィルターをサポートしているため、指定したパッケージからログを選択できます。たとえば、データベース パケットからのみ出力し、500 ミリ秒を超えるタイマー ログのみを出力するようにロガーに指示できます。
Slack フックを備えているため、ログをフィルタリングして Slack にフィードできます。
この例でタイマーを使用する方法を見てみましょう。後でフィルターも使用します:
リーリー

このプログラムを実行しても出力はありません:

ロガーはデフォルトではサイレントであるため、ライブラリ内で使用できます。単に環境変数を使用してログを表示します。例:

リーリー

上記の例では、database@timer フィルターを使用して、データベース パッケージのタイマー ログ出力を表示しました。

などの他のフィルターを試すこともできます。

LOG=*: すべてのログ

LOG=users@error,database: ユーザーからのすべてのエラー ログ、データベースからのすべてのログ
LOG=*@timer,database@info: すべてのパッケージからのタイマー ログとエラー ログ、およびデータベースからのすべてのログ
LOG=*,users@mute: users
を除くすべてのログ

ログを Slack に送信する コンソール ログは開発環境用ですが、製品には使いやすいインターフェイスを提供する必要があります。スラックフックのおかげで、上記の例では Slack を使用して簡単に統合できます。 リーリー

上の例で何をしたか説明しましょう:

5 行目: 受信 Webhook URL を設定します。 URLはここにリンクされています。

行 #6: フロー ログのエントリ チャネルを選択します。

行 #7: 送信者のユーザー名が表示されます。
行 #11: ストリーム フィルターを使用して、200 ミリ秒より古いタイマー ログのみを出力します。
この例が一般的なアイデアを理解できることを願っています。さらに質問がある場合は、ロガーのドキュメントを参照してください。

実際の例: CRUD

crud は Go データベース用の ORM スタイルのクラス ライブラリであり、その隠れた機能の 1 つは、内部ログ システムがロガーを使用していることです。これにより、実行中の SQL クエリを簡単に監視できるようになります。

お問い合わせ

これは、指定された電子メールのユーザー名を返す簡単なクエリです: リーリー

わかりました、これは短すぎます。何かが欠けているように感じます。完全なコンテキストを追加しましょう:

リーリー

つまり、環境変数 DATABASE_URL を介して MySQL データベースに接続された crud インスタンスがあります。このプログラムを実行すると、次の出力行が表示されます。 リーリー

前に述べたように、ログはデフォルトではサイレントです。 crud の内部ログを見てみましょう:

リーリー

これは単純であり、開発環境でクエリがどのように実行されるかを確認するには十分です。

CRUD と Slack の統合

ロガーは、アプリケーション レベルの「内部ログ システム」の構成管理用に設計されています。これは、アプリケーション レベルでロガーを設定することで、未処理のログを Slack に流入させることができることを意味します: リーリー 上記のコード内:

logger ライブラリと logger-slack-hook ライブラリをインポートしました。

ロガーのログが Slack に流れるように設定します。この構成は、サードパーティの依存関係を含む、コード ベースでのロガーのすべての使用をカバーします。

ストリーム フィルターを使用して、MySQL パッケージから 250 ミリ秒を超えるタイマー ログのみを出力しました。

この使用法は、スロー クエリのレポート以外にも拡張できます。私は個人的に、指定したパッケージの重要なエラーを追跡するために、また、新しいユーザーのログインや支払い生成ログなどの統計のためにこれを使用しています。

この記事で言及されているパッケージ

ひどい ロガー

ロガー-スラックフック

ご質問やご提案がありましたらお聞かせください

以上がSlack 上で発生する SQL クエリの監視の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CentosとUbuntuの違い CentosとUbuntuの違い Apr 14, 2025 pm 09:09 PM

Centosとubuntuの重要な違いは次のとおりです。起源(CentosはRed Hat、for Enterprises、UbuntuはDebianに由来します。個人用のDebianに由来します)、パッケージ管理(CentosはYumを使用し、安定性に焦点を当てます。チュートリアルとドキュメント)、使用(Centosはサーバーに偏っています。Ubuntuはサーバーやデスクトップに適しています)、その他の違いにはインストールのシンプルさが含まれます(Centos is Thin)

Centosをインストールする方法 Centosをインストールする方法 Apr 14, 2025 pm 09:03 PM

Centosのインストール手順:ISO画像をダウンロードし、起動可能なメディアを燃やします。起動してインストールソースを選択します。言語とキーボードのレイアウトを選択します。ネットワークを構成します。ハードディスクをパーティション化します。システムクロックを設定します。ルートユーザーを作成します。ソフトウェアパッケージを選択します。インストールを開始します。インストールが完了した後、ハードディスクから再起動して起動します。

メンテナンスを停止した後のCentosの選択 メンテナンスを停止した後のCentosの選択 Apr 14, 2025 pm 08:51 PM

Centosは廃止されました、代替品には次のものが含まれます。1。RockyLinux(最高の互換性)。 2。アルマリン(Centosと互換性); 3。Ubuntuサーバー(設定が必要); 4。RedHat Enterprise Linux(コマーシャルバージョン、有料ライセンス); 5。OracleLinux(CentosとRhelと互換性があります)。移行する場合、考慮事項は次のとおりです。互換性、可用性、サポート、コスト、およびコミュニティサポート。

Dockerデスクトップの使用方法 Dockerデスクトップの使用方法 Apr 15, 2025 am 11:45 AM

Dockerデスクトップの使用方法は? Dockerデスクトップは、ローカルマシンでDockerコンテナを実行するためのツールです。使用する手順には次のものがあります。1。Dockerデスクトップをインストールします。 2。Dockerデスクトップを開始します。 3。Docker Imageを作成します(DockerFileを使用); 4. Docker画像をビルド(Docker Buildを使用); 5。Dockerコンテナを実行します(Docker Runを使用)。

Dockerの原則の詳細な説明 Dockerの原則の詳細な説明 Apr 14, 2025 pm 11:57 PM

DockerはLinuxカーネル機能を使用して、効率的で孤立したアプリケーションランニング環境を提供します。その作業原則は次のとおりです。1。ミラーは、アプリケーションを実行するために必要なすべてを含む読み取り専用テンプレートとして使用されます。 2。ユニオンファイルシステム(UnionFS)は、違いを保存するだけで、スペースを節約し、高速化する複数のファイルシステムをスタックします。 3.デーモンはミラーとコンテナを管理し、クライアントはそれらをインタラクションに使用します。 4。名前空間とcgroupsは、コンテナの分離とリソースの制限を実装します。 5.複数のネットワークモードは、コンテナの相互接続をサポートします。これらのコア概念を理解することによってのみ、Dockerをよりよく利用できます。

Centosがメンテナンスを停止した後の対処方法 Centosがメンテナンスを停止した後の対処方法 Apr 14, 2025 pm 08:48 PM

CentOSが停止した後、ユーザーは次の手段を採用して対処できます。Almalinux、Rocky Linux、Centosストリームなどの互換性のある分布を選択します。商業分布に移行する:Red Hat Enterprise Linux、Oracle Linuxなど。 Centos 9ストリームへのアップグレード:ローリングディストリビューション、最新のテクノロジーを提供します。 Ubuntu、Debianなど、他のLinuxディストリビューションを選択します。コンテナ、仮想マシン、クラウドプラットフォームなどの他のオプションを評価します。

Docker画像が失敗した場合はどうすればよいですか Docker画像が失敗した場合はどうすればよいですか Apr 15, 2025 am 11:21 AM

障害のあるDocker画像ビルドのトラブルシューティング手順:DockerFileの構文と依存関係バージョンを確認します。ビルドコンテキストに必要なソースコードと依存関係が含まれているかどうかを確認します。エラーの詳細については、ビルドログを表示します。 -targetオプションを使用して、階層フェーズを構築して障害点を識別します。 Dockerエンジンの最新バージョンを使用してください。 -t [image-name]:デバッグモードで画像を作成して、問題をデバッグします。ディスクスペースを確認し、十分であることを確認してください。 Selinuxを無効にして、ビルドプロセスへの干渉を防ぎます。コミュニティプラットフォームに助けを求め、DockerFilesを提供し、より具体的な提案のためにログの説明を作成します。

VSCODEに必要なコンピューター構成 VSCODEに必要なコンピューター構成 Apr 15, 2025 pm 09:48 PM

VSコードシステムの要件:オペレーティングシステム:オペレーティングシステム:Windows 10以降、MACOS 10.12以上、Linux Distributionプロセッサ:最小1.6 GHz、推奨2.0 GHz以上のメモリ:最小512 MB、推奨4 GB以上のストレージスペース:最低250 MB以上:その他の要件を推奨:安定ネットワーク接続、XORG/WAYLAND(Linux)

See all articles