mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-08 20:11:21 +00:00
torrent: don't cancel storage, because lib can't handle such error and can graceful-shutdown anyway (#937)
This commit is contained in:
parent
b7f18a5de1
commit
474982ecaf
@ -33,18 +33,17 @@ const (
|
||||
|
||||
type mdbxPieceCompletion struct {
|
||||
db kv.RwDB
|
||||
ctx context.Context
|
||||
}
|
||||
|
||||
var _ storage.PieceCompletion = (*mdbxPieceCompletion)(nil)
|
||||
|
||||
func NewMdbxPieceCompletion(ctx context.Context, db kv.RwDB) (ret storage.PieceCompletion, err error) {
|
||||
ret = &mdbxPieceCompletion{ctx: ctx, db: db}
|
||||
func NewMdbxPieceCompletion(db kv.RwDB) (ret storage.PieceCompletion, err error) {
|
||||
ret = &mdbxPieceCompletion{db: db}
|
||||
return
|
||||
}
|
||||
|
||||
func (m mdbxPieceCompletion) Get(pk metainfo.PieceKey) (cn storage.Completion, err error) {
|
||||
err = m.db.View(m.ctx, func(tx kv.Tx) error {
|
||||
err = m.db.View(context.Background(), func(tx kv.Tx) error {
|
||||
var key [infohash.Size + 4]byte
|
||||
copy(key[:], pk.InfoHash[:])
|
||||
binary.BigEndian.PutUint32(key[infohash.Size:], uint32(pk.Index))
|
||||
@ -84,12 +83,12 @@ func (m mdbxPieceCompletion) Set(pk metainfo.PieceKey, b bool) error {
|
||||
// 1K fsyncs/2minutes it's quite expensive, but even on cloud (high latency) drive it allow download 100mb/s
|
||||
// and Erigon doesn't do anything when downloading snapshots
|
||||
if b {
|
||||
tx, err = m.db.BeginRwNosync(m.ctx)
|
||||
tx, err = m.db.BeginRwNosync(context.Background())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
} else {
|
||||
tx, err = m.db.BeginRw(m.ctx)
|
||||
tx, err = m.db.BeginRw(context.Background())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user