From 1351abf74b2275c91aa476c5e6b1d56021448881 Mon Sep 17 00:00:00 2001 From: Julius Andrikonis Date: Fri, 22 Sep 2023 14:30:13 +0300 Subject: [PATCH] BugFix: snapshot download reporting fixed --- .../sm_snapshots/progress_reporter.go | 1 + .../sm_snapshots/snapshot_manager.go | 20 +++++++++++-------- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/packages/chain/statemanager/sm_snapshots/progress_reporter.go b/packages/chain/statemanager/sm_snapshots/progress_reporter.go index 68673164b0..ba9e53f8c3 100644 --- a/packages/chain/statemanager/sm_snapshots/progress_reporter.go +++ b/packages/chain/statemanager/sm_snapshots/progress_reporter.go @@ -35,6 +35,7 @@ func NewProgressReporter(log *logger.Logger, header string, expected uint64) io. } func (pr *progressReporter) Write(p []byte) (int, error) { + pr.total += uint64(len(p)) now := time.Now() timeDiff := now.Sub(pr.lastReport) if timeDiff >= logStatusPeriodConst { diff --git a/packages/chain/statemanager/sm_snapshots/snapshot_manager.go b/packages/chain/statemanager/sm_snapshots/snapshot_manager.go index fab6ded737..aa4f0601aa 100644 --- a/packages/chain/statemanager/sm_snapshots/snapshot_manager.go +++ b/packages/chain/statemanager/sm_snapshots/snapshot_manager.go @@ -193,7 +193,7 @@ func (smiT *snapshotManagerImpl) loadSnapshot() SnapshotInfo { for i := range snapshotPaths { err := smiT.loadSnapshotFromPath(snapshotInfos[i], snapshotPaths[i]) if err == nil { - smiT.log.Debugf("Snapshot %s successfully loaded from %s", snapshotInfos[i], snapshotPaths[i]) + smiT.log.Infof("Snapshot %s successfully loaded from %s", snapshotInfos[i], snapshotPaths[i]) return snapshotInfos[i] } smiT.log.Errorf("Failed to load snapshot %s from %s: %v", snapshotInfos[i], snapshotPaths[i], err) @@ -272,7 +272,7 @@ func (smiT *snapshotManagerImpl) searchNetworkSnapshots(baseNetworkPaths []strin smiT.log.Errorf("Search network snapshots: unable to parse url %s: %v", baseNetworkPathWithChainID, err) return } - reader, err := smiT.getReadCloser(scheme, basePath, constIndexFileName) + reader, err := smiT.getReadCloser(scheme, "index file", basePath, constIndexFileName) if err != nil { smiT.log.Errorf("Search network snapshots: failed to open index file: %v", err) return @@ -283,7 +283,7 @@ func (smiT *snapshotManagerImpl) searchNetworkSnapshots(baseNetworkPaths []strin for scanner.Scan() { func() { snapshotFileName := scanner.Text() - sReader, er := smiT.getReadCloser(scheme, basePath, snapshotFileName) + sReader, er := smiT.getReadCloser(scheme, "snapshot header", basePath, snapshotFileName) if er != nil { smiT.log.Errorf("Search network snapshots: failed to open snapshot file: %v", er) return @@ -331,10 +331,14 @@ func (smiT *snapshotManagerImpl) loadSnapshotFromPath(snapshotInfo SnapshotInfo, loadNetworkFun := func(url string) error { fileNameLocal := downloadedSnapshotFileName(snapshotInfo.StateIndex(), snapshotInfo.BlockHash()) filePathLocal := filepath.Join(smiT.localPath, fileNameLocal) - err := DownloadToFile(smiT.ctx, url, filePathLocal, constDownloadTimeout, smiT.addProgressReporter) + addProgressReporterFun := func(r io.Reader, f string, s uint64) io.Reader { + return smiT.addProgressReporter(r, fmt.Sprintf("snapshot %s", snapshotInfo), f, s) + } + err := DownloadToFile(smiT.ctx, url, filePathLocal, constDownloadTimeout, addProgressReporterFun) if err != nil { return err } + smiT.log.Debugf("Loading snapshot %s from url %s: snapshot successfully downloaded to %s", snapshotInfo, url, filePathLocal) return loadLocalFun(filePathLocal) } @@ -369,7 +373,7 @@ func (smiT *snapshotManagerImpl) splitURL(uString string) (scheme string, path s } } -func (smiT *snapshotManagerImpl) getReadCloser(scheme string, basePath string, file string) (io.ReadCloser, error) { +func (smiT *snapshotManagerImpl) getReadCloser(scheme string, fileType string, basePath string, file string) (io.ReadCloser, error) { switch scheme { case constSchemeHTTP: fullPath, err := url.JoinPath(basePath, file) @@ -380,7 +384,7 @@ func (smiT *snapshotManagerImpl) getReadCloser(scheme string, basePath string, f if err != nil { return nil, fmt.Errorf("failed to start downloading file from url %s: %v", fullPath, err) } - r := smiT.addProgressReporter(downloader, fullPath, downloader.GetLength()) + r := smiT.addProgressReporter(downloader, fileType, fullPath, downloader.GetLength()) return NewReaderWithClose(r, downloader.Close), nil case constSchemeFile: fullPath := filepath.Join(basePath, file) @@ -394,8 +398,8 @@ func (smiT *snapshotManagerImpl) getReadCloser(scheme string, basePath string, f } } -func (smiT *snapshotManagerImpl) addProgressReporter(r io.Reader, url string, length uint64) io.Reader { - progressReporter := NewProgressReporter(smiT.log, fmt.Sprintf("downloading file %s", url), length) +func (smiT *snapshotManagerImpl) addProgressReporter(r io.Reader, fileType string, url string, length uint64) io.Reader { + progressReporter := NewProgressReporter(smiT.log, fmt.Sprintf("Downloading %s from url %s", fileType, url), length) return io.TeeReader(r, progressReporter) }