1. 程式人生 > >如何實時查看mysql當前連接數?

如何實時查看mysql當前連接數?

如何實時查看mysql當前連接數?

如何實時查看mysql當前連接數? 

1、查看當前所有連接的詳細資料:
./mysqladmin -uadmin -p -h10.140.1.1 processlist2、只查看當前連接數(Threads就是連接數.):
./mysqladmin  -uadmin -p -h10.140.1.1 status


、查看當前所有連接的詳細資料:
mysqladmin -uroot -proot processlist
D:\MySQL\bin>mysqladmin -uroot -proot processlist+-----+------+----------------+---------+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+-----+------+----------------+---------+---------+------+-------+------------------+
| 591 | root | localhost:3544 | bbs | Sleep | 25 | | |
| 701 | root | localhost:3761 | | uery | 0 | | show processlist |
+-----+------+----------------+---------+---------+------+-------+------------------+2、只查看當前連接數(Threads就是連接數.):
mysqladmin -uroot -proot status
D:\MySQL\bin>mysqladmin -uroot -proot status
Uptime: 2102 Threads: 3 Questions: 15531 Slow queries: 0 Opens: 0 Flush tab
les: 1 Open tables: 61 Queries per second avg: 7.3893、修改mysql最大連接數:
打開my.ini,修改max_connections=100(默認為100)。


今天有一臺mysql服務器突然連接數暴增,並且等待進程全部被鎖...因為問題解決不當,導致被罵...OTL

總結:以後要快速定位錯誤,布置解決方案

登錄到mysql客戶端後,使用status命令也能獲得thread連接數以及當前連接的id

或者用

show full processlist 

看一下所有連接進程,註意查看進程等待時間以及所處狀態 是否locked

如果進程過多,就把進程打印下來,然後查看

mysql -e ‘show full processlist;‘ > 111查找非locked的進程,一般就是當前執行中卡死,導致後面的進程排隊的原因。

另外,修改mysql最大連接數的方法:

編輯MySQL(和PHP搭配之最佳組合)配置文件 
my.cnf 或者是 my.ini

在[MySQL(和PHP搭配之最佳組合)d]配置段添加:
max_connections = 1000保存,重啟MySQL(和PHP搭配之最佳組合)服務。

然後用命令:
MySQL(和PHP搭配之最佳組合)admin -uroot -p variables 
輸入root數據庫賬號的密碼後可看到 
| max_connections | 1000 |查看MySQL連接數和當前用戶Mysql連接數


先用管理員身份進入mysql提示符。
#mysql -uroot -pxxxx
mysql> show processlist; 可以顯示前100條連接信息 show full processlist; 可以顯示全部。隨便說下,如果用普通賬號登錄,就只顯示這用戶的。註意命令後有分號。

如果我們想查看這臺服務器設置。 #vi /etc/my.cnfset-variable=max_user_connections=30 這個就是單用戶的連接數set-variable=max_connections=800 這個是全局的限制連接數


本文出自 “小菜鳥” 博客,請務必保留此出處http://baishuchao.blog.51cto.com/12918589/1930525

如何實時查看mysql當前連接數?