如何在NEO共识节点间分配任务

任何计算机系统都有监控操作,可能会发送心跳信息、校验和查询及哈希请求等。这些操作在本文中都被统称为任务。在中心化系统中,通常会有一个受认证的节点或节点群组来完成任务。而去中心化系统可以将任务下发给各个节点,从而灵活拓展,因此效率也显然更高,但这也就导致了相应的问题——到底如何在所选节点间分配任务。我们可以通过以下两种方式解决这个问题:

  • 节点随机选择要做的任务

  • 节点使用dBFT之类的共识算法分配任务

本文将探讨第二种方法。

拜占庭容错任务分配

假设有v个任务和n个可随时在系统中工作的节点。每个任务和节点都有一个独一无二的标识符。因此每个节点都可以使用HRW [2]选择任务,使用预先设定的算法来执行任务。任务分配共识实际上确认了所有任务都是在未发生技术故障的前提下完成的。

使用dBFT算法,即使网络[1]中高达1/3的节点做出妥协也可以达成共识。举个例子,若某系统n=v=3:

该系统有3个任务和3个节点,其中有一个节点有欺诈行为。

这些任务统一在各节点中进行分配:如果每个节点承担一个任务,在最坏的情况下会有一个任务可能无法被执行。因此我们使用了冗余来确保所有任务都能被执行。v任务须被n/3+1个节点执行。在此情况下,节点任务池的大小可通过以下公式算出。

在此案例中,P(3,3) = 2

不管哪个节点做出了妥协,所有任务都仍能被正确执行。

 

图1 不同任务数前提下任务池大小的最大值

图1标明,该公式的值趋向于v/3,意味着在任何情况下各节点任务池中的任务都占所有任务的1/3。在负载增加的情况下系统可能不能正常拓展。

减小任务池大小

若系统的n=3 v=4,任务池大小即为P(3,4) = 2.3 ≈ 3。各节点的任务池大小就可减至2:

因此,各任务被执行的几率就都达到了66%。因此任务池大小可以缩减,只要确保一定的精度就可以了。

出于研究的目的,我们建立了一个模拟模型进行实验,参数为v=1000。我们尝试在不同n的情况下找到能使任务无法执行的可能性小于0.00001的任务池大小。该模型已开源在github[3]。结果如图2所示:

图2 v=1000时的任务池容量实验

上图显示,该模型的实验数据实际上处于任务池容量的最大和最小值的区间里。因此当n增加时,任务池所需容量会减小。任务池容量的最大值与实验值之间的差额可以使用R(x)(位于y1轴上,取0-1之间的任意值)公式求得一个近似值。然后任务池容量就可通过以下公式求得。

深入研究

本文并未考虑网络节点发生故障的可能性,而且所有实验均在最坏假设下进行,做出妥协的节点数也带入了最大值。显然,100个节点中出现33个妥协节点的比例也比3个节点中出现1个妥协节点的几率小。因此可以将“妥协几率”的方程定义为Q(x),而后计算出任务池的大小为P(n,v)⋅R(n)⋅Q(n)。而当妥协节点的数量小于n/3时,R(x)的的行为还需要深入研究。

参考文献

  1. 张铮文,区块链拜占庭容错算法:docs.neo.org/en-us/basic…

  2. 一致性哈希(最高随机权值):
    en.wikipedia.org/wiki/Rendez…

  3. 模拟模型库:github.com/AlexVanin/b…

原文翻译自:medium.com/@neospcc/ta…

作者:Alexey Vanin

翻译:NEOFANS

 

### 使用 Py2Neo 创建节点 在 Neo4j 中通过 `py2neo` 库创建节点的过程相对简单。以下是具体方法以及注意事项: #### 导入必要的库 为了操作 Neo4j 数据库,首先需要导入 `py2neo` 的相关模块。 ```python from py2neo import Graph, Node ``` #### 连接数据库 连接到 Neo4j 数据库时需要注意可能存在的重试问题[^1]。可以通过以下方式建立连接: ```python graph = Graph("bolt://localhost:7687", auth=("username", "password")) ``` 这里的 `"bolt://localhost:7687"` 是默认的 Bolt 协议地址端口,而 `auth` 参数用于提供用户名密码认证信息。 #### 创建单个节点 可以使用 `Node` 类来定义并创建新节点。例如,要创建一个名为 “Person” 的标签节点,并为其设置属性: ```python alice = Node("Person", name="Alice", age=30) graph.create(alice) ``` 上述代码中,“Person” 表示该节点所属的标签,`name="Alice"` `age=30` 则表示附加于该节点上的键值对属性[^2]。 #### 批量创建多个节点 如果需要一次性创建多个节点,则可通过列表推导式或其他循环结构实现批量处理。例如: ```python people = [ Node("Person", name="Bob", age=25), Node("Person", name="Charlie", age=35) ] for person in people: graph.create(person) ``` 此部分逻辑同样适用于更复杂的场景下数据集的大规模加载需求。 #### 验证节点是否存在 完成节点创建之后,可执行查询语句验证其是否成功写入数据库。比如检索所有具有特定标签或满足某些条件的记录: ```cypher MATCH (n:Person) RETURN n; ``` 以上 Cypher 查询会返回当前图谱中的全部 Person 节点及其详情。 --- ### 注意事项 - 如果遇到连接失败的情况,请参照已知问题说明尝试两次重新链接至目标实例。 - 对于高级功能如调用 GDS 图形科学算法前需先转换成专用格式对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值