-
Notifications
You must be signed in to change notification settings - Fork 75
/
metrics.go
120 lines (108 loc) · 5.56 KB
/
metrics.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
//此源码被清华学神尹成大魔王专业翻译分析并修改
//尹成QQ77025077
//尹成微信18510341407
//尹成所在QQ群721929980
//尹成邮箱 yinc13@mails.tsinghua.edu.cn
//尹成毕业于清华大学,微软区块链领域全球最有价值专家
//https://mvp.microsoft.com/zh-cn/PublicProfile/4033620
//版权所有2016 Go Ethereum作者
//此文件是Go以太坊库的一部分。
//
//Go-Ethereum库是免费软件:您可以重新分发它和/或修改
//根据GNU发布的较低通用公共许可证的条款
//自由软件基金会,或者许可证的第3版,或者
//(由您选择)任何更高版本。
//
//Go以太坊图书馆的发行目的是希望它会有用,
//但没有任何保证;甚至没有
//适销性或特定用途的适用性。见
//GNU较低的通用公共许可证,了解更多详细信息。
//
//你应该收到一份GNU较低级别的公共许可证副本
//以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。
package les
import (
"github.com/ethereum/go-ethereum/metrics"
"github.com/ethereum/go-ethereum/p2p"
)
var (
/*proptxninpacketsmeter=metrics.newmeter(“eth/prop/txns/in/packets”)。
proptxninttrafficmeter=metrics.newmeter(“eth/prop/txns/in/traffic”)。
proptxnoutpacketsmeter=metrics.newmeter(“eth/prop/txns/out/packets”)。
NewMeter(“ETH/PROP/TXNS/OUT /流量”)
propashinpacketsmeter=metrics.newmeter(“eth/prop/hashes/in/packets”)。
NewMeter(“ET/PROP/散列/IN /流量”)
propashoutpacketsmeter=metrics.newmeter(“eth/prop/hashes/out/packets”)。
propashouttrafficmeter=metrics.newmeter(“eth/prop/hashes/out/traffic”)。
propblockinpacketsmeter=metrics.newmeter(“eth/prop/blocks/in/packets”)。
PropBlockIntraffimeter=metrics.newmeter(“eth/prop/blocks/in/traffic”)。
propblockoutpacketsmeter=metrics.newmeter(“eth/prop/blocks/out/packets”)。
PropBlockOutTrafficMeter=metrics.newMeter(“eth/prop/blocks/out/traffic”)。
reqhashinpacketsmeter=metrics.newmeter(“eth/req/hashes/in/packets”)。
reqhashIntraffimeter=metrics.newmeter(“eth/req/hashes/in/traffic”)。
reqhashoutpacketsmeter=metrics.newmeter(“eth/req/hashes/out/packets”)。
reqhashouttrafficmeter=metrics.newmeter(“eth/req/hashes/out/traffic”)。
reqblockinpacketsmeter=metrics.newmeter(“eth/req/blocks/in/packets”)。
reqBlockIntraffimeter=metrics.newmeter(“eth/req/blocks/in/traffic”)。
reqblockoutpacketsmeter=metrics.newmeter(“eth/req/blocks/out/packets”)。
reqblockouttrafficmeter=metrics.newmeter(“eth/req/blocks/out/traffic”)。
reqHeaderInpacketsMeter=metrics.newMeter(“eth/req/headers/in/packets”)。
reqheaderIntrafficemeter=metrics.newmeter(“eth/req/headers/in/traffic”)。
reqHeaderOutPacketsMeter=metrics.newMeter(“eth/req/headers/out/packets”)。
reqHeaderOutTrafficMeter=metrics.newMeter(“eth/req/headers/out/traffic”)。
reqbodyinpacketsmeter=metrics.newmeter(“eth/req/bodies/in/packets”)。
reqbodyIntraffimeter=metrics.newmeter(“eth/req/bodies/in/traffic”)。
reqbodyoutpacketsmeter=metrics.newmeter(“eth/req/body/out/packets”)。
reqbodyouttrafficmeter=metrics.newmeter(“eth/req/bodys/out/traffic”)。
reqstateinpacketsmeter=metrics.newmeter(“eth/req/states/in/packets”)。
reqstateIntraffimeter=metrics.newmeter(“eth/req/states/in/traffic”)。
reqstateoutpacketsmeter=metrics.newmeter(“eth/req/states/out/packets”)。
reqstateouttrafficmeter=metrics.newmeter(“eth/req/states/out/traffic”)。
reqReceiptInPacketsMeter=metrics.newMeter(“eth/req/receipts/in/packets”)。
reqReceiptInterffimeter=metrics.newmeter(“eth/req/receipts/in/traffic”)。
reqReceiptOutPacketsMeter=metrics.newMeter(“eth/req/receipts/out/packets”)。
reqReceiptOutTrafficMeter=metrics.newMeter(“eth/req/receipts/out/traffic”*/
miscInPacketsMeter = metrics.NewRegisteredMeter("les/misc/in/packets", nil)
miscInTrafficMeter = metrics.NewRegisteredMeter("les/misc/in/traffic", nil)
miscOutPacketsMeter = metrics.NewRegisteredMeter("les/misc/out/packets", nil)
miscOutTrafficMeter = metrics.NewRegisteredMeter("les/misc/out/traffic", nil)
)
//meteredmsgreadwriter是p2p.msgreadwriter的包装器,能够
//基于数据流内容累积上述定义的度量。
type meteredMsgReadWriter struct {
p2p.MsgReadWriter //将消息流打包到仪表
version int //选择正确仪表的协议版本
}
//newmeteredmsgwriter使用计量支持包装p2p msgreadwriter。如果
//度量系统被禁用,此函数返回原始对象。
func newMeteredMsgWriter(rw p2p.MsgReadWriter) p2p.MsgReadWriter {
if !metrics.Enabled {
return rw
}
return &meteredMsgReadWriter{MsgReadWriter: rw}
}
//init设置流使用的协议版本,以知道要
//协议版本之间的消息ID重叠时递增。
func (rw *meteredMsgReadWriter) Init(version int) {
rw.version = version
}
func (rw *meteredMsgReadWriter) ReadMsg() (p2p.Msg, error) {
//读取信息,并在出现错误时短路
msg, err := rw.MsgReadWriter.ReadMsg()
if err != nil {
return msg, err
}
//计算数据流量
packets, traffic := miscInPacketsMeter, miscInTrafficMeter
packets.Mark(1)
traffic.Mark(int64(msg.Size))
return msg, err
}
func (rw *meteredMsgReadWriter) WriteMsg(msg p2p.Msg) error {
//计算数据流量
packets, traffic := miscOutPacketsMeter, miscOutTrafficMeter
packets.Mark(1)
traffic.Mark(int64(msg.Size))
//将数据包发送到P2P层
return rw.MsgReadWriter.WriteMsg(msg)
}