如何實時查看mysql當前鏈接數?mysql
一、查看當前全部鏈接的詳細資料:
./mysqladmin -uadmin -p -h10.140.1.1 processlistsql
二、只查看當前鏈接數(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 |
+-----+------+----------------+---------+---------+------+-------+------------------+
二、只查看當前鏈接數(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
三、修改mysql最大鏈接數:
打開my.ini,修改max_connections=100(默認爲100)。服務器
今天有一臺mysql服務器忽然鏈接數暴增,而且等待進程所有被鎖...由於問題解決不當,致使被罵...OTL進程
總結:之後要快速定位錯誤,佈置解決方案ssl
登陸到mysql客戶端後,使用status命令也能得到thread鏈接數以及當前鏈接的idio
或者用table
show full processlistthread
看一下全部鏈接進程,注意查看進程等待時間以及所處狀態 是否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 這個是全局的限制鏈接數