区块链究竟是啥?1分钟系列 糖太宗 • 2022年5月11日 下午8:54 • 技术 • 阅读 29 区块链,比特币这些概念很火,但很多人搞不清楚它究竟是啥,从技术的角度,从架构的角度,用通俗的语言谈谈楼主的理解。 究竟啥是区块链? 一句话,区块链是一个存储系统。 更细一点,区块链是一个没有管理员,每个节点都拥有全部数据的分布式存储系统。 通常所见的存储系统是啥样的? 如上图,一块空间存储数据,一个软件管理数据,提供接口写入数据,这是存储系统,例如mysql。 普通的存储系统会有什么常见的问题? 常见的有两个问题: (1)数据存在一个地方很危险,空间损坏数据就丢了,用技术的话说即“数据不高可用”; (2)写入点只有一个,用技术的话说即“单点控制”; 如何保证数据高可用? 解决高可用要“冗余”,如上图,如果能把数据冗余到多个地方,就能保证高可用,一个地方的数据挂了,另外的地方仍存有数据。例如mysql主从集群,以及磁盘的RAID都是这个原理。 这里需要强调两点: (1)数据冗余往往会引发一致性问题,例如mysql主从集群中的读写延时问题; (2)数据冗余往往会降低写入效率,因为同步数据需要消耗额外的资源; 可不可以多点写入? 可以。可以多个节点都实施写入,例如mysql双主集群,又或者多机房多活数据中心。这里要强调的是,多节点写入往往会引发写写冲突的一致性问题。 多点控制写入之后,其实出现了多中心控制,在数据不一致的时候,往往需要有一个算法来协商如何处理不一致数据。 例如,存在两个中心节点时,可以约定这样的算法来处理不一致: (1)以时间戳最小的数据为准,即先来先得; 又例如,存在多个中心节点时,可以约定这样的算法来处理不一致: (2)投票,以多数票的数据为准; 什么是区块链? (1)区块是一块存储空间,可以存储数据; (2)区块链不但像链表一样把区块串起来,还有约定了一系列的方法管理这些数据,所以它是存储系统; (3)区块链有很多节点,每个节点都保存了全部的数据,所以它是高可用的; (4)每一个中心节点都可以生成区块,并写入数据,所以每一个点都是中心节点,或者说区块链是去中心化的,要想控制整个系统,必须控制一半以上的节点,才能控制投票,于是这个系统没有管理员; 综上,区块链实际上是一个没有管理员的,去中心化的,每个节点都拥有全部数据的分布式存储系统。只要你愿意,你随时可以成为区块链中的一个节点,并参与区块的生成与写入,比特币就是基于这个分布式存储上的电子货币。 由于节点很多,很多数据需要同步,这个系统的存储容量其实不大,目前全球存储比特币的区块链也就100多G。 画外音:额,有朋友说他们公司的mysql数据库轻轻松松几百G。 因为节点很多,数据需要保持一致,这个系统的写入效率也很低,存储比特币的区块链每10分钟才生成1个区块,1个区块只有1M的存储空间,只够写入2000笔比特币交易的数据。 画外音:比特币全球交易,每10分钟只能处理2000笔交易。有朋友说他们公司自研的存储系统轻轻松松;每秒处理交易10W笔。 关于区块链,本文只说了概念,作为一个存储系统,数据的生成,写入,管理,数据一致性,数据冲突处理方法,数据完整性保证…很多细节未来再用“通俗技术性文字”和大家分享。 希望这一分钟,大家有收获。 推荐文章: 《关于MySQL,PXB核心原理!》 《MySQL主从之外,你又多了一项选择,Galera》 《为什么MySQL要升级组复制,MGR?》 发布者:糖太宗,转载请注明出处:https://www.qztxs.com/archives/science/technology/5972 区块链 赞 (1) 打赏 微信扫一扫 支付宝扫一扫 糖太宗 0 0 生成海报 为什么MySQL要升级组复制?1分钟系列 上一篇 2022年5月11日 下午8:54 MySQL,在线热备的内核原理! 下一篇 2022年5月11日 下午8:55 相关推荐 OpenVPN + Ldap + OTP OpenVPN 服务端的一些配置 VPN是企业内比较重要的一个资产,不能从网上乱下载,去官网看看 https://openvpn.net/,第一次不懂事,不清楚OpenVPN还有商业版,OpenVPN Access Server 和 OpenVPN Community,直接就安装了OpenVPN AS,没有网上说的那么难,还有图形化界面,登陆进行发现2个并发... 常山赵子龙 技术 2022年5月28日 627000 技术 假如让你来设计数据库中间件 13年底,负责数据库中间件的设计,当时的设计文档,拿出来和大家分享: (1)可以了解下数据库中间件技术; (2)可以了解下架构师系统设计的思路; 画外音:后面项目没落地。 一、总体目标 数据库中间层项目背景不再展开,根据前期的调研以及和公司同事的讨论,中间层的核心目标主要有两个: (1)db虚拟化:让db对业务线透明(本文的db均指mysql),业务线不... 糖太宗 2022年5月11日 23000 use_algolia_search 去algolia官网注册账号 新建index索引 Blog 在hex项目下安装 1 2 3 4 5 6 7 8 9 10 # npm install hexo-algolia --save # export HEXO_ALGOLIA_INDEXING_KEY=xxxxxxxxxxxxxxxxxxxxxx # hexo algolia INFO ... 常山赵子龙 技术 2022年6月2日 16000 很多人问,到底要不要转管理? 想要成为一名管理者,并不是做个决定这么简单,做管理需要一套完全不同的技能。好的架构师,好的技术专家,并不一定代表一个好的管理者。 如何确定自己是不是适合管理岗位呢?可以先问问自己下面五个问题。 问题1:你的兴趣在哪,技术专家,还是带团队? 有没有想过自己五年后在做什么,届时是否工作得开心? 做技术专家,带团队做事情,还是自己创业,搞清楚自己想要什... 糖太宗 技术 2022年5月15日 24000 安全设计Checklist(转发) 输入验证 校验跨信任边界传递的不可信数据(策略检查数据合法性,含白名单机制等)格式化字符串时,依然要检验用户输入的合法性,避免可造成系统信息泄露或者拒绝服务 禁止向Java Runtime.exec()方法传递不可信、未净化的数据(当参数中包含空格,双引号,以-或者/符号开头表示一个参数开关时,可能会导致参数注入漏洞),建议如果可以禁止JVM执... 常山赵子龙 技术 2022年5月27日 45000 发表回复 您的电子邮箱地址不会被公开。 必填项已用*标注*昵称: *邮箱: 网址: 记住昵称、邮箱和网址,下次评论免输入 提交