mysql连接数

mysql连接数


MySQL最大连接数的默认值是100, 这个数值对于并发连接很多的数据库的应用是远不够用的,当连接请求大于默认连接数后,就会出现无法连接数据库的错误,因此我们需要把它适当调大一些。在使 用MySQL数据库的时候,经常会遇到这么一个问题,就是“Can not connect to MySQL server. Too many connections”-mysql 1040错误,这是因为访问MySQL且还未释放的连接数目已经达到MySQL的上限。通常,mysql的最大连接数默认是100, 最大可以达到16384。

查看连接数


查看最大连接数:在navicate中 或者 服务器中执行下面sql
show variables like '%max_connections%';

查看当前连接数:在navicate中 或者 服务器中执行下面sql

show status like 'Threads%';


Threads_connected :这个数值指的是打开的连接数.

Threads_running :这个数值指的是激活的连接数,这个数值一般远低于connected数值.

Threads_connected 跟show processlist结果相同,表示当前连接数。准确的来说,Threads_running是代表当前并发数

修改连接数


方法一:

命令行查看和修改最大连接数(max_connections)。

    mysql> mysql -uuser -ppassword(命令行登录MySQL)

    mysql>show variables  like  'max_connections' ;(查可以看当前的最大连接数)

    msyql> set  global  max_connections=1000;(设置最大连接数为1000,可以再次查看是否设置成功)

    mysql>exit 

 这种方式有个问题,设置的最大连接数只在mysql当前服务进程有效,一旦mysql重启,又会恢复到初始状态。因为mysql启动后的初始化工作是从其配置文件中读取数据的,而这种方式没有对其配置文件做更改。

方法二:

通过修改配置文件来修改mysql最大连接数(max_connections)。

这种方式说来很简单,只要修改MySQL配置文件my.ini 或 my.cnf的参数max_connections,将其改为max_connections=1000,然后重启MySQL即可。但是有一点最难的就是 my.ini这个文件在哪找。通常有两种可能,一个是在安装目录下,另一种是在数据文件的目录下,安装的时候如果没有人为改变目录的话,一般在/etc目录下。

其他


如果是root帐号,你能看到所有用户的当前连接。如果是其它普通帐号,只能看到自己占用的连接。

执行命令:show processlist;  (只列出前100条)

                    show full processlist (列出所有的连接)

你可能感兴趣的:(mysql连接数)