怎么實時查看mysql當前連接數
如何實時查看mysql當前連接數?
1、查看當前所有連接的詳細資料:
./mysqladmin -uadmin -p -h10.140.1.1 processlist
2、只查看當前連接數(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.389
3、修改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.cnf
set-variable=max_user_connections=30 這個就是單用戶的連接數
set-variable=max_connections=800 這個是全局的限制連接數
轉載:https://www.cnblogs.com/musings/p/5930338.html