导读
作者:王晓伟(微信:goodwxw) 知数堂《大数据实战就业》课程讲师 清华大学软件工程硕士,6年大数据系统管理及开发经验。
当前,正由IT时代进入DT时代,随着移动互联网、物联网的发展,企业正产生大量的数据,而数据的存储和组织离不开数据库技术,更多的公司意识到了数据能够为公司带来商业利益,于是如何管理和利用好数据已经变得越来越重要。
挖掘数据的价值,对数据进行分析,让数据指导决策已经成为很多公司最重要的工作之一,因此选择合适的数据库系统对公司的技术发展至关重要。
笔者曾经在某大型互联网公司负责Hadoop平台及部分MySQL数据库的管理,工作中涉及到对DBMS的选型、管理及优化等工作内容,笔者认为,未来数据库发展将有三大趋势:
由于DBMS的发展越来越快,功能越来越多,需要优化的参数内容也相对更多,而各个公司的应用场景不同,对数据库的要求也各有特点。传统DBMS对管理人员要求专业性高,成本也很高,DBMS可以处理大量的数据和复杂的负载工作,但是却难以管理,因为它们具有数百个配置选项,用于控制诸如用于缓存的内存量以及将数据写入存储器等因素。
基于这些原因,一些DBMS与AI的结合相继出现,例如Oracle提出的自治数据库的概念,以及“OtterTune”,OtterTune是亚马逊和卡内基梅隆大学一起开发的机器学习自动化调整DBMS的系统,并公布起设计论文和开源项目,重点解决DBMS长期存在的一些问题:
1、对管理人员专业性要求高;
2、管理成本高;
3、无法实现配置资源最优化等一系列问题。
据了解,OtterTune可以自动为DBMS的配置选项找到最好的设置方法。
OtterTune目标是使任何人都更容易部署数据库管理系统,即使是那些在数据库管理方面没有任何专业知识的人也可以使用它。
OtterTune与其他DBMS配置工具不同,因为它利用从先前的DBMS部署调整中学到知识。大大减少了调整新的DBMS部署所需的时间和资源。
为此,OtterTune维护了从以前的调优会话收集的调优数据库。它使用此数据构建机器学习(ML)模型,以捕获DBMS如何响应不同的配置。OtterTune使用这些模型来指导新应用程序的实验,推荐改进目标参数的设置(例如,减少延迟或提高吞吐量)。
AI与DBMS的结合目前已经开始尝试,随着技术的发展,未来应该会变的更加成熟,然而,我并不以为,AI的出现会让DBA失业,DBA的工作对于数据库的管理依然非常必要,并且各类AI工具的研发和使用通常也是由经验丰富的DBA来完成。
例如,我在工作中也曾经通过客户服务器的硬件配置及业务场景来自动生成大数据系统的配置文件,这在某种意义上也是一种AI的实现,而这个工具的实现是基于DBA平时对系统参数调整的经验才实现的。
因此,我认为作为DBA应该积极的拥抱技术的变化,尝试用各种手段来简化和优化数据库管理的工作,让AI等技术成为一个未来的DBA所必备的知识。
基于上述原因,出现了融合OLTP和OLAP的一种提法HTAP,意味着可以通过一个数据库系统同时满足事务性需求和分析型需求,而最具代表性的就是Google的Spanner+F1的论文,产生了一批NewSQL系统。
例如CockroachDB和国内PingCAP团队开发的TiDB,以TiDB为例,TiDB采用Raft实现分布式协议,并且完全兼容MySQL的客户端,这对笔者本人也非常有吸引力,即可以用熟悉的MySQL的接口,又不需要对数据库进行分库分表,既实现了分布式,又减轻了用户的学习成本,对于企业来讲,可以通过构建一套分布式数据库系统,同时满足事务性和分析型需求,减轻系统复杂性的同时也提高了效率。
在这里向TiDB团队致敬,在数据库领域作出了世界级的开源项目,可以说是具备里程碑的意义。HTAP将成为未来的数据库的主流发展趋势。
物联网发展势头迅猛,互联网和传统公司也争相布局,随着物联网的发展,传感器等产生了大量的数据,而这些数据往往都是时间顺序,在其他一些应用场景,例如金融领域的,股票交易,汇率等以及Devops的监控数据,都是属于时序数据。
基于这些场景产生了时序数据库的概念,时序数据库可以对时间属性进行特殊的索引,实现数据的快速查询以及更高的压缩,例如InfluxDB项目,InfluxDB是一个使用Go语言开发的分布式时序、时间和指标数据库,无需外部依赖。特别适合处理和分析资源监控数据。
笔者在物联网项目已经尝试使用了InfluxDB,用于存储大型中央空调设备产生的数据,目前项目已经稳定运行半年,与传统DBMS相比,InflluxDB的存储空间减少了近70%,存储和查询效率也有大幅度提升,并且通过InfluxDB集成的聚合函数和连续查询功能,可以自动生成数据的日报表、月报表、年报表,极大减轻了开发成本和系统复杂度。
同样,国内由陶建辉领衔的涛思数据(TAOS Data)团队也正在做时序数据库产品TDengine,目前已经开放测试,希望更多的国内团队做出属于我们自己的优秀数据库产品。
四、结语
数据库作为IT技术架构的核心,新技术层出不穷,随着物联网及人工智能时代的到来,数据库技术迎来高速发展期,DBMS与AI的结合,HTAP以及时序数据库将解决企业海量数据增长带来的各种需求及问题。