[转帖]金仓数据库KingbaseES V8R6索引坏块故障处理
案例说明:
在执行表数据查询时,出现下图所示错误,索引故障导致表无法访问,后重建索引问题解决。本案例复现了此类故障解决过程。
适用版本:
KingbaseES V8R3/R6
一、创建测试环境
-
# 表结构信息
-
prod=# \d+ test1
-
Table "public.test1"
-
Column| Type |Collation| Nullable |Default| Storage | Stats target | Description
-
--------+---------+-----------+----------+---------+----------+--------------+-------------
-
id |integer||notnull|| plain ||
-
v_name |varchar|||| extended ||
-
Indexes:
-
"test1_pkey" PRIMARY KEY, btree (id)
-
"test1_name_ind" btree (v_name)
-
Access method: heap
-
-
# 插入测试数据
-
prod=# insertinto test1 values (generate_series(1,10000),'usr'||generate_series(1,10000));
-
INSERT010000
-
prod=# selectcount(*) from test1;
-
count
-
-------10000
-
(1row)
-
-
# 查看索引应用
-
prod=# explain analyze select*from test1 where v_name='usr2';
-
QUERY PLAN
-
-----------------------------------------------------------------------------------------------------------------------
-
Index Scan using test1_name_ind on test1 (cost=0.29..8.30rows=1 width=11) (actual time=0.023..0.024rows=1 loops=1)
-
Index Cond: ((v_name)::text ='usr2'::text)
-
Planning Time: 0.055 ms
-
Execution Time: 0.038 ms
-
(4rows)
二、模拟数据文件故障
1、查看索引文件存储路径
-
prod=# select pg_relation_filepath('test1_name_ind');
-
pg_relation_filepath
-
----------------------
-
base/16385/26800
-
(1row)
2、模拟数据文件被破坏
-
[kingbase@node102 data]$ ls -lh base/16385/26800
-
-rw------- 1 kingbase kingbase 240K Nov 1715:01 base/16385/26800
-
-
[kingbase@node102 data]$ dd if=/dev/zero of=/data/kingbase/v8r6_c6/data/base/16385/26800 bs=8k count=22+0 records in2+0 records out
-
16384 bytes (16 kB) copied, 0.000147959 s, 111 MB/s
-
-
[kingbase@node102 data]$ ls -lh base/16385/26800
-
-rw------- 1 kingbase kingbase 16K Nov 1715:04 base/16385/26800# 如下所示索引故障导致表访问错误
-
prod=# select * from test1;ERROR: index "test1_name_ind" contains unexpected zero page at block 0HINT: Please REINDEX it.
三、重建索引解决故障
1、查看表索引信息
-
prod=# \d+ test1;
-
Table"public.test1"Column | Type | Collation | Nullable | Default | Storage | Stats target | Description
-
--------+---------+-----------+----------+---------+----------+--------------+-------------
-
id | integer | | not null | | plain | |
-
v_name | varchar | | | | extended | |
-
Indexes:
-
"test1_pkey"PRIMARYKEY, btree (id)
-
"test1_name_ind" btree (v_name)
-
Access method: heap
2、重建索引
-
# 索引重建
-
prod=# reindex index test1_name_ind;
-
REINDEX
-
-
#如下所示,重建索引后表数据访问正常
-
prod=# select*from test1 limit 3;
-
id | v_name
-
----+--------1| usr1
-
2| usr2
-
3| usr3
-
(3rows)
-
-
prod=# select*from test1 where v_name='usr2';
-
id | v_name
-
----+--------2| usr2
-
(1row)
-
-
prod=# explain analyze select*from test1 where v_name='usr2';
-
QUERY PLAN
-
-----------------------------------------------------------------------------------------------------------------------
-
Index Scan using test1_name_ind on test1 (cost=0.29..8.30rows=1 width=11) (actual time=0.023..0.024rows=1 loops=1)
-
Index Cond: ((v_name)::text ='usr2'::text)
-
Planning Time: 0.055 ms
-
Execution Time: 0.038 ms
-
(4rows)
四、总结
对于KingbaseES数据库,索引块的损坏会影响到表数据的正常访问,对于索引块故障处理比较简单,直接重建索引一般都可以解决此类问题。
[转帖]金仓数据库KingbaseES V8R6索引坏块故障处理的更多相关文章
- 通过ODBC接口访问人大金仓数据库
国产化软件和国产化芯片的窘境一样,一方面市场已经存在性能优越的同类软件,成本很低,但小众的国产化软件不仅需要高价买入版权,并且软件开发维护成本高:另一方面,国产软件目前普遍难用,性能不稳定,Bug ...
- QT 之 ODBC连接人大金仓数据库
QT 之 使用 ODBC 驱动连接人大金仓数据库 获取数据库驱动和依赖动态库 此操作可在人大金仓官网下载与系统匹配的接口动态库,或者从架构数据库的源码中获取驱动和依赖动态库 分别为: 驱动动态库:kd ...
- 通过jmeter连接人大金仓数据库
某项目用的人大金仓数据库,做性能测试,需要用jmeter来连接数据库处理一批数据.jmeter连接人大金仓,做个记录. 1. 概要 在"配置元件"中添加"JDBC Con ...
- PostgreSQL 索引坏块处理
今天应用反应有张表查询报错,报错信息如下 back=# select max(create_time) from public.tbl_index_table where create_time> ...
- PostgreSQL 恢复大法 - 恢复部分数据库、跳过坏块、修复无法启动的数据库
转载自:https://yq.aliyun.com/articles/582880 背景 一个较大的数据库,如何只恢复一部分数据(例如只恢复某个DB). 如果访问有坏块的表. 如何从无法启动的数据库中 ...
- linux安装国产数据库(金仓数据库,达梦数据库,南大通用数据库)
今天在公司做的任务是,在Linux的环境下安装三种数据库,结果一种数据库也没有安装好,首先遇到的问题是安装南大通用数据库遇到安装的第五步,就出现问题了,问题是Gbase SDK没有安装成功,以及Gba ...
- Rocky4.2下安装金仓v7数据库(KingbaseES)
1.准备操作系统 1.1 系统登录界面 1.2 操作系统版本信息 jdbh:~ # uname -ra Linux jdbh -x86_64 # SMP Fri Dec :: CST x86_64 G ...
- 润乾配置连接kingbase(金仓)数据库
问题背景 客户根据项目的不同,使用润乾连接的数据库类型各种各样,此文针对前几日使用润乾设计器连接kingbase金仓数据库做一个说明. kingbase金仓数据库是一款国产数据库,操作方式和配置 ...
- 对Oracle数据库坏块的理解
1.物理坏块和逻辑坏块 在数据库中有一个概念叫做数据块的一致性,Oracle的数据块的一致性包括了两个层次:物理一致性和逻辑一致性,如果一个数据块在这两个层次上存在不一致性,那就对应到了我们今天要要说 ...
- 金仓Kingbase数据库网页数据维护分析工具
金仓Kingbase是优秀的国产数据库产品,在能源,政务,国防等领域广泛使用, 现在TreeSoft数据库管理系统已支持Kingbase了,直接在浏览器中就可以操作查看Kingbase数据了,十分方便 ...
随机推荐
- 全国网络安全行业职业技能大赛云南省选拔赛 Misc 部分WP
word_sercet 题目 我的解答: 加密文档,010打开图片发现密码 VVV_123.com 解压打开得到flag(注:flag原本是隐藏的,但我之前设置过隐藏文字自动显示,因此这里直接可以看到 ...
- Java 在Excel中添加筛选器并执行筛选
以下内容介绍通过Java程序在Excel添加筛选器并执行筛选.程序需要使用Excel工具类库Free Spire.XLS for Java,本文中使用的是免费版,可在官网下载jar包,解压导入jar文 ...
- 云图说|图解制品仓库CodeArts Artifact
摘要:制品仓库用于存放由源码编译生成的.可运行的二进制文件,重要作用是实现制品文件的可信存储,支撑软件开发活动. 本文分享自华为云社区<[云图说]第277期 图解制品仓库CodeArts Art ...
- 华为云GaussDB(for Influx)揭密第六期:数据分级存储
摘要:GaussDB(for Influx)通过冷热数据存储分离,在提供海量数据高性能存储的同时可节省85%的存储成本,高效满足时序应用各种场景. 本文分享自华为云社区<华为云GaussDB(f ...
- CWE4.6标准中加入 OWASP 2021 TOP10
摘要: 新发布的CWE4.6标准,加入了OWASP 2021 TOP10的视图. 本文分享自华为云社区<CWE 4.6 和 OWAPS TOP10(2021)>,作者: Uncle_Tom ...
- PPT 提升素材搜索能力
https://cn.bing.com/images 高清透明 https://unsplash.com/ 更新快 https://pixabay.com/zh/ 免费高清图片 https://www ...
- Flask依赖的核心模块werkzeug
Flask的web框架实现 Flask是python Web框架,自然要遵 WSGI 规范,需要同时实现服务端程序+应用程序,并且要丰富完善请求和响应的处理. Flask自身并没有实现WSGI,而是依 ...
- 【Vue】阶段练习
目录 需求 参考汽车之家 首页 登录功能 展示所有汽车页面 项目 登录页面 跨域请求 一 同源策略 二 CORS(跨域资源共享)简介 三 CORS基本流程 四 CORS两种请求详解 五 Django项 ...
- 【3rd_Party】format() 处理一些常见的格式化解决方案
fmt的痛与对format设计的思考 fmt:轻量高性能的C++格式化库 C++20 引入了新的 format() 函数,该函数以字符串形式返回参数的格式化表示.format() 使用 python ...
- Spring 学习笔记(1)文章导读
<Spring 学习笔记>系列文章是博主在学习过 Spring 后对其进行总结的入门系列博文,适合初入 Spring 的小白,如果你最近正在学习或者打算学习 Spring 的话,不妨随着本 ...