diff options
author | Péter Szilágyi <peterke@gmail.com> | 2015-05-25 20:04:05 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2015-05-27 05:30:40 +0800 |
commit | 64174f196feb1b7ad58eed329ef5cdbebce9834c (patch) | |
tree | 821dac1c126b150cd902c082d23d37be4957e1af /p2p/discover/database.go | |
parent | 6a674ffea506aeb9962bb22bc0dbe0d5df72043b (diff) | |
download | go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.gz go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.bz2 go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.lz go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.xz go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.tar.zst go-tangerine-64174f196feb1b7ad58eed329ef5cdbebce9834c.zip |
p2p/discover: add support for counting findnode failures
Diffstat (limited to 'p2p/discover/database.go')
-rw-r--r-- | p2p/discover/database.go | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/p2p/discover/database.go b/p2p/discover/database.go index 3a3f1254b..1b73c3dea 100644 --- a/p2p/discover/database.go +++ b/p2p/discover/database.go @@ -44,9 +44,10 @@ var ( nodeDBVersionKey = []byte("version") // Version of the database to flush if changes nodeDBItemPrefix = []byte("n:") // Identifier to prefix node entries with - nodeDBDiscoverRoot = ":discover" - nodeDBDiscoverPing = nodeDBDiscoverRoot + ":lastping" - nodeDBDiscoverPong = nodeDBDiscoverRoot + ":lastpong" + nodeDBDiscoverRoot = ":discover" + nodeDBDiscoverPing = nodeDBDiscoverRoot + ":lastping" + nodeDBDiscoverPong = nodeDBDiscoverRoot + ":lastpong" + nodeDBDiscoverFindFails = nodeDBDiscoverRoot + ":findfail" ) // newNodeDB creates a new node database for storing and retrieving infos about @@ -275,6 +276,16 @@ func (db *nodeDB) updateLastPong(id NodeID, instance time.Time) error { return db.storeInt64(makeKey(id, nodeDBDiscoverPong), instance.Unix()) } +// findFails retrieves the number of findnode failures since bonding. +func (db *nodeDB) findFails(id NodeID) int { + return int(db.fetchInt64(makeKey(id, nodeDBDiscoverFindFails))) +} + +// updateFindFails updates the number of findnode failures since bonding. +func (db *nodeDB) updateFindFails(id NodeID, fails int) error { + return db.storeInt64(makeKey(id, nodeDBDiscoverFindFails), int64(fails)) +} + // querySeeds retrieves a batch of nodes to be used as potential seed servers // during bootstrapping the node into the network. // |