Commit Graph

386 Commits

Author SHA1 Message Date
vyzo
28b1a9f31d don't track segment sizes, it's a fruitless optimization 2019-05-17 23:39:21 +03:00
vyzo
afca355218 index the peer ID strings directly to avoid copying the byte slice 2019-05-17 23:36:46 +03:00
vyzo
d340d2983e cosmetics 2019-05-17 13:14:39 +03:00
vyzo
3140aaa2c3 implement protobook for pstoreds 2019-05-17 13:13:18 +03:00
vyzo
a9e3f07759 global interned protocol table 2019-05-17 12:47:07 +03:00
vyzo
5ed17f0b79 embed lock in segment 2019-05-17 12:37:46 +03:00
vyzo
08caa87351 refactor protocol functionality into ProtoBook 2019-05-17 12:33:33 +03:00
vyzo
ea23986270 segmented protocol info 2019-05-09 12:14:03 +03:00
vyzo
303b1b6207 update segment size on gc 2019-05-09 11:20:12 +03:00
Raúl Kripalani
e7e511ba99 segment the memory peerstore; granular locks. 2019-05-09 00:27:58 +01:00
Steven Allen
96639ef5f4
Merge pull request #76 from libp2p/fix/issue-75
don't delete under the read lock
2019-04-28 12:28:17 -07:00
vyzo
f21f6eac4f don't eager gc 2019-04-28 16:21:07 +03:00
vyzo
c58ce1f56f add Close method to memory address book, which cancels the gc process 2019-04-28 12:19:26 +03:00
vyzo
e4cf50160f periodically schedule gc 2019-04-28 12:17:48 +03:00
vyzo
d0a3cc17f4 don't delete under the read lock
let gc clean up the addrs
2019-04-28 11:35:23 +03:00
Steven Allen
3291020401
Merge pull request #74 from libp2p/feat/rwlock
Read/Write locking
2019-04-27 12:53:42 -07:00
vyzo
3cd491431b read/write metadata lock 2019-04-27 22:19:49 +03:00
vyzo
0ddad15bd2 read/write address book lock 2019-04-27 22:19:39 +03:00
vyzo
af2cb17f80 read/write protocol lock 2019-04-27 22:15:45 +03:00
Steven Allen
b496ee5433
Merge pull request #71 from libp2p/feat/optimize-mem
optimize peerstore memory
2019-04-23 09:41:50 -07:00
Steven Allen
b94490421d peerstore: bump number/size of interned protocol names
512 * 256 (max path length on many systems) = 128KiB
2019-04-23 09:36:39 -07:00
Steven Allen
1017515eca
Merge pull request #72 from libp2p/fix/unmarshal-peer-id
fix unmarshalling of peer IDs
2019-04-23 09:29:43 -07:00
Steven Allen
926321cd88 fix unmarshalling of peer IDs 2019-04-23 00:59:28 -07:00
Steven Allen
b65b48dbe1 intern protocol names
Ideally, we'd store a bitmap. But we'll have to think through how we want that
to play out with the datastore-backed peerstore (maybe move the `*Protocols`
methods down to the backend implementation?).
2019-04-23 00:54:18 -07:00
Steven Allen
aae59b7403 optimize memory of in-memory peerstore 2019-04-23 00:10:05 -07:00
Raúl Kripalani
ab02c26ae9
Merge pull request #70 from libp2p/fix/err-handling
fix error handling in UpdateAddrs: return on error
2019-04-16 22:16:09 +01:00
Raúl Kripalani
662be3b0a4 fix error handling: return on err. 2019-04-16 22:11:14 +01:00
Steven Allen
deb2163a68
Merge pull request #67 from libp2p/fix/keep-temp-addresses
keep temp addresses for 2 minutes
2019-04-12 10:32:51 -07:00
Steven Allen
30a9a2acf4 keep temp addresses for 2 minutes
Unfortunately, services like the DHT are slow enough that we can forget
addresses before we successfully dial.
2019-04-11 21:51:01 -07:00
Raúl Kripalani
eaba0f4384 farewell gx; thanks for serving us well. 2019-04-11 21:11:16 +01:00
Yusef Napora
cfad1e67a3 update readme badges 2019-04-09 11:56:53 -04:00
Matt Joiner
9ae3eaaeb0
Add to comment on KeyBook.PrivKey (#64) 2019-04-08 18:11:34 +10:00
Matt Joiner
d9cfa764ad Implement fmt.Stringer for PeerInfo 2019-03-11 14:16:16 +11:00
Raúl Kripalani
d2a21b6d4a
Merge pull request #61 from libp2p/b32migrate
migrate to multiformats/go-base32
2019-02-28 18:47:45 +00:00
Raúl Kripalani
2c5bc31271 migrate to multiformats/go-base32. 2019-02-28 18:34:51 +00:00
Raúl Kripalani
80f2a8c5e1
add go.mod, update travis 2019-02-28 18:33:05 +00:00
Raúl Kripalani
19a5811ba3 update ipfs deps post-gomodding them. 2019-02-28 17:59:54 +00:00
Raúl Kripalani
5866c85fe6 add go.mod and update travis. 2019-02-28 17:04:29 +00:00
Hector Sanjuan
e2df3e49ea
Merge pull request #59 from libp2p/gx/update-qtg73x
gx publish 2.0.19
2019-02-26 20:19:24 +00:00
Hector Sanjuan
2d1f3d424c gx publish 2.0.19 2019-02-26 19:57:18 +00:00
Hector Sanjuan
672b6e0248
Merge pull request #57 from libp2p/gx/update-az3v0j
gx publish 2.0.18
2019-02-26 17:40:31 +00:00
Hector Sanjuan
4d8a43fb57 gx publish 2.0.18 2019-02-26 16:48:25 +00:00
Raúl Kripalani
c123410c64
Merge pull request #47 from raulk/feat/pstore-ds-gc
pstoreds: migrate from strict TTL to GC-based expiry.
2019-02-22 14:43:47 +00:00
Raúl Kripalani
8db09c59cf pstore.Close(): return errors from children. 2019-02-22 14:39:51 +00:00
Raúl Kripalani
4806c742b5 pstoreds: remove dirty flag when deleting from db. 2019-02-21 19:31:19 +00:00
Raúl Kripalani
87fab3950d pstoreds: switch protobuf compilation to gogofaster. 2019-02-19 17:41:14 +00:00
Raúl Kripalani
c5e3e4d647 Merge branch 'master' into feat/pstore-ds-gc 2019-02-19 11:51:28 +00:00
Raúl Kripalani
135471f291 add io.Closer interface and implementation to Peerstore. 2019-02-19 11:45:32 +00:00
Jakub Sztandera
985bc5953b gx publish 2.0.17 2019-02-18 18:45:40 +01:00
Raúl Kripalani
4e7d772db3 pstoreds: remove async flushing on read: now sync. 2019-02-18 16:35:48 +00:00