mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-24 15:38:27 +00:00
More memory efficient index sending
This commit is contained in:
parent
4a87221f16
commit
593f098276
@ -77,7 +77,7 @@ type rawConnection struct {
|
|||||||
xw *xdr.Writer
|
xw *xdr.Writer
|
||||||
wmut sync.Mutex
|
wmut sync.Mutex
|
||||||
|
|
||||||
indexSent map[string]map[string][2]int64
|
indexSent map[string]uint64
|
||||||
awaiting []chan asyncResult
|
awaiting []chan asyncResult
|
||||||
imut sync.Mutex
|
imut sync.Mutex
|
||||||
|
|
||||||
@ -117,8 +117,8 @@ func NewConnection(nodeID string, reader io.Reader, writer io.Writer, receiver M
|
|||||||
cw: cw,
|
cw: cw,
|
||||||
wb: wb,
|
wb: wb,
|
||||||
xw: xdr.NewWriter(wb),
|
xw: xdr.NewWriter(wb),
|
||||||
|
indexSent: make(map[string]uint64),
|
||||||
awaiting: make([]chan asyncResult, 0x1000),
|
awaiting: make([]chan asyncResult, 0x1000),
|
||||||
indexSent: make(map[string]map[string][2]int64),
|
|
||||||
outbox: make(chan []encodable),
|
outbox: make(chan []encodable),
|
||||||
nextID: make(chan int),
|
nextID: make(chan int),
|
||||||
closed: make(chan struct{}),
|
closed: make(chan struct{}),
|
||||||
@ -140,26 +140,29 @@ func (c *rawConnection) ID() string {
|
|||||||
func (c *rawConnection) Index(repo string, idx []FileInfo) {
|
func (c *rawConnection) Index(repo string, idx []FileInfo) {
|
||||||
c.imut.Lock()
|
c.imut.Lock()
|
||||||
var msgType int
|
var msgType int
|
||||||
if c.indexSent[repo] == nil {
|
maxSent := c.indexSent[repo]
|
||||||
|
var newMaxSent uint64
|
||||||
|
if maxSent == 0 {
|
||||||
// This is the first time we send an index.
|
// This is the first time we send an index.
|
||||||
msgType = messageTypeIndex
|
msgType = messageTypeIndex
|
||||||
|
|
||||||
c.indexSent[repo] = make(map[string][2]int64)
|
|
||||||
for _, f := range idx {
|
for _, f := range idx {
|
||||||
c.indexSent[repo][f.Name] = [2]int64{f.Modified, int64(f.Version)}
|
if f.Version > newMaxSent {
|
||||||
|
newMaxSent = f.Version
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// We have sent one full index. Only send updates now.
|
// We have sent one full index. Only send updates now.
|
||||||
msgType = messageTypeIndexUpdate
|
msgType = messageTypeIndexUpdate
|
||||||
var diff []FileInfo
|
var diff []FileInfo
|
||||||
for _, f := range idx {
|
for _, f := range idx {
|
||||||
if vs, ok := c.indexSent[repo][f.Name]; !ok || f.Modified != vs[0] || int64(f.Version) != vs[1] {
|
if f.Version > maxSent {
|
||||||
diff = append(diff, f)
|
diff = append(diff, f)
|
||||||
c.indexSent[repo][f.Name] = [2]int64{f.Modified, int64(f.Version)}
|
newMaxSent = f.Version
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
idx = diff
|
idx = diff
|
||||||
}
|
}
|
||||||
|
c.indexSent[repo] = newMaxSent
|
||||||
c.imut.Unlock()
|
c.imut.Unlock()
|
||||||
|
|
||||||
c.send(header{0, -1, msgType}, IndexMessage{repo, idx})
|
c.send(header{0, -1, msgType}, IndexMessage{repo, idx})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user