lint
This commit is contained in:
parent
a994153e27
commit
bf29d41993
@ -660,16 +660,16 @@ func (s *SplitStore) doCompact(curTs *types.TipSet) error {
|
|||||||
hotCnt++
|
hotCnt++
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if sz, err := s.hot.GetSize(s.ctx, c); err != nil {
|
sz, err := s.hot.GetSize(s.ctx, c)
|
||||||
|
if err != nil {
|
||||||
if ipld.IsNotFound(err) {
|
if ipld.IsNotFound(err) {
|
||||||
log.Warnf("hotstore missing expected block %s", c)
|
log.Warnf("hotstore missing expected block %s", c)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
return xerrors.Errorf("error retrieving block %s from hotstore: %w", c, err)
|
return xerrors.Errorf("error retrieving block %s from hotstore: %w", c, err)
|
||||||
} else {
|
|
||||||
szPurge += sz
|
|
||||||
}
|
}
|
||||||
|
szPurge += sz
|
||||||
|
|
||||||
// it needs to be removed from hot store, mark it as candidate for purge
|
// it needs to be removed from hot store, mark it as candidate for purge
|
||||||
if err := purgew.Write(c); err != nil {
|
if err := purgew.Write(c); err != nil {
|
||||||
@ -965,64 +965,64 @@ func (s *SplitStore) walkChain(ts *types.TipSet, inclState, inclMsgs abi.ChainEp
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("error computing cid reference to parent tipset")
|
return xerrors.Errorf("error computing cid reference to parent tipset")
|
||||||
}
|
}
|
||||||
if sz, err := s.walkObjectIncomplete(pRef, visitor, fHot, stopWalk); err != nil {
|
sz, err := s.walkObjectIncomplete(pRef, visitor, fHot, stopWalk)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking parent tipset cid reference")
|
return xerrors.Errorf("error walking parent tipset cid reference")
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
|
|
||||||
// message are retained if within the inclMsgs boundary
|
// message are retained if within the inclMsgs boundary
|
||||||
if hdr.Height >= inclMsgs && hdr.Height > 0 {
|
if hdr.Height >= inclMsgs && hdr.Height > 0 {
|
||||||
if inclMsgs < inclState {
|
if inclMsgs < inclState {
|
||||||
// we need to use walkObjectIncomplete here, as messages/receipts may be missing early on if we
|
// we need to use walkObjectIncomplete here, as messages/receipts may be missing early on if we
|
||||||
// synced from snapshot and have a long HotStoreMessageRetentionPolicy.
|
// synced from snapshot and have a long HotStoreMessageRetentionPolicy.
|
||||||
if sz, err := s.walkObjectIncomplete(hdr.Messages, visitor, fHot, stopWalk); err != nil {
|
sz, err := s.walkObjectIncomplete(hdr.Messages, visitor, fHot, stopWalk)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking messages (cid: %s): %w", hdr.Messages, err)
|
return xerrors.Errorf("error walking messages (cid: %s): %w", hdr.Messages, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
|
|
||||||
if sz, err := s.walkObjectIncomplete(hdr.ParentMessageReceipts, visitor, fHot, stopWalk); err != nil {
|
sz, err = s.walkObjectIncomplete(hdr.ParentMessageReceipts, visitor, fHot, stopWalk)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking messages receipts (cid: %s): %w", hdr.ParentMessageReceipts, err)
|
return xerrors.Errorf("error walking messages receipts (cid: %s): %w", hdr.ParentMessageReceipts, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
} else {
|
} else {
|
||||||
if sz, err := s.walkObject(hdr.Messages, visitor, fHot); err != nil {
|
sz, err = s.walkObject(hdr.Messages, visitor, fHot)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking messages (cid: %s): %w", hdr.Messages, err)
|
return xerrors.Errorf("error walking messages (cid: %s): %w", hdr.Messages, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
|
|
||||||
if sz, err := s.walkObject(hdr.ParentMessageReceipts, visitor, fHot); err != nil {
|
sz, err := s.walkObject(hdr.ParentMessageReceipts, visitor, fHot)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking message receipts (cid: %s): %w", hdr.ParentMessageReceipts, err)
|
return xerrors.Errorf("error walking message receipts (cid: %s): %w", hdr.ParentMessageReceipts, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// messages and receipts outside of inclMsgs are included in the cold store
|
// messages and receipts outside of inclMsgs are included in the cold store
|
||||||
if hdr.Height < inclMsgs && hdr.Height > 0 {
|
if hdr.Height < inclMsgs && hdr.Height > 0 {
|
||||||
if sz, err := s.walkObjectIncomplete(hdr.Messages, visitor, fCold, stopWalk); err != nil {
|
sz, err := s.walkObjectIncomplete(hdr.Messages, visitor, fCold, stopWalk)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking messages (cid: %s): %w", hdr.Messages, err)
|
return xerrors.Errorf("error walking messages (cid: %s): %w", hdr.Messages, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
if sz, err := s.walkObjectIncomplete(hdr.ParentMessageReceipts, visitor, fCold, stopWalk); err != nil {
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
|
sz, err = s.walkObjectIncomplete(hdr.ParentMessageReceipts, visitor, fCold, stopWalk)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking messages receipts (cid: %s): %w", hdr.ParentMessageReceipts, err)
|
return xerrors.Errorf("error walking messages receipts (cid: %s): %w", hdr.ParentMessageReceipts, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
}
|
}
|
||||||
|
|
||||||
// state is only retained if within the inclState boundary, with the exception of genesis
|
// state is only retained if within the inclState boundary, with the exception of genesis
|
||||||
if hdr.Height >= inclState || hdr.Height == 0 {
|
if hdr.Height >= inclState || hdr.Height == 0 {
|
||||||
if sz, err := s.walkObject(hdr.ParentStateRoot, visitor, fHot); err != nil {
|
sz, err := s.walkObject(hdr.ParentStateRoot, visitor, fHot)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking state root (cid: %s): %w", hdr.ParentStateRoot, err)
|
return xerrors.Errorf("error walking state root (cid: %s): %w", hdr.ParentStateRoot, err)
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
atomic.AddInt64(scanCnt, 1)
|
atomic.AddInt64(scanCnt, 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1040,11 +1040,11 @@ func (s *SplitStore) walkChain(ts *types.TipSet, inclState, inclMsgs abi.ChainEp
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("error computing cid reference to parent tipset")
|
return xerrors.Errorf("error computing cid reference to parent tipset")
|
||||||
}
|
}
|
||||||
if sz, err := s.walkObjectIncomplete(hRef, visitor, fHot, stopWalk); err != nil {
|
sz, err := s.walkObjectIncomplete(hRef, visitor, fHot, stopWalk)
|
||||||
|
if err != nil {
|
||||||
return xerrors.Errorf("error walking parent tipset cid reference")
|
return xerrors.Errorf("error walking parent tipset cid reference")
|
||||||
} else {
|
|
||||||
atomic.AddInt64(szWalk, int64(sz))
|
|
||||||
}
|
}
|
||||||
|
atomic.AddInt64(szWalk, int64(sz))
|
||||||
|
|
||||||
for len(toWalk) > 0 {
|
for len(toWalk) > 0 {
|
||||||
// walking can take a while, so check this with every opportunity
|
// walking can take a while, so check this with every opportunity
|
||||||
|
@ -54,7 +54,7 @@ func (s *SplitStore) gcHotAfterCompaction() {
|
|||||||
} else if shouldDoFull && !canDoFull {
|
} else if shouldDoFull && !canDoFull {
|
||||||
log.Warnf("Attention! Estimated moving GC size %d is not within safety buffer %d of target max %d, performing aggressive online GC to attempt to bring hotstore size down safely", copySizeApprox, targetBuffer, s.cfg.HotstoreMaxSpaceTarget)
|
log.Warnf("Attention! Estimated moving GC size %d is not within safety buffer %d of target max %d, performing aggressive online GC to attempt to bring hotstore size down safely", copySizeApprox, targetBuffer, s.cfg.HotstoreMaxSpaceTarget)
|
||||||
log.Warn("If problem continues you can 1) temporarily allocate more disk space to hotstore and 2) reflect in HotstoreMaxSpaceTarget OR trigger manual move with `lotus chain prune hot-moving`")
|
log.Warn("If problem continues you can 1) temporarily allocate more disk space to hotstore and 2) reflect in HotstoreMaxSpaceTarget OR trigger manual move with `lotus chain prune hot-moving`")
|
||||||
log.Warn("If problem continues and you do not have any more disk space you can run continue to manually trigger online GC at agressive thresholds (< 0.01) with `lotus chain prune hot`")
|
log.Warn("If problem continues and you do not have any more disk space you can run continue to manually trigger online GC at aggressive thresholds (< 0.01) with `lotus chain prune hot`")
|
||||||
|
|
||||||
opts = append(opts, bstore.WithThreshold(aggressiveOnlineGCThreshold))
|
opts = append(opts, bstore.WithThreshold(aggressiveOnlineGCThreshold))
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user