关于数据库和区块链,总会有很多的困惑。区块链其实是一种数据库,因为他是数字账本,并且在区块的数据结构上存储信息。数据库中存储信息的结构被称为表格。但是,区块链是数据库,数据库可不是区块链。他们虽然都是存储信息的,但是设计却完全不同,所以不可以互换。而且,这两者存在的目标也不同,所以对于很多人来说,他们不是很清楚为什么区块链是需要的,以及为什么数据库更适合存储某些数据。首先,我们来看看数据库和区块链之间的区别。
数据库
传统数据库是用来存储信息的数据结构。这包含能够用来制作支持各类商业,金融和管理决定的报告,所需要的数据。政府也会使用数据库来存储大型数据,可以会有几百万个记录。数据库从文件分级系统开始,提供了最基本的信息获取和存储功能。然后,数据库使用相关的模型,通过将多个数据库进行相关,可以有更多复杂的方式来获得数据。存储在数据库中的信息可以使用管理系统来进行管理。简单的数据库被存储在数据行列中,被称为表格。表格中包含不同领域,用来定义不同记录的种类,存储数据被称为属性。每个领域包含列和航,代表存储的记录。
数据库是被管理员可以修改,管理和控制的。数据库总是会有管理员,并且可以完全控制数据库。他们可以创建,删除,修改数据库中的任何记录。他们能优化数据库的性能和大小。越大的数据库就会有更慢的性能,所以管理员可以使用方法来优化。管理员也可以把这个身份转给别人。例如,管理员可以把身份转给另外的用户,让他们来进行数据库备份。但是,问题也会有,例如服务器跨了,唯一的方法就是从备份恢复。数据库也是递归的,也就是说你可以回去重复某个任务,或者说删除任务。如果信息已经备份,那么管理员就会删除之前的记录和其他过期信息。比如你在现在数据库写入了“John Smith”,现在需要更新住址。但是现在已经有“John Smith”的备份了,所以你可以通过现有数据库的新地址进行更新。
数据库可以通过服务器架构来实现。这是因为计算机需要连接服务器,它们管理数据库,从而可以获得信息和存储的数据。最初地时候,数据库客户端使用ODBC连接,这是由管理员设定的,然后连接到数据库。这个客户端软件然后就会运行,来完成加密连接,但是必须要有权限才能进入。这个权限能够被管理员设置,或者用户通过密码也可以进入。这就是为什么用户账号会被创造,可以让认证的用户进入,同时拒绝那些没有认证的。现在大多数系统,都会使用网页接口。但是对于私人信息,还是需要认证,但是公开数据库就可以很容易地通过网页进入。
我们可以看出,数据库需要足够的控制,这会让它高度中心化。同时,这也是需要允许的,也就是说需要管理员来设定如何让用户进入。在生产环境下,DB管理员需要设定只读权限,他们也需要给用户设定更新和写入的权限。传统数据库的中心化会保证系统的安全和信任。很多数据库都会在私人网络下运行,同时背后是大公司的防火墙。其他也有数据库是基于云服务器。但是他们仍然是需要管理员来控制他们。
区块链
对于区块链的描述,我们会想到比特币。但是也有很多在企业环境下运行的私有链。区块链在2009年诞生,比特币是基于它的第一个系统。在比特币系统中,区块链是不可更改的数字账本,并且也是逐渐增长的加密分布式数据库。区块链会在同等大小的区块中存储信息。每个区块都会包含前个区块的哈希信息,从而提供加密安全性。这个哈希的信息就是前个区块中的数据和签名,并且前个区块的哈希会回到区块链的首个区块,被称为“创世区块”。整个信息就会通过哈希通过,并且指向下个区块的地址。区块链数据结构,例如默克尔树,是很有效地数据验证方式。
为了让区块能够加入到区块链上,整个过程中包含了博弈论。网络中作为节点的计算机被称为“矿工”,必须要竞争来从nonce中找出正确的数值。矿工必须要用计算资源来解决这个数值,而且这也需要计算机硬件。区块链内置的协议,可以通过全网算力来得出解决难题的难易程度。这意味着如果有越多的矿工,解决问题的难度也就越高。这是因为如果有更多矿工,网络上就会有更多的计算资源,同时提高了哈希力,也就是h/s。一旦矿工验证了区块,他们会因为提供算力而获得奖励。这部分激励就是推动节点来挖矿的动力,因为他们会获得交易费用和代币。在比特币中,这也被称为工作量证明算法。