cmd/geth, eth/downloader: rough guess at the import eta

pull/1224/head
Péter Szilágyi 10 years ago
parent b3d5ce7d48
commit 271fb20ecb
  1. 9
      cmd/geth/admin.go
  2. 15
      eth/downloader/downloader.go

@ -325,8 +325,13 @@ func (js *jsre) setHead(call otto.FunctionCall) otto.Value {
} }
func (js *jsre) syncProgress(call otto.FunctionCall) otto.Value { func (js *jsre) syncProgress(call otto.FunctionCall) otto.Value {
pending, cached, importing := js.ethereum.Downloader().Stats() pending, cached, importing, eta := js.ethereum.Downloader().Stats()
v, _ := call.Otto.ToValue(map[string]interface{}{"pending": pending, "cached": cached, "importing": importing}) v, _ := call.Otto.ToValue(map[string]interface{}{
"pending": pending,
"cached": cached,
"importing": importing,
"estimate": eta.String(),
})
return v return v
} }

@ -79,7 +79,9 @@ type Downloader struct {
banned *set.Set // Set of hashes we've received and banned banned *set.Set // Set of hashes we've received and banned
// Statistics // Statistics
importStart time.Time // Instance when the last blocks were taken from the cache
importQueue []common.Hash // Hashes of the previously taken blocks to check import progress importQueue []common.Hash // Hashes of the previously taken blocks to check import progress
importDone int // Number of taken blocks already imported from the last batch
importLock sync.Mutex importLock sync.Mutex
// Callbacks // Callbacks
@ -126,19 +128,25 @@ func New(mux *event.TypeMux, hasBlock hashCheckFn, getBlock getBlockFn) *Downloa
} }
// Stats retrieves the current status of the downloader. // Stats retrieves the current status of the downloader.
func (d *Downloader) Stats() (pending int, cached int, importing int) { func (d *Downloader) Stats() (pending int, cached int, importing int, estimate time.Duration) {
// Fetch the download status // Fetch the download status
pending, cached = d.queue.Size() pending, cached = d.queue.Size()
// Generate the import status // Figure out the import progress
d.importLock.Lock() d.importLock.Lock()
defer d.importLock.Unlock() defer d.importLock.Unlock()
for len(d.importQueue) > 0 && d.hasBlock(d.importQueue[0]) { for len(d.importQueue) > 0 && d.hasBlock(d.importQueue[0]) {
d.importQueue = d.importQueue[1:] d.importQueue = d.importQueue[1:]
d.importDone++
} }
importing = len(d.importQueue) importing = len(d.importQueue)
// Make an estimate on the total sync
estimate = 0
if d.importDone > 0 {
estimate = time.Since(d.importStart) / time.Duration(d.importDone) * time.Duration(pending+cached+importing)
}
return return
} }
@ -226,7 +234,9 @@ func (d *Downloader) TakeBlocks() []*Block {
hashes[i] = block.RawBlock.Hash() hashes[i] = block.RawBlock.Hash()
} }
d.importLock.Lock() d.importLock.Lock()
d.importStart = time.Now()
d.importQueue = hashes d.importQueue = hashes
d.importDone = 0
d.importLock.Unlock() d.importLock.Unlock()
} }
return blocks return blocks
@ -287,6 +297,7 @@ func (d *Downloader) Cancel() bool {
d.importLock.Lock() d.importLock.Lock()
d.importQueue = nil d.importQueue = nil
d.importDone = 0
d.importLock.Unlock() d.importLock.Unlock()
return true return true

Loading…
Cancel
Save