聚合国内IT技术精华文章,分享IT技术精华,帮助IT从业人士成长
IT技术精华
设为首页
加入收藏
订阅本站
IT技术文章精选
2024
每日Shell
关于
热门搜索:
IT技术
Linux
系统
算法
架构
数据库
优化
python
分布式
php
您的位置:
首页
» 技术文章 » 正文
区块链究竟是啥?1分钟系列
2021-09-17 00:50
浏览: 2346674 次
我要评论
(0 条)
字号:
大
中
小
#区块链
1
个内容
#比特币
1
个内容
#架构师
6
个内容
#架构
42
个内容
#互联网
25
个内容
区块链,比特币这些概念很火,但很多人搞不清楚它究竟是啥,从技术的角度,从架构的角度,用通俗的语言谈谈楼主的理解。
究竟啥是区块链?
一句话,区块链是一个存储系统。
更细一点,区块链是一个
没有管理员,每个节点都拥有全部数据的分布式存储系统
。
通常所见的存储系统是啥样的?
如上图,一块空间存储数据,一个软件管理数据,提供接口写入数据,这是存储系统,例如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?
》
标签:
知识来源:
mp.weixin.qq.com/s/?id=60c5e07690afa9eab58c26c4570c73e7&source_url=https%3A%2F%2Fmp.weixin.qq.com%2Fs%2FdYLOSwR8QHi9v8USGeirIA
本文链接:
区块链究竟是啥?1分钟系列
打印
复制链接
上一篇:
如何优雅地记录操作日志?
下一篇:
PipeCAD - 异常处理
网友评论
已有
0
条评论,
我也要评论
发表评论
用户名:
*
电子邮箱:
*
(保密)
网站网址:
验证码:
申请头像
添加评论内容
Ctrl+Enter 快捷回复
每天为热爱学习的工程师/架构师/技术经理/CTO更新最新最优质的IT技术精华文章,帮助你突破年薪百/千万。
➨GitHub:
https://github.com/taogogo
➨关注微博:
http://weibo.com/taogogo
随机推荐
数据分析该知道的IP地址知识
纯真IP数据库的解析与读取
最适合程序员的笔记软件
面试官:聊聊分布式事务,再说说解决方案!
CFL:面向医疗物联网的多集群联邦学习与跨链共识方法
软件工程师在加入新团队时应问的 20 个问题
为什么今天你应该把前端安全重视起来 |GMTC
不得不说,其实你的性能优化手段已经过时了 | QCon
美团外卖实时数仓建设实践
标签云
IT技术
Linux
系统
算法
架构
数据库
优化
python
分布式
php
App
opensource
面试
大数据
数据
术→技巧
java
教程
Web开发
Linux & Unix
Technical
程序设计
原创
机器学习
技术
docker
SQL Server
Javascript
Cache
程序开发
nginx
Working case
默认分类
..experience
编程
oracle
安全
杂项
Redis
操作系统
网友评论已有0条评论, 我也要评论