Documentation ¶
Index ¶
- Variables
- func DistCmp(target, a, b ID) int
- func LogDist(a, b ID) int
- func SignV4(r *enr.Record, privkey *ecdsa.PrivateKey) error
- type DB
- func (db *DB) Close()
- func (db *DB) DeleteNode(id ID)
- func (db *DB) FindFails(id ID, ip net.IP) int
- func (db *DB) FindFailsV5(id ID, ip net.IP) int
- func (db *DB) LastPingReceived(id ID, ip net.IP) time.Time
- func (db *DB) LastPongReceived(id ID, ip net.IP) time.Time
- func (db *DB) Node(id ID) *Node
- func (db *DB) NodeSeq(id ID) uint64
- func (db *DB) QuerySeeds(n int, maxAge time.Duration) []*Node
- func (db *DB) Resolve(n *Node) *Node
- func (db *DB) UpdateFindFails(id ID, ip net.IP, fails int) error
- func (db *DB) UpdateFindFailsV5(id ID, ip net.IP, fails int) error
- func (db *DB) UpdateLastPingReceived(id ID, ip net.IP, instance time.Time) error
- func (db *DB) UpdateLastPongReceived(id ID, ip net.IP, instance time.Time) error
- func (db *DB) UpdateNode(node *Node) error
- type FairMix
- type ID
- type Iterator
- type LocalNode
- func (ln *LocalNode) Database() *DB
- func (ln *LocalNode) Delete(e enr.Entry)
- func (ln *LocalNode) ID() ID
- func (ln *LocalNode) Node() *Node
- func (ln *LocalNode) Seq() uint64
- func (ln *LocalNode) Set(e enr.Entry)
- func (ln *LocalNode) SetFallbackIP(ip net.IP)
- func (ln *LocalNode) SetFallbackUDP(port int)
- func (ln *LocalNode) SetStaticIP(ip net.IP)
- func (ln *LocalNode) UDPContact(toaddr *net.UDPAddr)
- func (ln *LocalNode) UDPEndpointStatement(fromaddr, endpoint *net.UDPAddr)
- type Node
- func MustParse(rawurl string) *Node
- func MustParseV4(rawurl string) *Node
- func New(validSchemes enr.IdentityScheme, r *enr.Record) (*Node, error)
- func NewV4(pubkey *ecdsa.PublicKey, ip net.IP, tcp, udp int) *Node
- func Parse(validSchemes enr.IdentityScheme, input string) (*Node, error)
- func ParseV4(rawurl string) (*Node, error)
- func ReadNodes(it Iterator, n int) []*Node
- func SignNull(r *enr.Record, id ID) *Node
- func (n *Node) ID() ID
- func (n *Node) IP() net.IP
- func (n *Node) Incomplete() bool
- func (n *Node) Load(k enr.Entry) error
- func (n *Node) MarshalText() ([]byte, error)
- func (n *Node) Pubkey() *ecdsa.PublicKey
- func (n *Node) Record() *enr.Record
- func (n *Node) Seq() uint64
- func (n *Node) String() string
- func (n *Node) TCP() int
- func (n *Node) UDP() int
- func (n *Node) URLv4() string
- func (n *Node) UnmarshalText(text []byte) error
- func (n *Node) ValidateComplete() error
- type NullID
- type Secp256k1
- type V4ID
Constants ¶
This section is empty.
Variables ¶
var ValidSchemes = enr.SchemeMap{ "v4": V4ID{}, }
List of known secure identity schemes. 当前正常使用的所有节点标识模型
var ValidSchemesForTesting = enr.SchemeMap{ "v4": V4ID{}, "null": NullID{}, }
正常使用的以及用于测试的节点标识模型
Functions ¶
func DistCmp ¶
DistCmp compares the distances a->target and b->target. Returns -1 if a is closer to target, 1 if b is closer to target and 0 if they are equal. 比较节点间的距离 返回-1,a与target更近 返回1,b与target更近 返回0, a与b和target一样近
Types ¶
type DB ¶
type DB struct {
// contains filtered or unexported fields
}
DB is the node database, storing previously seen nodes and any collected metadata about them for QoS purposes.
func OpenDB ¶
OpenDB opens a node database for storing and retrieving infos about known peers in the network. If no path is given an in-memory, temporary database is constructed. 创建一个储存节点的数据库对象 path为空代表创建内存数据库,否则根据路径创建持久数据库
func (*DB) DeleteNode ¶
DeleteNode deletes all information associated with a node. 删除数据库所有和这个节点有关的信息
func (*DB) FindFails ¶
FindFails retrieves the number of findnode failures since bonding. 获取指定节点findfail的次数
func (*DB) FindFailsV5 ¶
FindFailsV5 retrieves the discv5 findnode failure counter. 获取指定节点findfail的次数(v5版本)
func (*DB) LastPingReceived ¶
LastPingReceived retrieves the time of the last ping packet received from a remote node. 获取指定节点的lastping时间 也就是上次接收到来自这个节点ping包的时间
func (*DB) LastPongReceived ¶
LastPongReceived retrieves the time of the last successful pong from remote node. 获取指定节点lastpong的时间 调用过LastPongReceived后,就会在后台启动删除过期节点的协程 过期节点就是超过一小时没有收到pong包的节点
func (*DB) NodeSeq ¶
NodeSeq returns the stored record sequence number of the given node. 获取指定节点的seq
func (*DB) QuerySeeds ¶
QuerySeeds retrieves random nodes to be used as potential seed nodes for bootstrapping. 从数据库中随机出来最多n个节点 随机出来的节点距离上次响应时间都不超过maxAge 这个函数用于启动的时候获取初始的节点
func (*DB) Resolve ¶
Resolve returns the stored record of the node if it has a larger sequence number than n. 输入一个Node对象,判断输入的对象和数据库中哪个seq更大,返回seq更大的结果
func (*DB) UpdateFindFails ¶
UpdateFindFails updates the number of findnode failures since bonding. 更新指定节点findfail的次数
func (*DB) UpdateFindFailsV5 ¶
UpdateFindFailsV5 stores the discv5 findnode failure counter. 更新指定节点findfail的次数(V5版本)
func (*DB) UpdateLastPingReceived ¶
UpdateLastPingReceived updates the last time we tried contacting a remote node. 更新指定节点的lastping时间 更新上次接收到来自这个节点ping包的时间为指定的时间
func (*DB) UpdateLastPongReceived ¶
UpdateLastPongReceived updates the last pong time of a node. 更新指定节点lastpong的时间
func (*DB) UpdateNode ¶
UpdateNode inserts - potentially overwriting - a node into the peer database. 将输入的节点保存到数据库中 输入的节点的Seq要大于数据库中存在的 每个节点在数据库中占用两个字段
nodeKey(node.ID())用来保存节点的rlp编码 nodeItemKey(node.ID(),zeroIP,dbNodeSeq)保存节点的Seq
type FairMix ¶
type FairMix struct {
// contains filtered or unexported fields
}
FairMix aggregates multiple node iterators. The mixer itself is an iterator which ends only when Close is called. Source iterators added via AddSource are removed from the mix when they end.
The distribution of nodes returned by Next is approximately fair, i.e. FairMix attempts to draw from all sources equally often. However, if a certain source is slow and doesn't return a node within the configured timeout, a node from any other source will be returned.
It's safe to call AddSource and Close concurrently with Next. 可以以公平的方式从多个来源迭代节点
func NewFairMix ¶
NewFairMix creates a mixer.
The timeout specifies how long the mixer will wait for the next fairly-chosen source before giving up and taking a node from any other source. A good way to set the timeout is deciding how long you'd want to wait for a node on average. Passing a negative timeout makes the mixer completely fair. 创建一个FairMix迭代器,用来从多个来源平均的迭代节点 输入的时间表示等待一个来源返回节点的超时时间
func (*FairMix) AddSource ¶
AddSource adds a source of nodes. AddSource就是在FairMix.sources数组中添加一项,并且启动这个来源的协程
func (*FairMix) Close ¶
func (m *FairMix) Close()
Close shuts down the mixer and all current sources. Calling this is required to release resources associated with the mixer.
type ID ¶
type ID [32]byte
ID is a unique identifier for each node. ID是每个节点的唯一标识,本质是长度32字节的字节数组
func HexID ¶
HexID converts a hex string to an ID. The string may be prefixed with 0x. It panics if the string is not a valid ID. 将hex字符串解析为ID,格式错误将会panic hex字符串有无0x前缀皆可
func PubkeyToIDV4 ¶
PubkeyToIDV4 derives the v4 node address from the given public key. 将公钥转换成节点ID 计算方法: keccak256(pub.X || pub.Y)
func (ID) MarshalText ¶
MarshalText implements the encoding.TextMarshaler interface.
func (ID) TerminalString ¶
TerminalString returns a shortened hex string for terminal logging.
func (*ID) UnmarshalText ¶
UnmarshalText implements the encoding.TextUnmarshaler interface. 从hex字符串转化成enode.ID对象,text是hex字符串的字节数组
type Iterator ¶
type Iterator interface { Next() bool // moves to next node Node() *Node // returns current node Close() // ends the iterator }
Iterator represents a sequence of nodes. The Next method moves to the next node in the sequence. It returns false when the sequence has ended or the iterator is closed. Close may be called concurrently with Next and Node, and interrupts Next if it is blocked. 节点的迭代器对象,包含Next,Node,Close方法 这个文件实现了sliceIter,filterIter,FairMix
func CycleNodes ¶
CycleNodes makes an iterator which cycles through the given nodes indefinitely. 生成一个在输入的这些节点中遍历的迭代器,迭代到结尾就重新从头开始,可以无限迭代
type LocalNode ¶
type LocalNode struct {
// contains filtered or unexported fields
}
LocalNode produces the signed node record of a local node, i.e. a node run in the current process. Setting ENR entries via the Set method updates the record. A new version of the record is signed on demand when the Node method is called. LocalNode对象用于生成本地节点经过签名的Record对象
func NewLocalNode ¶
func NewLocalNode(db *DB, key *ecdsa.PrivateKey) *LocalNode
NewLocalNode creates a local node. 创建一个本地节点,指定节点数据库和本地节点的私钥
func (*LocalNode) Database ¶
Database returns the node database associated with the local node. 获取本地节点使用的数据库
func (*LocalNode) Delete ¶
Delete removes the given entry from the local record. 从LocalNode.entries删除一项,同样删除后也需要重新签名
func (*LocalNode) Set ¶
Set puts the given entry into the local record, overwriting any existing value. Use Set*IP and SetFallbackUDP to set IP addresses and UDP port, otherwise they'll be overwritten by the endpoint predictor.
Since node record updates are throttled to one per second, Set is asynchronous. Any update will be queued up and published when at least one second passes from the last change. 往LocalNode.entries字段一条 ENRKey->Entry 的映射 并且添加后使得缓存的cur失效,因为增加了新的键值对要重新签名
func (*LocalNode) SetFallbackIP ¶
SetFallbackIP sets the last-resort IP address. This address is used if no endpoint prediction can be made and no static IP is set. 设置LocalNode.endpoint4或LocalNode.endpoint6 的fallbackIP字段 fallbackIP是没有预测结果而且静态ip也没有设置的最终结果
func (*LocalNode) SetFallbackUDP ¶
SetFallbackUDP sets the last-resort UDP-on-IPv4 port. This port is used if no endpoint prediction can be made. 设置ln.endpoint4和ln.endpoint6的fallbackUDP字段
func (*LocalNode) SetStaticIP ¶
SetStaticIP sets the local IP to the given one unconditionally. This disables endpoint prediction. 设置LocalNode的staticIP字段
func (*LocalNode) UDPContact ¶
UDPContact should be called whenever the local node has announced itself to another node via UDP. It feeds the local endpoint predictor. 一旦本地向其他节点发送Ping包,就调用AddContact往IPTracker里面添加
func (*LocalNode) UDPEndpointStatement ¶
UDPEndpointStatement should be called whenever a statement about the local node's UDP endpoint is received. It feeds the local endpoint predictor. fromaddr代表其他节点的地址,endpoint代表fromaddr认为本地的地址 一旦获得了别的节点认为本地节点的地址的信息就调用此方法 v4版本节点发现收到ping和pong都会调用 v5版本节点发现收到pong包会调用
type Node ¶
type Node struct {
// contains filtered or unexported fields
}
Node represents a host on the network.
func MustParseV4 ¶
MustParseV4 parses a node URL. It panics if the URL is not valid.
func New ¶
New wraps a node record. The record must be valid according to the given identity scheme. 新建一个Node对象, node.id就是IdentityScheme.NodeAddr的返回值 输入的Record必须满足给定的scheme
func NewV4 ¶
NewV4 creates a node from discovery v4 node information. The record contained in the node has a zero-length signature. 创建一个v4版本的节点对象 需要提供节点的公钥,ip,tcp和udp端口
func Parse ¶
func Parse(validSchemes enr.IdentityScheme, input string) (*Node, error)
Parse decodes and verifies a base64-encoded node record. 解析节点链接 输入的格式可能是:
enode://xxx enr:xxx
创建两种类型的节点真实函数是New和NewV4 分别用来创建enr类型和enode类型
func ParseV4 ¶
ParseV4 parses a node URL.
There are two basic forms of node URLs:
- incomplete nodes, which only have the public key (node ID)
- complete nodes, which contain the public key and IP/Port information
For incomplete nodes, the designator must look like one of these
enode://<hex node id> <hex node id>
For complete nodes, the node ID is encoded in the username portion of the URL, separated from the host by an @ sign. The hostname can only be given as an IP address or using DNS domain name. The port in the host name section is the TCP listening port. If the TCP and UDP (discovery) ports differ, the UDP port is specified as query parameter "discport".
In the following example, the node URL describes a node with IP address 10.3.58.6, TCP listening port 30303 and UDP discovery port 30301.
enode://<hex node id>@10.3.58.6:30303?discport=30301
解析V4版本的链接,有两种类型,不完整版和完整版 不完整版的格式如下
enode://<hex node id> <hex node id>
完整版的格式包括了ip以及端口号,例如
enode://<hex node id>@10.3.58.6:30303?discport=30301
func ReadNodes ¶
ReadNodes reads at most n nodes from the given iterator. The return value contains no duplicates and no nil values. To prevent looping indefinitely for small repeating node sequences, this function calls Next at most n times. 从迭代器中读取n个节点,并对结果进行去重,读取过程中迭代器到底直接返回
func (*Node) Incomplete ¶
Incomplete returns true for nodes with no IP address. 如果节点没有ip地址这个就返回true
func (*Node) MarshalText ¶
MarshalText implements encoding.TextMarshaler.
func (*Node) Record ¶
Record returns the node's record. The return value is a copy and may be modified by the caller.
func (*Node) UnmarshalText ¶
UnmarshalText implements encoding.TextUnmarshaler.
func (*Node) ValidateComplete ¶
ValidateComplete checks whether n has a valid IP and UDP port. Deprecated: don't use this method. 确保节点保存了ip和udp端口以及节点公钥
type NullID ¶
type NullID struct{}
NullID is the "null" ENR identity scheme. This scheme stores the node ID in the record without any signature. 不进行签名,节点的地址就是SignNull传入的id
type Secp256k1 ¶
Secp256k1 is the "secp256k1" key, which holds a public key. 代表键值对中的公钥键值对 公钥在记录中是以压缩格式保存