質問 特定の MySQL 接続について、それがどのクライアント プロセスからのものであるかをどのように知ることができますか? ハンドシェイクレスポンス MySQL クライアントが MySQL サーバーに接続すると、ユーザー名とパスワードがサーバーに送信されるだけでなく、現在のプロセス ID、オペレーティング システム名、ホスト名などの情報もサーバーに送信されます。このデータ パケットは HandshakeResponse と呼ばれ、公式 Web サイトにそのフォーマットの詳細な説明があります。 接続ドライバーを自分で変更し、これを使用して接続時に送信される情報を確認できるようになりました。 2020-05-19 15:31:04,976 - mysql-connector-python.mysql.connector.protocol.MySQLProtocol.make_auth - メインスレッド - INFO - conn-attrs {'_pid': '58471'、'_platform': 'x86_64'、'_source_host': 'NEEKYJIANG-MB1'、'_client_name': 'mysql-connector-python'、'_client_license': 'GPL-2.0'、'_client_version': '8.0.20'、'_os': 'macOS-10.15.3'} HandshakeResponse パケットのバイト形式は次のとおりです。送信されるデータはパケットの最後にあります。 4 つの機能フラグ、CLIENT_PROTOCOL_41 は常に設定されています 4 最大パケットサイズ 1文字セット 文字列[23] 予約済み(すべて[0]) 文字列[NUL] ユーザー名 機能とCLIENT_PLUGIN_AUTH_LENENC_CLIENT_DATA {の場合 lenenc-int 認証応答の長さ 文字列[n] 認証応答 } それ以外の場合、機能と CLIENT_SECURE_CONNECTION が 1 認証応答の長さ 文字列[n] 認証応答 } それ以外 { 文字列[NUL] 認証応答 } 機能とCLIENT_CONNECT_WITH_DB { 文字列[NUL] データベース } 機能とCLIENT_PLUGIN_AUTH { 文字列[NUL] 認証プラグイン名 } 機能とCLIENT_CONNECT_ATTRS { lenenc-int すべてのキー値の長さ lenenc-str キー lenenc-str 値 'すべてのキーと値の長さ' にデータがある場合、キーと値のペアがさらにあります } 解決 前述の内容から、MySQL クライアントが現在のプロセス ID を MySQL サーバーに送信していることがわかります。これが問題を解決するための最も基本的な可能性を提供します。サーバーはこの情報を受信すると、performance_schema.session_connect_attrs に保存します。 最初のステップは、関心のある接続、その接続元の IP、およびその processlist_id について information_schema.processlist を照会することです。 mysql> information_schema.processlist から * を選択します。 +----+---------+--------------------+--------------------+--------+-----------+-----------+----------------------------------------------+ | ID | ユーザー | ホスト | DB | コマンド | 時間 | 状態 | 情報 | +----+---------+--------------------+--------------------+--------+-----------+-----------+----------------------------------------------+ | 8 | ルート | 127.0.0.1:57760 | performance_schema | クエリ | 0 | 実行中 | information_schema.processlist から * を選択 | | 7 | appuser | 172.16.192.1:50198 | NULL | スリープ | 2682 | | NULL | +----+---------+--------------------+--------------------+--------+-----------+-----------+----------------------------------------------+ セットに2行(0.01秒) 2番目のステップは、performance_schema.session_connect_attrsを介して接続のプロセスIDを照会することです。 mysql> processlist_id = 7 の場合、session_connect_attrs から * を選択します。 +----------------+-----------------+------------------------+------------------+ | プロセスリスト ID | ATTR_NAME | ATTR_VALUE | ORDINAL_POSITION | +----------------+-----------------+------------------------+------------------+ | 7 | _pid | 58471 | 0 | | 7 | _プラットフォーム | x86_64 | 1 | | 7 | _source_host | NEEKYJIANG-MB1 | 2 | | 7 | _client_name | mysql-connector-python | 3 | | 7 | _client_license | GPL-2.0 | 4 | | 7 | _クライアントバージョン | 8.0.20 | 5 | | 7 | _os | macOS-10.15.3 | 6 | +----------------+-----------------+------------------------+------------------+ セット内の行数は 7 です (0.00 秒) processlist_id = 7 の接続は、172.16.192.1 のプロセス 58471 によって開始されていることがわかります。 診る ipython を使用してデータベースに接続したところ、ps から表示された結果は 58471 とまったく同じで、クエリ結果と一致していました。 ps -ef | grep 58471 501 58471 57741 0 3:24 PMttys001 0:03.67 /Library/Frameworks/Python.framework/Versions/3.8/Resources/Python.app/Contents/MacOS/Python /Library/Frameworks/Python.framework/Versions/3.8/bin/ipython 上記は、MySQL が対応するクライアント プロセスに接続する方法の詳細です。MySQL 接続の対応するクライアント プロセスの詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: Docker で Tomcat、MySQL、Redis をインストールするための詳細な手順
>>: テーブル内の要素のドラッグと並べ替えの問題について簡単に説明します
序文最近、レポート機能に取り組んでいたのですが、ある月に各部署に入社した人と退職した人の数をカウント...
この記事では、タイムライン効果を実現するためのvue+swiperの具体的なコードを参考までに共有し...
WeChat ミニプログラム - QR コード ジェネレーターダウンロード: weapp-qrcod...
注: nginxはbrew経由でインストールされますウェブサイトのルートディレクトリ: /opt/h...
参考までに、win7システム上のVMware仮想マシンにlinux7.2インターネットアクセス構成を...
1. Javascript は前のページ history.go(-1) に戻り、2 つのページを返し...
まずは、以前書いた CSS カルーセルアニメーション効果を見てみましょう。アニメーションの遷移をスム...
最近、私はプロジェクトに取り組んでおり、背景を記述するために SQL ステートメントを使用する必要が...
XHTML は CSS レイアウトの基礎です。jb51.net は常に XHTML 知識の習得を重視...
目次コード:補充:要約する要件: 左のツリーと右のテーブル。組織ツリーでノードを選択した後、詳細ペー...
以前は、このような使用シナリオを処理するために rand() で直接 order していましたが、効...
序文MySQL を学習する際に、MySQL のロック メカニズムについて簡単に理解したことがあると思...
目次問題の説明MySQLオンラインDDLで列を追加する従来の方法01 コピー方法02 インプレースメ...
rm コマンドrm コマンドは、ファイルを削除するときによく使用されるコマンドです。ファイルまたはデ...
1. ダウンロード公式サイトからmysql-5.7.19-linux-glibc2.12-x86_6...