以太坊rpc接口调用之nonce

背景

我们在使用以太坊相关的json-rpc借口发送交易时,往往会出现这种现象:交易已经发送出去,也获得了交易的hash值。dev模式的geth也在正常挖矿,可是问题是交易却迟迟未被确认。会发生此种类型的接口如:

eth_sendTransaction
eth_sendRawTransaction

那么是什么原因导致此问题呢?今天就带大家了解一些导致此问题的原因。

问题追踪

除了上面的表象问题,我们还可以进步查询相应的问题信息。 (1)发生上面问题的情况往往是通过json api调用或其他通过rpc调用的方式,如果直接使用控制台(console)的命令来执行,是会被很快确认的。 (2)通过eth_getTransaction,命令我们会查询到上面的交易,但是交易的blocknumber使用为null; (3)通过txpool.content命名,我们会看到上面的交易处于queued队列中,却迟迟不会被处理。

导致以上现象的最终原因就是在发送交易时传递的nonce值不对。

nonce使用说明

为了防止交易的重播攻击,每笔交易必须有一个nonce随机数,针对每一个账户nonce都是从0开始,当nonce为0的交易处理完之后,才会处理nonce为1的交易,并依次加1的交易才会被处理。以下是nonce使用的几条规则:

  • 当nonce太小,交易会被直接拒绝。
  • 当nonce太大,交易会一直处于队列之中,这也就是导致我们上面描述的问题的原因;
  • 当发送一个比较大的nonce值,然后补齐开始nonce到那个值之间的nonce,那么交易依旧可以被执行。
  • 当交易处于queue中时停止geth客户端,那么交易queue中的交易会被清除掉。

了解了上面的内容,大家就可以去排查自己的交易是否是因为此原因导致未成功发送了。

后语

如有问题可以留言或私下联系。QQ技术交流群:659809063。Geth客户端API接口封装和智能合约调用的JAVA版本正在编写完善,有需要的朋友也可以联系。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏腾讯大数据的专栏

全民拥抱Docker云--Lhotse系统经验分享

前言 “只要站在风口,猪也能飞起来”,这碗心灵鸡汤不知道激励了多少英雄豪杰踏上寻风口之路。而现如今,Docker这阵龙卷风呼啸来袭,更让众人生起迎风而上、直冲云...

2079
来自专栏Java架构

微服务设计模式之断路器

25010
来自专栏数字

区块链生态圈应用落地须了解区块链共识技术开发

区块链在网络应用过程中,衍生出了很多的产品出来,从最开始的数字资产币种,到后面的交易所,再衍生出其他的产品,包括现在要打造的链的生态圈,其实都离不开区块链技术核...

1784
来自专栏区块链大本营

【技术贴】从拜占庭问题,谈区块链技术实现及政务应用

36910
来自专栏技术翻译

理解分布式系统的8个谬误

你在分布式系统上工作吗?微服务,Web API,SOA,Web服务器,应用服务器,数据库服务器,缓存服务器,负载均衡器 - 如果这些描述了系统设计中的组件,那么...

582
来自专栏BeJavaGod

网站平台架构演变史(三) - 数据库表的查询优化

上篇说道了数据库读写分离,对于大型网站来说这么说是十分有必要的。数据库在整个互联网架构中担当的角色无法有两个,存储和运算,很多时候这两个是并存的,但是在后期,对...

3617
来自专栏Linyb极客之路

区块链中的分布式模式

823
来自专栏华仔的技术笔记

EOS与ETH体系结构比较

3558
来自专栏程序人生

区块链和数据库:致虚极,守静笃

如果说牛顿的经典物理是爱因斯坦相对论在低速环境下的一种体现的话,我们所熟知的数据库技术,可以认为是区块链技术在弱分布式环境下的一个特例。

574
来自专栏腾讯云区块链

智能合约简介

在Fabric中,chaincode(链码)也称为智能合约,是用高级语言编写的一段代码。代码主要是读取和操作账本上的数据。 智能合约是一座连接用户应用和Fabr...

670

扫码关注云+社区