【MySQL】查看数据库状态

1.事务

-- 查看当前所有事务
select * from information_schema.innodb_trx;
-- 查看正在锁的事务
select * from information_schema.innodb_locks;
-- 查看等待锁的事务
select * from information_schema.innodb_lock_waits;

2.锁

-- 查看当前有那些表是打开的
show open tables;
-- In_use:有多少线程正在使用某张表
show OPEN TABLES where In_use > 0;

-- 解锁
-- 显示连接列表(查询 ID)
show full processlist;
-- 结束指定(ID)连接
kill id;

-- 解锁
UNLOCK TABLES;

show status like '%lock%';

-- 指定表加锁
LOCK TABLES tbl_name READ;
LOCK TABLES tbl_name WRITE;
-- 所有表加锁
FLUSH TABLES WITH READ LOCK;

3.线程

-- 查看当前连接
-- Threads_connected:打开的连接数
-- Threads_running:激活的连接数(并发数,一般远低于connected)
-- Threads_created:表示创建过的线程数
show status like 'Threads%';

-- 如果 Threads_created 值过大的话,表明 MySQL 服务器一直在创建线程,可以适当增加 thread_cache_size 值
show variables like 'thread_cache_size';

4.连接

-- 查询最大连接数
show variables like '%max_connections%';
-- 设置最大连接数
set global max_connections=1000;
-- 在/etc/my.cnf里面设置数据库的最大连接数
-- [mysqld]
-- max_connections = 1000

5.其它查询

-- 显示连接状态,可以把 connect 换成其它参数
show STATUS LIKE '%connect%';

-- Aborted_clients:由于客户没有正确关闭连接已经死掉,已经放弃的连接数量。
-- Aborted_connects:尝试已经失败的 MySQL 服务器的连接的次数。
-- Connections:试图连接 MySQL 服务器的次数。
-- Created_tmp_tables:当执行语句时,已经被创造了的隐含临时表的数量。
-- Delayed_insert_threads:正在使用的延迟插入处理器线程的数量。
-- Delayed_writes:用 INSERT:DELAYED 写入的行数。
-- Delayed_errors:用 INSERT:DELAYED 写入的发生某些错误(可能重复键值)的行数。
-- Flush_commands:执行 FLUSH 命令的次数。
-- Handler_delete:请求从一张表中删除行的次数。
-- Handler_read_first:请求读入表中第一行的次数。
-- Handler_read_key:请求数字基于键读行。
-- Handler_read_next:请求读入基于一个键的一行的次数。
-- Handler_read_rnd:请求读入基于一个固定位置的一行的次数。
-- Handler_update:请求更新表中一行的次数。
-- Handler_write:请求向表中插入一行的次数。
-- Key_blocks_used:用于关键字缓存的块的数量。
-- Key_read_requests:请求从缓存读入一个键值的次数。
-- Key_reads:从磁盘物理读入一个键值的次数。
-- Key_write_requests:请求将一个关键字块写入缓存次数。
-- Key_writes:将一个键值块物理写入磁盘的次数。
-- Max_used_connections:同时使用的连接的最大数目。
-- Not_flushed_key_blocks:在键缓存中已经改变但是还没被清空到磁盘上的键块。
-- Not_flushed_delayed_rows:在 INSERT:DELAY 队列中等待写入的行的数量。
-- Open_tables:打开表的数量。
-- Open_files:打开文件的数量。
-- Open_streams:打开流的数量(主要用于日志记载)
-- Opened_tables:已经打开的表的数量。
-- Questions:发往服务器的查询的数量。
-- Slow_queries:要花超过 long_query_time 时间的查询数量。
-- Threads_connected:当前打开的连接的数量。
-- Threads_running:不在睡眠的线程数量。
-- Uptime:服务器工作了多长时间,单位秒。
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
查询数据库状态信息: ------------------------------Data file size---------------------------- if exists (select * from tempdb.sys.all_objects where name like '%#dbsize%') drop table #dbsize create table #dbsize (Dbname varchar(30),dbstatus varchar(20),Recovery_Model varchar(10) default ('NA'), file_Size_MB decimal(20,2)default (0),Space_Used_MB decimal(20,2)default (0),Free_Space_MB decimal(20,2) default (0)) go insert into #dbsize(Dbname,dbstatus,Recovery_Model,file_Size_MB,Space_Used_MB,Free_Space_MB) exec sp_msforeachdb 'use [?]; select DB_NAME() AS DbName, CONVERT(varchar(20),DatabasePropertyEx(''?'',''Status'')) , CONVERT(varchar(20),DatabasePropertyEx(''?'',''Recovery'')), sum(size)/128.0 AS File_Size_MB, sum(CAST(FILEPROPERTY(name, ''SpaceUsed'') AS INT))/128.0 as Space_Used_MB, SUM( size)/128.0 - sum(CAST(FILEPROPERTY(name,''SpaceUsed'') AS INT))/128.0 AS Free_Space_MB from sys.database_files where type=0 group by type' go -------------------log size-------------------------------------- if exists (select * from tempdb.sys.all_objects where name like '#logsize%') drop table #logsize create table #logsize (Dbname varchar(30), Log_File_Size_MB decimal(20,2)default (0),log_Space_Used_MB decimal(20,2)default (0),log_Free_Space_MB decimal(20,2)default (0)) go insert into #logsize(Dbname,Log_File_Size_MB,log_Space_Used_MB,log_Free_Space_MB) exec sp_msforeachdb 'use [?]; select DB_NAME() AS DbName, sum(size)/128.0 AS Log_File_Size_MB, sum(CAST(FILEPROPERTY(name, ''SpaceUsed'') AS INT))/128.0 as log_Space_Used_MB, SUM( size)/128.0 - sum(CAST(FILEPROPERTY(name,''SpaceUsed'') AS INT))/128.0 AS log_Free_Space_MB from sys.database_files where type=1 group by type' go --------------------------------database free size if exists (select * from tempdb.sys.all_objects where name like '%#dbfreesize%') drop table #dbfreesize create table #dbfreesize (name varchar(50), database_size varchar(50), Freespace varchar(50)default (0.00)) insert into #dbfreesize(name,database_size,Freespace) exec sp_msforeachdb 'use ?;SELECT database_name = db_name() ,database_size = ltrim(str((convert(DECIMAL(15, 2), dbsize) + convert(DECIMAL(15, 2), logsize)) * 8192 / 1048576, 15, 2) + ''MB'') ,''unallocated space'' = ltrim(str(( CASE WHEN dbsize >= reservedpages THEN (convert(DECIMAL(15, 2), dbsize) - convert(DECIMAL(15, 2), reservedpages)) * 8192 / 1048576 ELSE 0 END ), 15, 2) + '' MB'') FROM ( SELECT dbsize = sum(convert(BIGINT, CASE WHEN type = 0 THEN size ELSE 0 END)) ,logsize = sum(convert(BIGINT, CASE WHEN type <> 0 THEN size ELSE 0 END)) FROM sys.database_files ) AS files ,( SELECT reservedpages = sum(a.total_pages) ,usedpages = sum(a.used_pages) ,pages = sum(CASE WHEN it.internal_type IN ( 202 ,204 ,211 ,212 ,213 ,214 ,215 ,216 ) THEN 0 WHEN a.type <> 1 THEN a.used_pages WHEN p.index_id < 2 THEN a.data_pages ELSE 0 END) FROM sys.partitions p INNER JOIN sys.allocation_units a ON p.partition_id = a.container_id LEFT JOIN sys.internal_tables it ON p.object_id = it.object_id ) AS partitions' ----------------------------------- if exists (select * from tempdb.sys.all_objects where name like '%#alldbstate%') drop table #alldbstate create table #alldbstate (dbname varchar(25), DBstatus varchar(25), R_model Varchar(20)) --select * from sys.master_files insert into #alldbstate (dbname,DBstatus,R_model) select name,CONVERT(varchar(20),DATABASEPROPERTYEX(name,'status')),recovery_model_desc from sys.databases --select * from #dbsize insert into #dbsize(Dbname,dbstatus,Recovery_Model) select dbname,dbstatus,R_model from #alldbstate where DBstatus <> 'online' insert into #logsize(Dbname) select dbname from #alldbstate where DBstatus <> 'online' insert into #dbfreesize(name) select dbname from #alldbstate where DBstatus <> 'online' select d.Dbname,d.dbstatus,d.Recovery_Model, (file_size_mb + log_file_size_mb) as DBsize, d.file_Size_MB,d.Space_Used_MB,d.Free_Space_MB, l.Log_File_Size_MB,log_Space_Used_MB,l.log_Free_Space_MB,fs.Freespace as DB_Freespace from #dbsize d join #logsize l on d.Dbname=l.Dbname join #dbfreesize fs on d.Dbname=fs.name order by Dbname

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值