drop mergeStats and move freelist stats update to Tx

pull/34/head
Martin Kobetic 2014-06-17 19:30:10 +00:00
parent c105316292
commit 4918ce8301
2 changed files with 14 additions and 12 deletions

16
db.go
View File

@ -427,12 +427,16 @@ func (db *DB) removeTx(tx *Tx) {
break
}
}
n := len(db.txs)
// Unlock the meta pages.
db.metalock.Unlock()
// Merge statistics.
db.mergeStats(&tx.stats)
db.statlock.Lock()
db.stats.OpenTxN = n
db.stats.TxStats.add(&tx.stats)
db.statlock.Unlock()
}
// Update executes a function within the context of a read-write managed transaction.
@ -550,16 +554,6 @@ func (db *DB) allocate(count int) (*page, error) {
return p, nil
}
// mergeStats updates db stats in thread-safe manner.
func (db *DB) mergeStats(txStats *TxStats) {
db.statlock.Lock()
db.stats.FreelistN = db.freelist.count()
db.stats.FreelistAlloc = db.freelist.size()
db.stats.OpenTxN = len(db.txs)
db.stats.TxStats.add(txStats)
db.statlock.Unlock()
}
// Stats represents statistics about the database.
type Stats struct {
// Freelist stats

10
tx.go
View File

@ -232,11 +232,19 @@ func (tx *Tx) rollback() {
func (tx *Tx) close() {
if tx.writable {
// Grab freelist stats.
var freelistN = tx.db.freelist.count()
var freelistAlloc = tx.db.freelist.size()
// Remove writer lock.
tx.db.rwlock.Unlock()
// Merge statistics.
tx.db.mergeStats(&tx.stats)
tx.db.statlock.Lock()
tx.db.stats.FreelistN = freelistN
tx.db.stats.FreelistAlloc = freelistAlloc
tx.db.stats.TxStats.add(&tx.stats)
tx.db.statlock.Unlock()
} else {
tx.db.removeTx(tx)
}