MySQL中统计各个IP的连接数的方法总结

 更新时间:2025年12月19日 08:39:57   作者:「光与松果」  
本文介绍了多种在MySQL中统计各个IP连接数的方法,包括查询INFORMATION_SCHEMA.PROCESSLIST、使用SHOW PROCESSLIST命令、实时监控脚本、定期统计并记录到表等,此外,还提供了一些实用技巧,需要的朋友可以参考下

MySQL中统计各个IP的连接数

在MySQL中统计各个IP的连接数,可以使用以下几种方法:

方法1:查询 INFORMATION_SCHEMA.PROCESSLIST

SELECT 
    SUBSTRING_INDEX(host, ':', 1) AS client_ip,
    COUNT(*) AS connection_count
FROM information_schema.processlist 
WHERE host != ''
GROUP BY client_ip
ORDER BY connection_count DESC;

方法2:使用 SHOW PROCESSLIST 命令

-- 先创建临时表存储结果
CREATE TEMPORARY TABLE temp_processlist AS
SHOW PROCESSLIST;

-- 然后查询统计
SELECT 
    SUBSTRING_INDEX(host, ':', 1) AS client_ip,
    COUNT(*) AS connection_count
FROM temp_processlist
WHERE host != ''
GROUP BY client_ip
ORDER BY connection_count DESC;

方法3:更详细的连接信息统计

SELECT 
    SUBSTRING_INDEX(host, ':', 1) AS client_ip,
    COUNT(*) AS total_connections,
    SUM(CASE WHEN command = 'Sleep' THEN 1 ELSE 0 END) AS sleep_connections,
    SUM(CASE WHEN command != 'Sleep' THEN 1 ELSE 0 END) AS active_connections,
    GROUP_CONCAT(DISTINCT user) AS connected_users
FROM information_schema.processlist 
WHERE host != ''
GROUP BY client_ip
ORDER BY total_connections DESC;

方法4:实时监控脚本(Shell)

#!/bin/bash
# 保存为 monitor_connections.sh

mysql -u root -p -e "
SELECT 
    SUBSTRING_INDEX(host, ':', 1) AS '客户端IP',
    COUNT(*) AS '连接数',
    GROUP_CONCAT(DISTINCT USER) AS '用户列表'
FROM information_schema.processlist 
WHERE host != ''
GROUP BY SUBSTRING_INDEX(host, ':', 1)
ORDER BY COUNT(*) DESC;"

方法5:定期统计并记录到表

-- 创建统计记录表
CREATE TABLE IF NOT EXISTS connection_stats (
    id INT AUTO_INCREMENT PRIMARY KEY,
    stat_time DATETIME DEFAULT CURRENT_TIMESTAMP,
    client_ip VARCHAR(45),
    connection_count INT,
    unique_users INT
);

-- 插入统计数据的存储过程
DELIMITER //
CREATE PROCEDURE log_connection_stats()
BEGIN
    INSERT INTO connection_stats (client_ip, connection_count, unique_users)
    SELECT 
        SUBSTRING_INDEX(host, ':', 1) AS client_ip,
        COUNT(*) AS connection_count,
        COUNT(DISTINCT user) AS unique_users
    FROM information_schema.processlist 
    WHERE host != ''
    GROUP BY SUBSTRING_INDEX(host, ':', 1);
END //
DELIMITER ;

-- 执行统计
CALL log_connection_stats();

方法6:查看当前连接详情

SELECT 
    ID as connection_id,
    USER as mysql_user,
    SUBSTRING_INDEX(host, ':', 1) AS client_ip,
    DB as database_name,
    COMMAND as command_type,
    TIME as time_seconds,
    STATE as connection_state,
    INFO as current_query
FROM information_schema.processlist 
WHERE host != ''
ORDER BY client_ip, TIME DESC;

实用技巧

1. 查找连接数过多的IP

SELECT 
    SUBSTRING_INDEX(host, ':', 1) AS client_ip,
    COUNT(*) AS connection_count
FROM information_schema.processlist 
WHERE host != ''
GROUP BY client_ip
HAVING connection_count > 10  -- 设置阈值
ORDER BY connection_count DESC;

2. 杀死特定IP的所有连接

-- 先生成kill语句预览
SELECT CONCAT('KILL ', ID, ';') AS kill_command
FROM information_schema.processlist 
WHERE SUBSTRING_INDEX(host, ':', 1) = '192.168.1.100';  -- 替换为目标IP

-- 确认无误后执行kill

到此这篇关于MySQL中统计各个IP的连接数的方法总结的文章就介绍到这了,更多相关MySQL统计IP连接数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql 5.7.13 解压缩版(免安装)安装配置教程

    mysql 5.7.13 解压缩版(免安装)安装配置教程

    这篇文章主要介绍了MySQL 5.7.13 for Windows解压缩版(免安装)安装配置教程,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • mysql 临时表 cann''t reopen解决方案

    mysql 临时表 cann''t reopen解决方案

    MySql关于临时表cann't reopen的问题,本文将提供详细的解决方案,需要了解的朋友可以参考下
    2012-11-11
  • MySQL处理和消除重复数据的多种方法

    MySQL处理和消除重复数据的多种方法

    在数据库管理中,数据重复是一个常见的问题,重复数据不仅浪费存储空间,还可能导致数据分析的偏差和错误,ySQL作为一种流行的关系型数据库管理系统,提供了多种方法来处理和消除重复数据,本文将详细介绍MySQL处理重复数据的方法,需要的朋友可以参考下
    2025-12-12
  • DDL数据库与表的创建和管理深入讲解使用教程

    DDL数据库与表的创建和管理深入讲解使用教程

    这篇文章主要介绍了DDL数据库与表的创建和管理,系统架构的层面来看,数据库从大到小依次是数据库服务器(上面安装了DBMS和数据库)、数据库(也称database或者schema)、数据表、数据表的行与列
    2023-04-04
  • MySQL驱动包下载全过程

    MySQL驱动包下载全过程

    这篇文章主要介绍了MySQL驱动包下载全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • ERROR 1862 (HY000): Your password has expired. To log in you must change it using a .....

    ERROR 1862 (HY000): Your password has expired. To log in you

    当你在安装 MySQL过程中,通过mysqld --initialize 初始化 mysql 操作后,生成临时密码后,没有直接进行 MySQL连接,中途重启服务或者重启机器等,导致密码失效问题,怎么处理呢,感兴趣的朋友一起看看吧
    2019-11-11
  • 使用MySQL唯一索引的注意事项及说明

    使用MySQL唯一索引的注意事项及说明

    这篇文章主要介绍了使用MySQL唯一索引的注意事项及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 通过两种方式增加从库——不停止mysql服务

    通过两种方式增加从库——不停止mysql服务

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库。前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作
    2015-11-11
  • 一文深入探讨MySQL是如何解决幻读问题

    一文深入探讨MySQL是如何解决幻读问题

    SQL标准中定义了4种隔离级别,分别是读未提交、读已提交、可重复读以及序列化。不同的隔离级别下,本文将重点探讨下MySQL是如何解决幻读问题的,需要的朋友可以跟着小编一起来探讨一下
    2023-07-07
  • mysql函数日期和时间函数汇总

    mysql函数日期和时间函数汇总

    这篇文章主要介绍了mysql函数日期和时间函数汇总,日期和时间函数主要用来处理日期和时间值,一般的日期函数除了使用​​date​​​类型的参数外,也可以使用​​datetime​​​或者​​timestamp​​类型的参数,但会忽略这些值的时间部分
    2022-07-07

最新评论