兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx

兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx

ID:27453267

大小:30.94 KB

页数:14页

时间:2018-12-03

兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx_第1页
兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx_第2页
兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx_第3页
兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx_第4页
兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx_第5页
资源描述:

《兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析.docx》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、兄弟连Go语言+区块链技术培训以太坊源码分析(32)eth-downloader-peer源码分析queue给downloader提供了调度功能和限流的功能。通过调用Schedule/ScheduleSkeleton来申请对任务进行调度,然后调用ReserveXXX方法来领取调度完成的任务,并在downloader里面的线程来执行,调用DeliverXXX方法把下载完的数据给queue。最后通过WaitResults来获取已经完成的任务。中间还有一些对任务的额外控制,ExpireXXX用来控制任务是

2、否超时,CancelXXX用来取消任务。##Schedule方法Schedule调用申请对一些区块头进行下载调度。可以看到做了一些合法性检查之后,把任务插入了blockTaskPool,receiptTaskPool,receiptTaskQueue,receiptTaskPool。TaskPool是Map,用来记录header的hash是否存在。TaskQueue是优先级队列,优先级是区块的高度的负数,这样区块高度越小的优先级越高,就实现了首先调度小的任务的功能。        //Schedul

3、eaddsasetofheadersforthedownloadqueueforscheduling,returning    //thenewheadersencountered.    //from表示headers里面第一个元素的区块高度。返回值返回了所有被接收的header    func(q*queue)Schedule(headers[]*types.Header,fromuint64)[]*types.Header{        q.lock.Lock()        deferq

4、.lock.Unlock()            //Insertalltheheadersprioritisedbythecontainedblocknumber        inserts:=make([]*types.Header,0,len(headers))        for_,header:=rangeheaders{            //Makesurechainorderishonouredandpreservedthroughout            hash:=

5、header.Hash()            ifheader.Number==nil

6、

7、header.Number.Uint64()!=from{                log.Warn("Headerbrokechainordering","number",header.Number,"hash",hash,"expected",from)                break            }            //headerHead存储了最后一个插入的区块头,检

8、查当前区块是否正确的链接。            ifq.headerHead!=(common.Hash{})&&q.headerHead!=header.ParentHash{                log.Warn("Headerbrokechainancestry","number",header.Number,"hash",hash)                break            }            //Makesurenoduplicaterequests

9、areexecuted            //检查重复,这里直接continue了,那不是from对不上了。            if_,ok:=q.blockTaskPool[hash];ok{                log.Warn("Headeralreadyscheduledforblockfetch","number",header.Number,"hash",hash)                continue            }            if_,

10、ok:=q.receiptTaskPool[hash];ok{                log.Warn("Headeralreadyscheduledforreceiptfetch","number",header.Number,"hash",hash)                continue            }            //Queuetheheaderforcontentretrieval            q.blockTa

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。