EOS计算资源估算办法【内存/CPU/带宽】

简介: 要开发一个基于EOS区块链的DAPP需要多少内存、CPU或带宽资源?这是很多即将开始EOS项目的开发者关注的一个重要问题。本文将介绍如何估算EOS DAPP的内存/CPU/带宽资源需求以及相应的成本。

要开发一个基于EOS区块链的DAPP需要多少内存、CPU或带宽资源?这是很多即将开始EOS项目的开发者关注的一个重要问题。本文将介绍如何估算EOS DAPP的内存/CPU/带宽资源需求以及相应的成本。

在我们开始进入具体的EOS区块链DApp的资源需求估算之前,先了解一下EOS中的资源类型、使用方法以及资源分配模型。如果你希望深入学习EOS DApp的开发,可以参考这个EOS DApp开发教程

1、EOS中的资源类型

在EOS区块链上,有三种类型的资源供EOS账号利用:

  • 状态存储:RAM,即内存
  • 带宽及日志存储:Bandwidth,即网络带宽
  • 计算:CPU

2、EOS资源的利用方式

在EOS区块链中,内存/RAM用于保存区块链的状态,例如交易委托账本和账户余额等。这些状态通常由应用程序逻辑来访问。

网络带宽计量你在过去3天内的平均带宽消耗。每当你发送一个动作或交易都会暂时占用一些带宽资源。

CPU计量你在过去3天里的对计算资源的平均利用情况,单位为毫秒。每当你发送一个动作或交易,也会暂时消耗一些CPU资源。

3、EOS资源的分配模型

在EOS区块链中,网络带宽和CPU资源是采用抵押方式获取的。分配给你多少带宽和CPU,取决于你抵押的EOS代币在过去3天里EOS区块链系统抵押合约持有的代币总量中占多大的比例。发送交易所消耗的网络带宽资源和CPU资源,会随时间流逝自动再释放给你。

EOS中的RAM资源则需要以市场价格购买,该价格按Bancor算法自动调节。与CPU和网络带宽资源不同,已经占用的内存资源不会自动释放,唯一的释放办法是从你的账户状态存储中删除数据,之后你就可以按市场价格出售这些空闲的内存资源。

4、资源价格计算器

要计算EOS内存资源的价格,需要使用bancor算法。如果你希望学习如何在自己的EOS钱包产品中实现资源的价格计算,可以参考这个EOS钱包开发教程

首先用EOS的客户端工具cleos命令获取内存市场数据:

$ cleos -u http://nodes.get-scatter.com:80 get table eosio eosio rammarket                  

{
  "supply": "10000000000.0000 RAMCORE",
  "base": {
    "balance": "35044821247 RAM",
    "weight": "0.50000000000000000"
  },
  "quote": {
    "balance": "3158350.8754 EOS",
    "weight": "0.50000000000000000"
  }
}

基于上面的内存市场数据,可以按如下公式计算内存价格:

内存价格 = Connector Balance / (Smart Token’s Outstanding supply × CW)
          = 3158350.8754 EOS / 35044821247 RAM = 0.09 EOS/Kib

其中:

  • Connector Balance = quote.balance
  • Smart Token’s Outstanding supply = base.balance
  • CW = quote.weight
  • EOS是连接器(connector), RAMCORE是智能代币(smart token)

注意:在Bancor协议白皮书中有个错误,CW不是故意设置为50%,详情参考这里

网络带宽和CPU资源的价格依赖于出块节点,彼此的价格都不一样。下面以eosnewyorkio这个出块节点为例说明。

还是先用cleos获取基础数据:

$ cleos -u https://api.eosnewyork.io/ get account eosnewyorkio

net bandwidth:

staked:        900.0000 EOS           (total stake delegated from account to self)
delegated:       0.0010 EOS           (total staked delegated to account from others)
used:               200 bytes
available:        578.4 MiB
limit:            578.4 MiB

cpu bandwidth:

staked:        900.0000 EOS           (total stake delegated from account to self)
delegated:       0.0000 EOS           (total staked delegated to account from others)
used:             10.91 ms
available:        1.864 min
limit:            1.864 min

计算公式如下:

Net Price = (Net Staked / Net Available) / 3
          = 900.0000 / (578.4*1024) / 3 = 0.0005 EOS/KiB/Day
          
CPU Price = (CPU Staked / CPU Available) / 3
          = 900.0000/(1.864*60*1000)/3 = 0.0025 EOS/ms/Day          

你可以在这里查看这些资源的实时价格

5、估算EOS DApp的内存资源需求

首先我们估算内存资源的需求及成本。参考eos节点源码eos/libraries/chain/eosio_contract.cpp:

The amount of code = code_size X setcode_ram_bytes_multiplier

code_size: size of wast file

setcode_ram_bytes_multiplier =10

另外:

overhead_per_row_pper_index = 32 + sizeof(key) + row data for all objects which stored in DB

这样得到总计内存需求:

Ram for Dapp = Amount of code + overhead_per_row_pper_index

6、估算EOS DApp的CPU和带宽资源需求

假设我们要开发一个EOS上的DApp,预计每天有1000个用户访问,每个用户每天进行5个交易。

通常一个交易需要消耗200字节的带宽和1ms的CPU。因此我们可以得到如下的结果:

total_cpu_dapp = 1ms*5*1000 = 5 000 ms/day

total_net_dapp = 0.2*5*1000 = 1000 KiB/day

结合前面的资源价格计算,我们得到如下的DApp资源成本数据:

Total EOS (CPU+NET) = 1000KiB * 0.0005 EOS/KiB/Day + 5 000 ms/Day *0.0025EOS/ms/Day 
                    ~ 13 EOS/day

也就是说,为了运营这个DApp,让它可以支持每天5000人次的访问,我们每天需要保证合约账户上有13个EOS的资源抵押可用,这就是我们开发这个EOS DApp所需要的内存、CPU和带宽资源的估算结果。如果你希望用熟悉的PHP来开发EOS DApp,可以下载这个EOS PHP开发包


原文链接:EOS DAPP资源需求计算方法 - 汇智网

目录
相关文章
|
8天前
|
弹性计算 Kubernetes Perl
k8s 设置pod 的cpu 和内存
在 Kubernetes (k8s) 中,设置 Pod 的 CPU 和内存资源限制和请求是非常重要的,因为这有助于确保集群资源的合理分配和有效利用。你可以通过定义 Pod 的 `resources` 字段来设置这些限制。 以下是一个示例 YAML 文件,展示了如何为一个 Pod 设置 CPU 和内存资源请求(requests)和限制(limits): ```yaml apiVersion: v1 kind: Pod metadata: name: example-pod spec: containers: - name: example-container image:
|
17天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
191 2
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
128 5
|
29天前
|
运维 JavaScript Linux
容器内的Nodejs应用如何获取宿主机的基础信息-系统、内存、cpu、启动时间,以及一个df -h的坑
本文介绍了如何在Docker容器内的Node.js应用中获取宿主机的基础信息,包括系统信息、内存使用情况、磁盘空间和启动时间等。核心思路是将宿主机的根目录挂载到容器,但需注意权限和安全问题。文章还提到了使用`df -P`替代`df -h`以获得一致性输出,避免解析错误。
|
1月前
|
C# 开发工具 Windows
C# 获取Windows系统信息以及CPU、内存和磁盘使用情况
C# 获取Windows系统信息以及CPU、内存和磁盘使用情况
41 0
|
2月前
|
Prometheus Kubernetes 监控
使用kubectl快速查看各个节点的CPU和内存占用量
在Kubernetes集群中,安装metrics-server,并使用kubectl快速查看集群中各个节点的资源使用情况。
128 0
|
3月前
|
存储 监控 Docker
如何限制docker使用的cpu,内存,存储
如何限制docker使用的cpu,内存,存储
|
3月前
|
缓存 Kubernetes 数据中心
在Docker中,如何控制容器占用系统资源(CPU,内存)的份额?
在Docker中,如何控制容器占用系统资源(CPU,内存)的份额?
|
3月前
|
KVM 虚拟化
[kvm]cpu内存硬盘配置
[kvm]cpu内存硬盘配置
|
3月前
|
缓存 Linux 调度
Linux服务器如何查看CPU占用率、内存占用、带宽占用
Linux服务器如何查看CPU占用率、内存占用、带宽占用
981 0