首页 > 数据库 >数据库国产化替代之后,补坑之路从未止步……

数据库国产化替代之后,补坑之路从未止步……

时间:2022-12-13 21:26:40浏览次数:53  
标签:止步 国产化 val covering PG test openGauss 补坑 id

 

 

“天底下没有完美的数据库,也许Oracle是个例外”,前阵子几个DBA在讨论国产化替代时,有人就这么说。确实是的,Oracle算是比较完美的数据库产品了,不过现在很多用户都在面临从Oracle数据库向其他数据库迁移的问题。中国电信已经宣布了今年年底前全线下架Oracle数据库,全部用国产或者开源数据库替代。本周和中国电信的朋友交流的时候,他们说已经完成了数百套系统从Oracle数据库的迁移,最晚到8月份,这个任务就能够完成了。

 

还有些企业怕遇到坑,因此还在不断地研究、认证、测试、分析中。事实上,在做出决策之前多一分小心还是十分必要的。10年前电信提出用开源数据库替代Oracle的时候,针对MYSQL和PG做了一番分析,我也参与了其中的一些工作,通过对当时的MYSQL和PG进行对比,我们最终的分析结果是:如果要迁移计费、账务系统,MYSQL优于PG。当然这个分析并不是说MYSQL就全面碾压PG,而只是针对计费、账务这样的系统场景,PG的膨胀与VACUUM会对系统稳定运行造成较大的影响,相对而言风险更大。

 

其实我们也没办法看得太远,哪怕是选择好的数据库,在迁移过程中,甚至迁移完成后的长期运行过程中,还是会遇到很多坑。有些问题可能是数据库基础架构从娘胎里带来的,无法马上解决的问题。如果你的应用对这样的问题十分敏感,不解决会引发大问题,那样就十分悲惨了。

 

昨天刚刚上班就有一个客户遇到国产数据库的问题,他们有一条SQL执行十分频繁,总体开销很大,希望通过index only scan来降低开销,不过创建了索引之后,执行计划依然不走index only scan,还是要走需要回表的执行计划。我以前也没有遇到过这类的问题,正好这个国产数据库是基于opengauss 2.0的,我们的测试环境中有opengauss 2.0和3.0的环境。于是我就先在opengauss 2.0的环境中做了一个测试。实际上openGauss是不支持Covering index的,在openGauss 2.0上,我们创建Covering index的时候会报错:

 

 

openGauss2.0是不支持这个语法的,openGauss3.0也类似,只不过错误信息有所变化:

 

在openGauss3.0中,针对ustore的表是支持covering index的,而针对默认的和PG兼容的ASTORE是不支持的。于是我们做了些变更,创建了一个测试用例。

drop table test_covering ;
create table test_covering (id serial,name text,val int);
create index idx_test_covering on test_covering(id,val);
insert into test_covering(name,val) select 'test'||generate_series(1,10000),(random()*100)::int%100;
analyze test_covering;
update test_covering set val=val+1;
select relallvisible from pg_class where relname='test_covering';
explain  (analyze true,buffers true) select val from test_covering where id>=10 and id<100;
vacuum test_covering;
select relallvisible from pg_class where relname='test_covering';
explain  (analyze true,buffers true) select val from test_covering where id>=10 and id<100;

从执行计划上看,确实没有采用Index Only Scan的执行计划。openGauss是基于PG 9.2.4开发的,难道这是PG早期的BUG吗?按理说PG的COVERING INDEX就是为了让SQL可以使用Index only scan的。于是我立即在openGauss 3.0上测试了一下。

 

 在openGauss 3.0上,我并没有看到预期的Index Only Scan的执行计划。于是我在网上和一个朋友交流了这个问题,他正好对此有过研究,立即就指出了这是一个visibility map的问题,PG 8.4为了支持MVCC,引入了visibility map。不过VM文件并不是实时更新的,因此如果PAGE在VM中是不可见状态时,就必须做回表操作,因为索引中并不存在数据行可见性的标识数据,因此不能使用Index Only Scan。为了进一步确认这个问题,我在一个社区版的PG 11上做了一个测试。

drop table test_covering ;
create table test_covering (id serial,name text,val int);
create index idx_test_covering on test_covering(id) include(val);
insert into test_covering(name,val) select 'test'||generate_series(1,10000),(random()*100)::int%100;
analyze test_covering;
update test_covering set val=val+1;
select relallvisible from pg_class where relname='test_covering';
select relallvisible from pg_class where relname='test_covering';
explain  (analyze true,buffers true) select val from test_covering where id>=10 and id<100;
vacuum test_covering;
select relallvisible from pg_class where relname='test_covering';
explain  (analyze true,buffers true) select val from test_covering where id>=10 and id<100;

 

 

我们在PG 11上看到了预期的执行计划,因为PG的数据行的可视性信息仅仅存储于表数据中,而索引中没有这个信息,因此在做Index Only Scan的时候,如果VM没有及时更新,就必须回表才能获得准确的信息了。在VACUUM前执行的查询中,HEAP FETCHES是180,说明虽然执行计划是Index Only Scan,不过有180条数据是回表操作了。

 

当VM里已经更新了PAGE的信息,那么这些PAGE上的记录就不需要“回表操作”了,因此VACUUM后VM得到了更新,此时HEAP FETCHES变成0了,说明没有任何回表操作。因为VM文件的大小远远小于数据表的文件,因此不回表会降低执行成本。从上面的例子我们也可以看出,不回表执行0.037毫秒,回表执行0.203毫秒,差异还是挺大的。

 

在PG 11上只要做了表分析,那么起码执行计划是Index Only Scan的,为什么openGauss上执行计划也不选择Index Only Scan呢?刚才我们测试openGauss的时候因为不支持Covering Index的问题,对SQL做了改写。改写后的SQL在PG 11上是什么样的呢?

 

 

我们发现,如果索引变成了普通的索引之后,在PG上的执行计划也和openGauss一样了。

 

 

 

不过如果我们做一个vacuum,执行计划就变得正确了,而且也不存在“回表”的问题了。从这个测试我们再联想一下openGauss,openGauss数据库的CBO优化器是不是认为因为VM比较旧,这个查询需要回表,所以不选择Index Only Scan的执行计划呢?

 

 

 于是我们也在openGauss上做了VACUUM,不过VACUUM完成后,可视的PAGE数量还是0,执行计划也还是没有发生改变。过了一段时间后,发现可见页的数量不为零了,于是再次分析执行计划,发现执行计划已经变成了Index Only Scan。

 

 

openGauss的文档上对于VM文件更新的问题并未做出说明,因为我们也只能猜测openGauss的vacuum命令并不更新VM文件,VM文件的更新可能是由其他机制来完成的。因为这个问题的存在,因此openGauss在ASTORE上不支持Covering Index,以防止创建了这样的索引,大部分情况下,Index Only Scan的执行计划也不可用。不过我们在openGauss的相关文档上并未找到这方面的说明。

 

我们利用openGauss 3.0的USTORE功能,做了最后一个实验,因为刚才我们看到openGauss在USTORE上是支持covering index的,是不是用Ustore可以解决这个问题呢?

rop table test_covering ;
create table test_covering (id serial,name text,val int)  with (STORAGE_TYPE=USTORE) ;
create index idx_test_covering on test_covering using ubtree(id) include(val) ;
insert into test_covering(name,val) select 'test'||generate_series(1,10000),(random()*100)::int%100;
explain  (analyze true,buffers true) select val from test_covering where id>=10 and id<100;
analyze test_covering;
update test_covering set val=val+1;
explain  (analyze true,buffers true) select val from test_covering where id>=10 and id<100;

 

 

和我们预想的一样,在USTORE上不需要VM的情况下,优化器正确地选择了Index Only Scan。似乎在opengauss上使用USTORE可以完美解决这个问题。不过目前USTORE还不够成熟。在USTORE上也存在不少坑,比如说官方文档中没有提及的USTORE表不支持回收站的问题,以及USTORE上以前我们遇到的一些性能问题。从openGauss仅在USTORE上支持covering index上,我们也可以看出华为openGauss在VM方面可能存在一些问题。就像我们测试中发现,哪怕做vacuum,也不能马上更新VM数据。不能及时更新VM,会导致SQL语句的回表操作增加,导致covering index的初衷无法实现。

 

数据库使用过程中难免会遇到坑,在使用“完美的数据库”-Oracle的时候我们不也经常遇到BUG吗。遇到坑并不怕,怕的是遇到坑之后我们无法找到解决方案,也不知道这个坑到底是怎么回事。国产数据库并不只是在功能与性能上存在差距的问题,更大的问题可能是在今后的长期维护上,运维知识、运维专家、运维工具的缺失可能会更大地影响国产数据库的发展。

 

不过不管如何,走出第一步就没有后退的道理了,遇到坑就退回去也是不大可能的。企业在走出第一步之前,就应该未雨绸缪,安排好填坑的队伍,这样才能有备无患。

 

作者丨白鳝

标签:止步,国产化,val,covering,PG,test,openGauss,补坑,id
From: https://www.cnblogs.com/88223100/p/After-the-localization-and-substitution-of-databases-th

相关文章

  • 数据库国产化替代之后,补坑之路从未止步……
      “天底下没有完美的数据库,也许Oracle是个例外”,前阵子几个DBA在讨论国产化替代时,有人就这么说。确实是的,Oracle算是比较完美的数据库产品了,不过现在很多用户都在面......
  • linux、国产化
    1.国产通用东方通安装   2.国产化通用java环境安装1、将该压缩包放到/usr/local/java目录下(java需要自己创建,名字自己随意取,见名知意),然后解压该压......
  • core部署linux、国产化
    前言:本文基于centos7.9操作系统,服务器x86/x64,所有操作在虚拟机中操作,记录部署过程中出现的问题,在此记录解决方案。查看系统版本命令:cat/etc/redhat-releasecat/proc/v......
  • 国产化首款32通道微弱电流信号放大芯片
    模拟集成电路开发商重庆东微电子股份有限公司推出国产化首款32通道微弱电流信号放大器。产品EMT1010A的大规模数模混合集成电路,将主要针对各种工业级和全自动电化学发光免......
  • 《XY618 4G 核心板》BOM全国产化,支持安卓11.0操作系统!
       产品概括:《XY6184G核心板》是深圳市新移科技有限公司基于紫光展锐T618(虎贲T618)平台所研发出的一款4G全网通智能模块,搭载了安卓11.0操作系统,BOM全国产化。该模块......
  • 国产化云平台如何实现多云管控,黄河云来“打样儿”
    黄河云是黄河科技集团创新有限公司(以下简称:黄河科技)落实河南省委、省政府要求,依托河南信息产业投资有限公司建设的自主可控的信息化新型基础设施,也是河南首个规模化商用的国......
  • UD PCIe-402全国产化信号处理模块
    一、产品概述UDPCIe-402全国产化信号处理模块为标准PCIe全高半长的结构,对外支持PCIe2.0×8通信,也可以采用千兆以太网接口进行通信,模块为100%国产化设计。FPGA芯片选用国......
  • 信创产业国产化替代的机遇和挑战
    面对日益增加的安全风险,我们国家正在加速自主可控,关键核心技术攻关,也将迎来前所未有的国产化浪潮。针对信创产业,国家提出了“2+8+N”体系,按照这个顺序逐步实现自主可控。......
  • 国产化系统,国产化CPU
    国产操作系统多为以Linux为基础二次开发的操作系统。目前、比较火的国产化系统有“银河麒麟”、“统信UOS”、“鸿蒙等等”。但是、无论是什么系统,都是大相径庭,主要还是看......
  • AntDB数据库与DSG强强联手,助力通信行业核心系统国产化
    日前,湖南亚信安慧科技有限公司(简称:亚信安慧科技)与迪思杰(北京)数据管理技术有限公司开展了产品兼容互认工作。图1:AntDB数据库与DSGSuperSyncV3.2兼容互认证明近年来,国家大......