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
を除くすべてのログ
上の例で何をしたか説明しましょう:
5 行目: 受信 Webhook URL を設定します。 URLはここにリンクされています。
行 #6: フロー ログのエントリ チャネルを選択します。
行 #7: 送信者のユーザー名が表示されます。
行 #11: ストリーム フィルターを使用して、200 ミリ秒より古いタイマー ログのみを出力します。
この例が一般的なアイデアを理解できることを願っています。さらに質問がある場合は、ロガーのドキュメントを参照してください。
実際の例: CRUD
お問い合わせ
これは、指定された電子メールのユーザー名を返す簡単なクエリです: リーリーわかりました、これは短すぎます。何かが欠けているように感じます。完全なコンテキストを追加しましょう:
リーリーつまり、環境変数 DATABASE_URL を介して MySQL データベースに接続された crud インスタンスがあります。このプログラムを実行すると、次の出力行が表示されます。 リーリー
前に述べたように、ログはデフォルトではサイレントです。 crud の内部ログを見てみましょう:リーリー
これは単純であり、開発環境でクエリがどのように実行されるかを確認するには十分です。CRUD と Slack の統合
ロガーは、アプリケーション レベルの「内部ログ システム」の構成管理用に設計されています。これは、アプリケーション レベルでロガーを設定することで、未処理のログを Slack に流入させることができることを意味します: リーリー 上記のコード内:
logger ライブラリと logger-slack-hook ライブラリをインポートしました。
ロガーのログが Slack に流れるように設定します。この構成は、サードパーティの依存関係を含む、コード ベースでのロガーのすべての使用をカバーします。
ストリーム フィルターを使用して、MySQL パッケージから 250 ミリ秒を超えるタイマー ログのみを出力しました。
この使用法は、スロー クエリのレポート以外にも拡張できます。私は個人的に、指定したパッケージの重要なエラーを追跡するために、また、新しいユーザーのログインや支払い生成ログなどの統計のためにこれを使用しています。
この記事で言及されているパッケージ
ロガー-スラックフック
ご質問やご提案がありましたらお聞かせください
以上がSlack 上で発生する SQL クエリの監視の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

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

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

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