From 55f4756770f7ebc204fa6e91c87f7ace59d64675 Mon Sep 17 00:00:00 2001 From: Ibrahim Jarif Date: Thu, 27 Aug 2020 19:16:07 +0530 Subject: [PATCH] fix(task): Return error on closed DB (#6075) Fixes DGRAPH-2181 The queries in dgraph are processed in separate goroutines. The pstore badger DB could be closed while the query was being processed. This causes panics such as ``` panic: runtime error: invalid memory address or nil pointer dereference panic: Unclosed iterator at time of Txn.Discard. [signal SIGSEGV: segmentation violation code=0x1 addr=0x10 pc=0x11d2311] goroutine 19298 [running]: github.com/dgraph-io/badger/v2.(*Txn).Discard(0xc05586bc20) /go/pkg/mod/github.com/dgraph-io/badger/v2@v2.0.1-rc1.0.20200718033852-37ee16d8ad1c/txn.go:517 +0xc1 panic(0x19e26a0, 0x2988560) /usr/local/go/src/runtime/panic.go:969 +0x166 github.com/dgraph-io/badger/v2/skl.(*Skiplist).IncrRef(...) ``` This PR attempts to reduce the number of such crashes. This PR doesn't fix the actual issue but it tries to reduce the probability of such crashes by checking if badger is not closed before accessing it. An ideal fix would be to stop all the goroutines started by dgraph while closing DB so that we don't try to read from a closed badger DB. (cherry picked from commit 3cea0fe26c27d62e9ebc5f9574cdc9ba2e31fa13) --- posting/mvcc.go | 3 +++ 1 file changed, 3 insertions(+) diff --git a/posting/mvcc.go b/posting/mvcc.go index cc575e5d31c..c1bcc99b5fb 100644 --- a/posting/mvcc.go +++ b/posting/mvcc.go @@ -366,6 +366,9 @@ func ReadPostingList(key []byte, it *badger.Iterator) (*List, error) { } func getNew(key []byte, pstore *badger.DB, readTs uint64) (*List, error) { + if pstore.IsClosed() { + return nil, badger.ErrDBClosed + } txn := pstore.NewTransactionAt(readTs, false) defer txn.Discard()