为保证GBase 8c数据库中的数据安全,避免发生丢失数据、非法访问数据等事故,建议数据库管理员进行如下日维护检查。
1、检查 GBase 8c 状态
通过GBase 8c提供的工具查询数据库和实例状态,确认数据库和实例都处于正常的运行状态,可以对外提供数据服务。
gs_check -U omm -i CheckClusterState
gbase=# SHOW parameter_name;
gs_guc reload -D /gaussdb/data/dbnode -c "paraname=value"
锁机制是数据库保证数据一致性的重要手段,检查相关信息可以检查数据库的事务和运行状况。
gbase=# SELECT * FROM pg_locks;
gbase=# SELECT * FROM pg_thread_wait_status WHERE wait_status = 'acquire lock';
- ps ux
-
- kill -9 pid
3、统计事件数据
SQL语句长时间运行会占用大量资源。用户可以通过查看事件发生的时间、占用内存大小等信息,来了解现在数据库运行状态。
查询事件的线程启动时间、事务启动时间、SQL启动时间以及状态变更时间。
gbase=# SELECT backend_start,xact_start,query_start,state_change FROM pg_stat_activity;
●查询当前服务器的会话计数信息
gbase=# SELECT count(*) FROM pg_stat_activity;
●查询系统级统计信息
查询当前使用内存最多的会话信息。
gbase=# SELECT * FROM pv_session_memory_detail() ORDER BY usedsize desc limit 10;
4、对象检查
表、索引、分区、约束等是数据库的核心存储对象,其核心信息和对象维护是DBA重要的日常工作。
gbase=# \d+ table_name
gbase=# SELECT * FROM pg_statistic;
gbase=# \d+ index_name
gbase=# SELECT * FROM pg_partition;
使用ANALYZE语句收集数据库相关的统计信息。
使用VACUUM语句可以回收空间并更新统计信息。
gbase=# SELECT * FROM pg_constraint;
5、SQL 报告检查
使用EXPLAIN语句查看执行计划。
6、备份
数据备份重于一切,日常应检查备份执行情况,并检查备份有效性,确保备份能够保障数据安全,备份安全加密也应兼顾。
gs_dump dbname -p port -f out.sql -U user_name -W password
gs_dump dbname -p port -n schema_name -f out.sql
gs_dump dbname -p port -t table_name -f out.sql
7、基本信息检查
基本信息包括版本、组件、补丁集等信息,定期检查数据库信息并登记在案是数据库生命周期管理的重要内容之一。
gbase=# SELECT version();
●容量检查
- gbase=# SELECT pg_table_size('table_name');
-
- gbase=# SELECT pg_database_size('database_name');