博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
揭秘UOS独特的CPU模型
阅读量:6453 次
发布时间:2019-06-23

本文共 1474 字,大约阅读时间需要 4 分钟。

近期,某链的CPU资源出现了严重的供不应求,“CPU爆了”成为链圈的一个热词。

在这里插入图片描述

CPU爆了意味着区块链网络当前没办法为你的账号提供计算服务,是令开发者头疼的问题之一。DApp开发成本过高,需要支付大额利息去租赁CPU资源,并且面临用户因拥堵无法进入DAPP的局面....

Ulord近日发布的UOS独有的CPU模型,是CPU拥堵的解药。今天小秘书就来系统地谈谈UOS独特的CPU模型如何解决CPU拥堵的!

一、CPU是什么?

CPU即中央处理器,是操作系统中才会涉及到的概念,通常被称为计算机的大脑。虽然 CPU 只构成许多处理单元中的一个,但它却是最重要的处理单元之一。它是计算机中执行计算、操作和运行程序的部分。

在区块链操作系统上,CPU 用于执行处理事务,相当于是每一笔交易的燃料。每个操作都需要一定的CPU处理时间,因此,如果你要将交易广播到区块链网络,则你的账号必须具有足够的CPU分配。

CPU资源用完可恢复,周期为24小时。

二、为什么会出现CPU拥堵?

我们可以把链比喻成火车,CPU就是你坐火车的车票。

火车的座位(全网CPU的总量)是固定的,而抵押获取Token的数量是随时变化的。假如在一个链上,每个区块之间的间隔是500毫秒。为了帮助确保BP节点们有足够的时间在世界各地发放区块,打包区块的处理时间是300毫秒,那么每个区块的交易处理时间限制为200毫秒,BP节点必须在这200毫秒内将生产出来的区块进行验证然后发布到网络上。

在那200毫秒的上限内还有一个百分比阈值会启动限速。在没有到达此阈值之前,系统认为网络是不拥堵的,此时用户在相同CPU抵押的情况下,可以使用更多的CPU资源。一旦超过此阈值,此时的网络使用量大,系统会认为处于“拥堵”状态,所以用户可使用的CPU资源会被限制,体现为根据抵押的代币按比例分配CPU的资源,这时如果抵押太低,就会出现因资源不足而产生的交易失败。

举个例子,假设整条链上有1000个代币被抵押在CPU上,其中包含小新的账户抵押的20个,每个区块的交易处理时间限制为200毫秒,那么理论上小新会拥有CPU总容量的2%的使用权,4毫秒。 如果链的CPU没有被大量使用并且没有达到激活限速阈值,小新在一个区块内的CPU可用量超过4毫秒;一旦链的CPU使用达到了该阈值,小新在一个区块内的可用CPU量会减少,最低回到4毫秒,这个时候如果个人抵押较少,可能会造成无法发起交易,这就是CPU拥堵。

三、UOS独特的CPU模型,解决CPU拥堵

UOS具有独特的CPU模型,在区块容量和链上可使用CPU最高临界值做了创新设计。

UOS的区块容量大,有2M。每个区块之间间隔1000毫秒,550毫秒用来打包区块,450毫秒用来处理交易。UOS在1000毫秒内,交易处理时间比每个区块之间间隔500毫秒的链要多出50毫秒。从本质上提高了用户使用的CPU时长。

UOS在链的CPU使用百分比阈值进行了创新设计,一般链的CPU使用百分比阈值为10%-30%就会拥堵,而UOS独特的CPU模型,当用户所用的CPU资源达到全网的50%的时候才会发生拥堵,改善了CPU使用率,从而提高交易的TPS。

结束语

UOS独特的CPU模型对整个行业来说,将掀起一番讨论热潮。

Ulord社区资深开发者说道:UOS未来可能会成为一片新大陆, 成为解决公链CPU拥堵的终极出路。期待一个个优秀的开发者、一个个现象级的应用,从UOS上崛起。

转载于:https://blog.51cto.com/14138546/2342381

你可能感兴趣的文章
部署Ganglia监控Hadoop&Hbase
查看>>
gitlab的用户使用手册
查看>>
论Optimizer的工作模式ALL_ROWS&FIRST_ROWS
查看>>
生产环境高并发MySQL SQL语句优化案例
查看>>
Lync 小技巧-24-PDF 加密文件-转-Word-操作手册
查看>>
ASP.NET性能优化之分布式Session
查看>>
TaffyDB Introduction
查看>>
转载:《TypeScript 中文入门教程》 16、Symbols
查看>>
JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记4
查看>>
C#技术------垃圾回收机制(GC)
查看>>
【转】eclipse -- the project was not built due to a resource exists with a different case...
查看>>
漫谈并发编程(三):共享受限资源
查看>>
【转】github如何删除一个仓库
查看>>
Linux系统编程——进程调度浅析
查看>>
大数据Lambda架构
查看>>
openCV_java 图像二值化
查看>>
状态模式
查看>>
删除CentOS / RHEL的库和配置文件(Repositories and configuraiton files)
查看>>
DJANGO变动库的一次真实手动经历
查看>>
8个基本的引导工具的网页设计师
查看>>