mysql客户端怎么运行程序(MySQL 如何连接对应的客户端进程)
mysql客户端怎么运行程序
MySQL 如何连接对应的客户端进程问题
对于一个给定的 MySQL 连接,我们如何才能知道它来自于哪个客户端的哪个进程呢?
HandshakeResponse
MySQL-Client 在连接 MySQL-Server 的时候,不只会把用户名密码发送到服务端,还会把当前进程id,操作系统名,主机名等等信息也发到服务端。这个数据包就叫 HandshakeResponse 官方有对其格式进行详细的说明。
我自己改了一个连接驱动,用这个驱动可以看到连接时发送了哪些信息。
|
2020-05-19 15:31:04,976 - mysql-connector-python.mysql.connector.protocol.MySQLProtocol.make_auth - MainThread - 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 capability flags, CLIENT_PROTOCOL_41 always set 4 max -packet size 1 character set string[23] reserved ( all [0]) string[NUL] username if capabilities & CLIENT_PLUGIN_AUTH_LENENC_CLIENT_DATA { lenenc- int length of auth-response string[n] auth-response } else if capabilities & CLIENT_SECURE_CONNECTION { 1 length of auth-response string[n] auth-response } else { string[NUL] auth-response } if capabilities & CLIENT_CONNECT_WITH_DB { string[NUL] database } if capabilities & CLIENT_PLUGIN_AUTH { string[NUL] auth plugin name } if capabilities & CLIENT_CONNECT_ATTRS { lenenc- int length of all key - values lenenc-str key lenenc-str value if-more data in 'length of all key-values' , more keys and value pairs } |
解决方案
从前面的内容我们可以知道 MySQL-Client 确实向 MySQL-Server 发送了当前的进程 id ,这为解决问题提供了最基本的可能性。当服务端收到这些信息后双把它们保存到了 performance_schema.session_connect_attrs。
第一步通过 information_schema.processlist 查询关心的连接,它来自于哪个 IP,和它的 processlist_id 。
|
mysql> select * from information_schema.processlist; + ----+---------+--------------------+--------------------+---------+------+-----------+----------------------------------------------+ | ID | USER | HOST | DB | COMMAND | TIME | STATE | INFO | + ----+---------+--------------------+--------------------+---------+------+-----------+----------------------------------------------+ | 8 | root | 127.0.0.1:57760 | performance_schema | Query | 0 | executing | select * from information_schema.processlist | | 7 | appuser | 172.16.192.1:50198 | NULL | Sleep | 2682 | | NULL | + ----+---------+--------------------+--------------------+---------+------+-----------+----------------------------------------------+ 2 rows in set (0.01 sec) |
第二步通过 performance_schema.session_connect_attrs 查询连接的进程 ID
|
mysql> select * from session_connect_attrs where processlist_id = 7; + ----------------+-----------------+------------------------+------------------+ | PROCESSLIST_ID | ATTR_NAME | ATTR_VALUE | ORDINAL_POSITION | + ----------------+-----------------+------------------------+------------------+ | 7 | _pid | 58471 | 0 | | 7 | _platform | x86_64 | 1 | | 7 | _source_host | NEEKYJIANG-MB1 | 2 | | 7 | _client_name | mysql-connector-python | 3 | | 7 | _client_license | GPL-2.0 | 4 | | 7 | _client_version | 8.0.20 | 5 | | 7 | _os | macOS-10.15.3 | 6 | + ----------------+-----------------+------------------------+------------------+ 7 rows in set (0.00 sec) |
可以看到 processlist_id = 7 的这个连接是由 172.16.192.1 的 58471 号进程发起的。
检查
我刚才是用的 ipython 连接的数据库,ps 看到的结果也正是 58471 与查询出来的结果一致。
|
ps -ef | grep 58471 501 58471 57741 0 3:24下午 ttys001 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 连接对应的客户端进程的资料请关注开心学习网其它相关文章!
原文链接:https://www.sqlpy.com/blogs/283699273
- MySQL SQL Assistant智能提示
- php考试复习题(php+mysql开发的最简单在线题库在线做题系统完整案例)
- mysql数据库与表的基本操作总结(Mysql、Oracle中常用的多表修改语句总结)
- redhat6.5安装mysql(Redhat7.3安装MySQL8.0.22的详细教程二进制安装)
- mysql 慢查询排查方法(MYSQL慢查询和日志实例讲解)
- mysql数据库死锁原理(MySQL数据库锁机制原理解析)
- mysql账户访问权限(MySQL 权限控制详解)
- 软件测试常用mysql语句(MySQL压力测试工具Mysqlslap的使用)
- linux安装nacos教程(Nacos配置MySQL8的方法)
- 怎么看mysql有没有外键约束(MySQL外键约束的实例讲解)
- 修改mysql安装服务名称(Apache为mysql以及自己的项目设置虚拟路径)
- mysql事务特性和隔离级别(Mysql事务特性和级别原理解析)
- mysql水平拓展的瓶颈(MySQL令人大跌眼镜的隐式转换)
- mysql事务未提交会锁表吗(Mysql事务中Update是否会锁表?)
- mysql对null值如何理解(MySQL为Null会导致5个问题个个致命)
- mysql查询语法总结(MySQL全面瓦解之查询的过滤条件详解)
- 当年的 白洋淀战神 练肌肉 嘎子哥也成为行走的荷尔蒙(当年的白洋淀战神)
- 肌肉小子陈康, 亚洲巨兽 黄哲勋,哪个才是你的菜(肌肉小子陈康亚洲巨兽)
- 新闻周刊 青岛网红 赵厂长 编段子一箩筐输出快乐,陪父亲十二载勇斗病魔(新闻周刊青岛网红)
- 44岁夏雨演谋女郎爸,大其24岁却看不出,互动不怕袁泉吃醋(44岁夏雨演谋女郎爸)
- 全椒人,你还记得吗 那年,那人,那网,那些我们的青春记忆(全椒人你还记得吗)
- 全椒人在苏州10周年联谊会在苏州举办(全椒人在苏州10周年联谊会在苏州举办)
热门推荐
- 使用Console命令调试JS
- python时间序列模式识别(Python时间序列处理之ARIMA模型的使用讲解)
- mysql缓存是什么(详解mysql查询缓存简单使用)
- php异常和错误区别(PHP批斗大会之缺失的异常详解)
- 将SQL Server数据迁移到MySQL的方法
- 日常操作docker命令(SEATA事务服务DOCKER部署的过程详解)
- Asp.net导出Excel乱码
- dedecms更新后设置空白(Dedecms去掉URL中a目录的方法)
- win10上装ubuntu系统(Windows 10 太难用如何定制你的 Ubuntu方法详解)
- dedecms数据库优化(dedecms友情链接flink增加下拉菜单的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9