目录
不知道什么是更好的
您永远不会忘记您的第一次CRUD应用
你也永远不会忘记你的第一个搜索系统
我学到的
算法真的很重要
表现也很重要
你认为写系统很复杂吗?
在现实世界中,它必须被操作
答案通常是“视情况而定”
编程遗愿清单
首页 后端开发 Golang Go rqlite作者告诉你:开发数据库软件,算法多重要!

Go rqlite作者告诉你:开发数据库软件,算法多重要!

Jan 22, 2022 am 09:19 AM
go golang

本文由golang教程栏目给大家介绍关于《Go rqlite作者告诉你:开发数据库软件,算法多重要!》,希望对需要的朋友有所帮助!

编写数据库程序是一项迷人的工作。在过去的两年里,我一直深度参与开源数据库的开发,而数据库编程可能是作为一个软件开发者所能完成的最有启发性的项目了。

然而,真正令人震惊的是, 在过去的 6 年里,我对数据库的态度发生了很大的变化。 从一开始不感兴趣的状态,到现在我开始认为数据库系统是软件工程的一个巅峰。

不知道什么是更好的

在我的职业生涯的大部分时间里, 我对数据库的唯一经验就是阅读有关它们的资料。 通常是在想当枯燥的背景下 — 打开任何一本有关数据库的本科教科书,就能明白我的意思。 通常你会看到如下表格,作为关系型数据库的典型用例:

ID FIRST LAST TITLE DEPARTMENT
1 Robert Kelly Director Marketing
2 Tom Burke Representative Sales
3 John Smith Vice President Sales

你能再多读些无聊的东西吗?如果这些都是关于数据库的,我不想和它们有任何关系。重点是什么?软件比这酷多了,对吧?所以我在很长一段时间里完全避免了与数据库有关的任何事情

您永远不会忘记您的第一次CRUD应用

2009年,经过多年的写作 嵌入式软件, Linux 设备驱动程序, 和 网络软件, 我发现自己领导的团队需要构建一个基于web的系统。你看,这个 AWS 云计算已经到来,基于云计算的许可技术 MAC 地址 不再有效。我的团队必须建立一个 许可门户 用于我们新的基于EC2的软件设备。因为我们在这方面有很多经验 Python, 我们选择了 Django, 运行在 MySQL. 发生了一些新的事情。实际上,我是从数据库开始工作的。

随着我国平原地区的发展CRUD应用程序继续运行,我开始意识到数据库是多么重要——它对我们的系统是多么重要。如果我们丢失了数据库,我们的软件开发就白费了。如果数据库损坏了数据,我们客户的设备可能会未经许可,他们的网络将停止运行。如果数据库不能正常运行,成千上万的人将同时受到影响。但这些事情都没有发生过。数据库始终工作。它从不让我们失望。我印象深刻。
后来我发现了外键约束,唯一约束,引用完整性,索引,(记住,在这个时候我什么都不知道关于这些事情)-数据库可以通过各种方式帮助我构建一个更健壮的系统。我终于意识到现代数据库是惊人的-数据库是世界上最无聊的东西直到你真的必须用它们来构建一个系统

你也永远不会忘记你的第一个搜索系统

到2012年,我领导了一个团队,建立了一个大型索引和搜索系统基础上的大型键值数据库,带有弹性搜索在其核心。看看elasticsearch这样的系统能做什么 —— 一个建立在世界级索引这项技术——即使其下有TB级的日志数据,也让人大开眼界。
到现在为止,我甚至看到数据库和搜索系统也失败了,但我被数据库技术迷住了。到2014年,我加入了一个小型专门团队,开发[开源时间序列数据库]的核心(github.com/influxdata/influxdb).

我学到的

算法真的很重要

只有在数据库开发中才有大O分析真的活过来了。数据库是程序员仍然需要循环、排序和过滤数百万对象的少数应用程序之一。这是少数几个在CS课上学到的很多枯燥材料都很重要的地方之一。

其他许多软件开发都不是这样。写入启动ROM固件?不,算法对我来说从来都不重要。调谐器设备驱动程序? 不,没关系。网络设备管理软件? CRUD应用程序?几乎不所有这些学科都需要不同的技能和知识。大多数时候,我只是在面试中讨论了运行时的复杂性。
但随着数据库的发展,这一切都发生了变化。实际上看到一个系统返回正确的结果,但是由于算法的改变,只在以前的一小部分时间内,看到它发生在您的代码中,在您构建的系统中,这是一件美妙的事情。

表现也很重要

软件中有一个老故事是这样的:程序员编写的一些代码的运行速度比以前的版本快十倍。他展示了它,但有人指出,它产生的数据与正确的数据略有不同。“但是速度快了十倍。”程序员指出。“好吧,如果它不需要是正确的,我可以制作一个完全不占用空间、运行速度无限快的版本”,另一个回答说。
这个道德故事一直对我影响很大。正确总是比什么都重要。这是真的。但这也让我相信,项目之所以有价值,仅仅是因为它们产生了正确的结果。

对于数据库,情况并非如此。
性能不仅仅是一项功能。这是一个要求。那些愿意为数据库掏钱的人经常这样做,因为他们拥有大量的数据。如果数据库在这种情况下不能很好地执行—如果它不能快速有效地返回结果—那么它可能根本不工作。

你认为写系统很复杂吗?

我认为开发数据库最让我震惊的是查询引擎变得如此复杂。我有很多构建系统的经验,可以将数据写入并存储到磁盘。使这些系统运行良好可能是一项重大挑战。
但这种复杂性通常比查询引擎的复杂性要小得多。一个灵活的查询系统——有效地构建一个系统来回答问题,当你不知道问题会是什么的时候——需要认真的设计思想。查询计划器必须有效。查询系统必须支持许多正交需求——按某些维度过滤,按其他维度分组,连接来自不同表的数据——有时还支持来自外部源的数据。最后,查询系统必须高效且性能良好。这导致了设计和实现中抽象和优化之间的紧张关系,这需要真正的技巧才能很好地管理。

在现实世界中,它必须被操作

任何重要的数据库都必须支持备份、恢复、碎片管理和监视等基本操作。
如果我,作为一个严肃的操作员,不能备份你的数据库,我不能使用它,就这么简单。数据库接受写操作的速度有多快并不重要。在查询过程中,它的内存占用有多小并不重要。如果我不能保护数据库中的数据不受数据库创建者您无法控制的故障的影响,我将永远无法舒适地运行它。
当然,有很多方法可以备份数据库,而不需要数据库的合作。但内置方法通常是最好的。这也是我向 rqlite v2.0.如果我想让任何人认真地使用rqlite,我必须解决现实世界中的问题,即系统可能完全失败,并将数据拖得很长时间。

因此,在设计和实现数据库时,从一开始就要构建操作支持。将其作为设计的基本部分。您的用户将为此感谢您。

答案通常是“视情况而定”

当您第一次开始使用数据库时,尤其是作为一名操作员,您经常会问这样的问题:系统可以以什么速率索引?它对查询的响应速度有多快?我需要多少磁盘空间?一块碎片能有多大,而且还能正常工作?我怎样才能加快速度?所有人都毫无保留地问。我过去常常自己做。
也许你可以和数据库程序员谈谈,问他们这些问题。而你经常——也许永远——得到的回答是:这取决于你。你必须基准,你必须衡量。听到这个消息可能会很恼火,而且可能看起来像是在逃避责任。

但事实并非如此。
现在,当我听到这样的问题时,我会微笑。太天真了。
索引率可能取决于数据的大小,而不仅仅是文档或数据点的数量。这可能取决于批处理、数据的基数、数据库是否群集、数据中的哪些列和字段被索引、是新数据还是对现有数据的更新、运行数据库的机器、RAM、IO性能以及使用的复制。
控制性能的变量永远不会结束。
对于查询,可能取决于时间序列数据的时间范围。它取决于命中的记录数、查询的字段数、是否涉及范围扫描、数据是否索引、使用的索引类型、可能访问的碎片数、数据是否为本地数据。以及机器的特点。它有货吗?它正在进行维护吗?网络忙吗?

所以答案总是, 视情况而定。 数据库设计者是诚实的。 他们可以知道他们建立的系统的一切, 但仍然不知道您的问题的答案。

编程遗愿清单

如果给那些希望提高编程能力的开发人员一条建议的话,那就是加入数据库开发团队。因为数据库开发,我的编程技能大大提高了——这是一次美妙的编码体验。

原文地址:https://www.philipotoole.com/what-i-learned-from-programming-a-database/

译文地址:https://learnku.com/go/t/64605

以上是Go rqlite作者告诉你:开发数据库软件,算法多重要!的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用 Golang 安全地读取和写入文件? 如何使用 Golang 安全地读取和写入文件? Jun 06, 2024 pm 05:14 PM

在Go中安全地读取和写入文件至关重要。指南包括:检查文件权限使用defer关闭文件验证文件路径使用上下文超时遵循这些准则可确保数据的安全性和应用程序的健壮性。

如何为 Golang 数据库连接配置连接池? 如何为 Golang 数据库连接配置连接池? Jun 06, 2024 am 11:21 AM

如何为Go数据库连接配置连接池?使用database/sql包中的DB类型创建数据库连接;设置MaxOpenConns以控制最大并发连接数;设置MaxIdleConns以设定最大空闲连接数;设置ConnMaxLifetime以控制连接的最大生命周期。

golang框架的优缺点比较 golang框架的优缺点比较 Jun 05, 2024 pm 09:32 PM

Go框架凭借高性能和并发性优势脱颖而出,但也存在一些缺点,如相对较新、开发者生态系统较小、缺少某些功能。此外,快速变化和学习曲线可能因框架而异。Gin框架以其高效路由、内置JSON支持和强大的错误处理而成为构建RESTfulAPI的热门选择。

如何在 Golang 单元测试中使用 gomega 进行断言? 如何在 Golang 单元测试中使用 gomega 进行断言? Jun 05, 2024 pm 10:48 PM

如何在Golang单元测试中使用Gomega进行断言在Golang单元测试中,Gomega是一个流行且功能强大的断言库,它提供了丰富的断言方法,使开发人员可以轻松验证测试结果。安装Gomegagoget-ugithub.com/onsi/gomega使用Gomega进行断言以下是使用Gomega进行断言的一些常用示例:1.相等断言import"github.com/onsi/gomega"funcTest_MyFunction(t*testing.T){

Golang 框架中的错误处理最佳实践有哪些? Golang 框架中的错误处理最佳实践有哪些? Jun 05, 2024 pm 10:39 PM

最佳实践:使用明确定义的错误类型(errors包)创建自定义错误提供更多详细信息适当记录错误正确传播错误,避免隐藏或抑制根据需要包装错误以添加上下文

Golang框架与Go框架:内部架构与外部特性对比 Golang框架与Go框架:内部架构与外部特性对比 Jun 06, 2024 pm 12:37 PM

GoLang框架与Go框架的区别体现在内部架构和外部特性上。GoLang框架基于Go标准库,扩展其功能,而Go框架由独立库组成,实现特定目的。GoLang框架更灵活,Go框架更容易上手。GoLang框架在性能上稍有优势,Go框架的可扩展性更高。案例:gin-gonic(Go框架)用于构建RESTAPI,而Echo(GoLang框架)用于构建Web应用程序。

如何在 Golang 中将 JSON 数据保存到数据库中? 如何在 Golang 中将 JSON 数据保存到数据库中? Jun 06, 2024 am 11:24 AM

可以通过使用gjson库或json.Unmarshal函数将JSON数据保存到MySQL数据库中。gjson库提供了方便的方法来解析JSON字段,而json.Unmarshal函数需要一个目标类型指针来解组JSON数据。这两种方法都需要准备SQL语句和执行插入操作来将数据持久化到数据库中。

如何解决golang框架中常见的安全问题? 如何解决golang框架中常见的安全问题? Jun 05, 2024 pm 10:38 PM

如何在Go框架中解决常见的安全问题随着Go框架在Web开发中的广泛采用,确保其安全至关重要。以下是解决常见安全问题的实用指南,附带示例代码:1.SQL注入使用预编译语句或参数化查询来防止SQL注入攻击。例如:constquery="SELECT*FROMusersWHEREusername=?"stmt,err:=db.Prepare(query)iferr!=nil{//Handleerror}err=stmt.QueryR

See all articles