【GaussDB】数据库状态,节点状态,实例状态说明

1.检查节点状态。

[omm@gauss001 ~]$ gs_om -t status --detail
[  CMServer State   ]

node             node_ip         instance                             state
-----------------------------------------------------------------------------
1  192.168.0.142 192.168.0.142   1    /data/cluster/data/cm/cm_server Primary

[   Cluster State   ]

cluster_state   : Normal
redistributing  : No
balanced        : Yes
current_az      : AZ_ALL

[  Datanode State   ]

node             node_ip         instance                           state
---------------------------------------------------------------------------------------
1  192.168.0.142 192.168.0.142   6001 /data/cluster/data/dn/dn_6001 P Primary Normal

2.节点状态查看 

[omm@gauss001 dn_6001]$ gs_om -t status -h 192.168.0.142
-----------------------------------------------------------------------

cluster_state             : Normal
redistributing            : No
balanced                  : Yes
-----------------------------------------------------------------------
node                      : 1
node_name                 : 192.168.0.142
node                      : 1
instance_id               : 1
node_ip                   : 192.168.0.142
data_path                 : /data/cluster/data/cm/cm_server
type                      : CMServer
instance_state            : Primary
node                      : 1
instance_id               : 6001
node_ip                   : 192.168.0.142
data_path                 : /data/cluster/data/dn/dn_6001
type                      : Datanode
instance_state            : Primary
static_connections        : 0
HA_state                  : Normal
reason                    : Normal
standby_node              : 
standby_data_path         : 
standby_node              : 
standby_data_path         : 
standby_state             : Unknown
sender_sent_location      : 0/0
sender_write_location     : 0/0
sender_flush_location     : 0/0
sender_replay_location    : 0/0
receiver_received_location: 0/0
receiver_write_location   : 0/0
receiver_flush_location   : 0/0
receiver_replay_location  : 0/0
sync_state                : Unknown
secondary_state           : Unknown
sender_sent_location      : 0/0
sender_write_location     : 0/0
sender_flush_location     : 0/0
sender_replay_location    : 0/0
receiver_received_location: 0/0
receiver_write_location   : 0/0
receiver_flush_location   : 0/0
receiver_replay_location  : 0/0
sync_state                : Unknown
node                      : 1
node_ip                   : 192.168.0.142
type                      : Fenced UDF
state                     : Normal
-----------------------------------------------------------------------
node_state                : Normal

3.数据库状态

cluster_state 数据库状态。
•Normal:表示数据库可用,且数据有冗余备份。所有进程都在运行,主备关系正常。
•Unavailable:表示数据库不可用。
•Degraded:表示数据库可用,但存在故障的数据库节点、数据库主节点实例。

4.实例角色

•Normal:表示单主机实例。
•Primary:表示实例为主实例。
•Standby:表示实例为备实例。
•Pending:表示该实例在仲裁阶段。
•Unknown:表示实例状态未知。
•Down:表示实例处于宕机状态。
•Abnormal:表示节点处于异常状态。
•Manually stopped:表示节点已经被手动停止。

5.节点状态说明

状态:字段含义
Normal:表示节点启动正常。
Need repair:当前节点需要修复。
Starting:节点正在启动中。
Wait promoting:节点正等待升级中。例如备机向主机发送升级请求后,正在等待主机回应时的状态。
Promoting:备节点正在升级为主节点的状态
Demoting:节点正在降级中,如主机正在降为备机中。
Building:备机启动失败,需要重建。
Catchup:备节点正在追赶主节点。
Coredump:节点程序崩溃。
Unknown:节点状态未知。

数据库状态信息: ------------------------------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、付费专栏及课程。

余额充值