查看mysql 或SQL server 的连接数,mysql超时、最大连接数配置
作者:mmseoamin日期:2024-04-27

1、mysql 的连接数

 1.1、最大可连接数

         show variables like 'max_connections';

1.2、运行中连接数       

         show status like 'Threads_connected';

1.3、配置最大连接数,

         mysql版本不同可配置的最大连接数不同,mysql8.0的版本默认151个连接数,最大可配置16384;

        配置过程(配置完成需要重启mysql):

        查找my.cnf Linux命令find / -name my.cnf

        查看并修改 vi或vim命令 vi /etc/my.cnf

        输入i 进入编辑模式,在[mysgld] 的最后一行 

输入

#修改my.cnf文件,在文件中加入如下属性默认151 最大16384

max_connections=2000

按【ESC】 退出编辑  输入:wq 退出并保存

重启mysql,使用 find / -name mysql.server 找到mysql的启动文件

拷贝完整路径后 加 stop 停止mysql  

拷贝完整路径后 加 start 启动mysql

然后使用root账号进入mysql  mysql -u root -p   按【enter】后输入root账号的密码

使用1.1 和1.2命令 可以查询到结果如下

查看mysql 或SQL server 的连接数,mysql超时、最大连接数配置,第1张

2、SQL server 的连接数

在SQL Server中,可以使用以下几种方法来查看连接数:

2.1、使用系统存储过程:sp_who或者sp_who2,这两个存储过程可以列出当前数据库的连接信息,包括连接的进程ID,登录名,登录时间等。可以使用以下命令执行这两个存储过程:

        EXEC sp_who;

        EXEC sp_who2;

2.2、使用动态管理视图:sys.dm_exec_connections,这个视图返回连接到SQL Server的所有连接的信息,包括连接ID、会话ID、客户端IP地址等。可以使用以下查询来获取连接数:

        SELECT COUNT(*) AS ConnectionCount

        FROM sys.dm_exec_connections;

2.3、使用动态管理视图:sys.dm_exec_sessions,这个视图返回SQL Server中当前会话或连接的信息,包括会话ID、登录名、登录时间等。可以使用以下查询来获取连接数:

SELECT COUNT(*) AS ConnectionCount

FROM sys.dm_exec_sessions;

3、mysql超时配置

 3.1、yfyi文件中,可以修改以下参数:

eout:设置连接空闲超时时间,默认为8小时。

teractiveeout:设置交互式连接空闲超时时间,默认为8小时。

axnections:设置MySQL服务器的最大连接数。

3.2、 使用keepalive参数:在MySQL客户端连接时,可以使用keepalive参数来保持连接。例如:

ysql -h localhost -u root -p --keepalive=3600

上述命令将保持与MySQL服务器的连接时间为1小时。

3.3、 使用连接池:连接池是一种数据库连接管理技术,可以在应用程序和MySQL服务器之间建立一个连接池,以提高连接效率和性能。连接池可以缓存数据库连接,避免频繁地创建和关闭连接。

g命令来测试网络的延迟和丢包情况。

MySQL超时断开连接问题是一个常见的数据库连接问题,可以通过修改MySQL配置文件、使用keepalive参数、使用连接池和检查网络连接等方法来解决。在使用MySQL时,需要注意MySQL服务器的最大连接数和连接空闲超时时间等参数,以确保数据库的正常工作。