找回密码
 立即注册

扫一扫,登录网站

首页 区块链生态 查看内容
  • 5130
  • 0
  • 分享到

分析区块链和数据库,技术之间的不同之处

2018-8-9 10:06

来源: 巴比特

关于数据库和区块链,总会有很多的困惑。区块链其实是一种数据库,因为他是数字账本,并且在区块的数据结构上存储信息。数据库中存储信息的结构被称为表格。但是,区块链是数据库,数据库可不是区块链。他们虽然都是存储信息的,但是设计却完全不同,所以不可以互换。而且,这两者存在的目标也不同,所以对于很多人来说,他们不是很清楚为什么区块链是需要的,以及为什么数据库更适合存储某些数据。首先,我们来看看数据库和区块链之间的区别。

数据库

传统数据库是用来存储信息的数据结构。这包含能够用来制作支持各类商业,金融和管理决定的报告,所需要的数据。政府也会使用数据库来存储大型数据,可以会有几百万个记录。数据库从文件分级系统开始,提供了最基本的信息获取和存储功能。然后,数据库使用相关的模型,通过将多个数据库进行相关,可以有更多复杂的方式来获得数据。存储在数据库中的信息可以使用管理系统来进行管理。简单的数据库被存储在数据行列中,被称为表格。表格中包含不同领域,用来定义不同记录的种类,存储数据被称为属性。每个领域包含列和航,代表存储的记录。

1*rV5d77C8m4m7qRSXzRLOmw

数据库是被管理员可以修改,管理和控制的。数据库总是会有管理员,并且可以完全控制数据库。他们可以创建,删除,修改数据库中的任何记录。他们能优化数据库的性能和大小。越大的数据库就会有更慢的性能,所以管理员可以使用方法来优化。管理员也可以把这个身份转给别人。例如,管理员可以把身份转给另外的用户,让他们来进行数据库备份。但是,问题也会有,例如服务器跨了,唯一的方法就是从备份恢复。数据库也是递归的,也就是说你可以回去重复某个任务,或者说删除任务。如果信息已经备份,那么管理员就会删除之前的记录和其他过期信息。比如你在现在数据库写入了“John Smith”,现在需要更新住址。但是现在已经有“John Smith”的备份了,所以你可以通过现有数据库的新地址进行更新。

1*zsf5RQBQ3PUNPlxnXvaeVg

数据库可以通过服务器架构来实现。这是因为计算机需要连接服务器,它们管理数据库,从而可以获得信息和存储的数据。最初地时候,数据库客户端使用ODBC连接,这是由管理员设定的,然后连接到数据库。这个客户端软件然后就会运行,来完成加密连接,但是必须要有权限才能进入。这个权限能够被管理员设置,或者用户通过密码也可以进入。这就是为什么用户账号会被创造,可以让认证的用户进入,同时拒绝那些没有认证的。现在大多数系统,都会使用网页接口。但是对于私人信息,还是需要认证,但是公开数据库就可以很容易地通过网页进入。

我们可以看出,数据库需要足够的控制,这会让它高度中心化。同时,这也是需要允许的,也就是说需要管理员来设定如何让用户进入。在生产环境下,DB管理员需要设定只读权限,他们也需要给用户设定更新和写入的权限。传统数据库的中心化会保证系统的安全和信任。很多数据库都会在私人网络下运行,同时背后是大公司的防火墙。其他也有数据库是基于云服务器。但是他们仍然是需要管理员来控制他们。

区块链

对于区块链的描述,我们会想到比特币。但是也有很多在企业环境下运行的私有链。区块链在2009年诞生,比特币是基于它的第一个系统。在比特币系统中,区块链是不可更改的数字账本,并且也是逐渐增长的加密分布式数据库。区块链会在同等大小的区块中存储信息。每个区块都会包含前个区块的哈希信息,从而提供加密安全性。这个哈希的信息就是前个区块中的数据和签名,并且前个区块的哈希会回到区块链的首个区块,被称为“创世区块”。整个信息就会通过哈希通过,并且指向下个区块的地址。区块链数据结构,例如默克尔树,是很有效地数据验证方式。

1*a-4Vo2MS2YEMsSGSdD00wQ

为了让区块能够加入到区块链上,整个过程中包含了博弈论。网络中作为节点的计算机被称为“矿工”,必须要竞争来从nonce中找出正确的数值。矿工必须要用计算资源来解决这个数值,而且这也需要计算机硬件。区块链内置的协议,可以通过全网算力来得出解决难题的难易程度。这意味着如果有越多的矿工,解决问题的难度也就越高。这是因为如果有更多矿工,网络上就会有更多的计算资源,同时提高了哈希力,也就是h/s。一旦矿工验证了区块,他们会因为提供算力而获得奖励。这部分激励就是推动节点来挖矿的动力,因为他们会获得交易费用和代币。在比特币中,这也被称为工作量证明算法。

就像我们看到的,区块链使用去中心化的分布式网络。去中心化意味着网络所有的节点都会存储区块链的备份。节点存储全节点的备份,或者是挖矿,或者他们两者都可以做到。没有任何的管理员来验证区块转账。你需要能够解决加密问题的矿工,但是这是基于全网算力的比例。一旦区块被加入到链上,那么这些信息就是不可改变以及透明的。区块链转账是不可以逆转的,这也意味着一旦验证了区块,他们就不能重复使用。区块链是可以容错的,因为如果一个或者多个节点宕机,总是会有其他节点在运行区块链。去中心化的另个优势,就可以让那些不认识或者不信任的人获得透明性。区块链会通过记录转账来提高信任,并且提供加密安全算法来交易数据。

1*8r8KH51ZjQexca4u8gFaMA

区块链是P2P的网络架构。它并不需要中心化的数据库,而是网络所有的节点都会互相连接起来。所以,没人可以控制所有的节点。区块链上无需管理员。如果节点中有人欺诈呢?这会影响整个网络吗?理论上的答案是如果他们获得大多数算力,那么就是可能的。理论上,如果有人可以控制51%的算力,就可以控制网络。这需要非常多的计算资源,所以产生攻击是非常昂贵的。使用计算资源挖矿是有利可图的。能够保证区块链安全的本质就是去中心化,如果有人想修改区块链上的任何信息,就需要其他人的帮助来验证。这就会从主链中分割出新的链,并且只有比主链长才会有效。类似比特币有几千个节点,所以如果需要进行欺诈,就需要改变网络中的所有节点。实际上,这是需要大量计算和电力的,也非常困难完成。这是一种监管的方式,为了保证没人可以欺骗任何人。这就是为何区块链是不可更改的。同时,由于转账信息任何人都能看到,因此这也是透明的。

这就是区块链和数据库,在底层架构上的区别。

1*K6xWZrIXQNT4j2uULFWamA


版权申明:本内容来自于互联网,属第三方汇集推荐平台。本文的版权归原作者所有,文章言论不代表链门户的观点,链门户不承担任何法律责任。如有侵权请联系QQ:3341927519进行反馈。
12下一页
相关新闻
发表评论

请先 注册/登录 后参与评论

    回顶部