github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/rpc/client_example_test.go (about)

     1  
     2  //此源码被清华学神尹成大魔王专业翻译分析并修改
     3  //尹成QQ77025077
     4  //尹成微信18510341407
     5  //尹成所在QQ群721929980
     6  //尹成邮箱 yinc13@mails.tsinghua.edu.cn
     7  //尹成毕业于清华大学,微软区块链领域全球最有价值专家
     8  //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620
     9  //版权所有2016 Go Ethereum作者
    10  //此文件是Go以太坊库的一部分。
    11  //
    12  //Go-Ethereum库是免费软件:您可以重新分发它和/或修改
    13  //根据GNU发布的较低通用公共许可证的条款
    14  //自由软件基金会,或者许可证的第3版,或者
    15  //(由您选择)任何更高版本。
    16  //
    17  //Go以太坊图书馆的发行目的是希望它会有用,
    18  //但没有任何保证;甚至没有
    19  //适销性或特定用途的适用性。见
    20  //GNU较低的通用公共许可证,了解更多详细信息。
    21  //
    22  //你应该收到一份GNU较低级别的公共许可证副本
    23  //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。
    24  
    25  package rpc_test
    26  
    27  import (
    28  	"context"
    29  	"fmt"
    30  	"math/big"
    31  	"time"
    32  
    33  	"github.com/ethereum/go-ethereum/rpc"
    34  )
    35  
    36  //在这个例子中,我们的客户希望跟踪最新的“块号”
    37  //服务器已知。服务器支持两种方法:
    38  //
    39  //eth_getBlockByNumber(“最新”,)
    40  //返回最新的块对象。
    41  //
    42  //ETH订阅(“newblocks”)
    43  //创建在新块到达时激发块对象的订阅。
    44  
    45  type Block struct {
    46  	Number *big.Int
    47  }
    48  
    49  func ExampleClientSubscription() {
    50  //连接客户端。
    51  client, _ := rpc.Dial("ws://127.0.0.1:8485“)
    52  	subch := make(chan Block)
    53  
    54  //确保Subch接收到最新的块。
    55  	go func() {
    56  		for i := 0; ; i++ {
    57  			if i > 0 {
    58  				time.Sleep(2 * time.Second)
    59  			}
    60  			subscribeBlocks(client, subch)
    61  		}
    62  	}()
    63  
    64  //到达时打印订阅中的事件。
    65  	for block := range subch {
    66  		fmt.Println("latest block:", block.Number)
    67  	}
    68  }
    69  
    70  //subscribeBlocks在自己的goroutine中运行并维护
    71  //新块的订阅。
    72  func subscribeBlocks(client *rpc.Client, subch chan Block) {
    73  	ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
    74  	defer cancel()
    75  
    76  //订阅新块。
    77  	sub, err := client.EthSubscribe(ctx, subch, "newHeads")
    78  	if err != nil {
    79  		fmt.Println("subscribe error:", err)
    80  		return
    81  	}
    82  
    83  //现在已建立连接。
    84  //用当前块更新频道。
    85  	var lastBlock Block
    86  	if err := client.CallContext(ctx, &lastBlock, "eth_getBlockByNumber", "latest"); err != nil {
    87  		fmt.Println("can't get latest block:", err)
    88  		return
    89  	}
    90  	subch <- lastBlock
    91  
    92  //订阅将向通道传递事件。等待
    93  //订阅以任何原因结束,然后循环重新建立
    94  //连接。
    95  	fmt.Println("connection lost: ", <-sub.Err())
    96  }