mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
Tracing in the aggregator (#194)
* Tracing in the aggregator * Trace merge of keys * print value when merging * More tracing * Fix trace keys * Fix tracing * Fix skipping * Fix tracing for deleteAccount Co-authored-by: Alexey Sharp <alexeysharp@Alexeys-iMac.local>
This commit is contained in:
parent
0404744146
commit
e83c9f276a
@ -70,6 +70,8 @@ type Aggregator struct {
|
|||||||
codeChanges Changes
|
codeChanges Changes
|
||||||
storageChanges Changes
|
storageChanges Changes
|
||||||
changesBtree *btree.BTree // btree of ChangesItem
|
changesBtree *btree.BTree // btree of ChangesItem
|
||||||
|
trace bool // Turns on tracing for specific accounts and locations
|
||||||
|
tracedKeys map[string]struct{} // Set of keys being traced during aggregations
|
||||||
}
|
}
|
||||||
|
|
||||||
type ChangeFile struct {
|
type ChangeFile struct {
|
||||||
@ -606,6 +608,7 @@ func NewAggregator(diffDir string, unwindLimit uint64, aggregationStep uint64) (
|
|||||||
diffDir: diffDir,
|
diffDir: diffDir,
|
||||||
unwindLimit: unwindLimit,
|
unwindLimit: unwindLimit,
|
||||||
aggregationStep: aggregationStep,
|
aggregationStep: aggregationStep,
|
||||||
|
tracedKeys: make(map[string]struct{}),
|
||||||
}
|
}
|
||||||
byEndBlock := btree.New(32)
|
byEndBlock := btree.New(32)
|
||||||
var closeBtree bool = true // It will be set to false in case of success at the end of the function
|
var closeBtree bool = true // It will be set to false in case of success at the end of the function
|
||||||
@ -819,10 +822,13 @@ func (a *Aggregator) Close() {
|
|||||||
closeFiles(a.byEndBlock)
|
closeFiles(a.byEndBlock)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Aggregator) readAccount(blockNum uint64, addr []byte) []byte {
|
func (a *Aggregator) readAccount(blockNum uint64, addr []byte, trace bool) []byte {
|
||||||
var val []byte
|
var val []byte
|
||||||
a.byEndBlock.DescendLessOrEqual(&byEndBlockItem{endBlock: blockNum}, func(i btree.Item) bool {
|
a.byEndBlock.DescendLessOrEqual(&byEndBlockItem{endBlock: blockNum}, func(i btree.Item) bool {
|
||||||
item := i.(*byEndBlockItem)
|
item := i.(*byEndBlockItem)
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("readAccount %x: search in file [%d-%d]\n", addr, item.startBlock, item.endBlock)
|
||||||
|
}
|
||||||
if item.accountsIdx.Empty() {
|
if item.accountsIdx.Empty() {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
@ -833,6 +839,9 @@ func (a *Aggregator) readAccount(blockNum uint64, addr []byte) []byte {
|
|||||||
key, _ := g.Next(nil) // Add special function that just checks the key
|
key, _ := g.Next(nil) // Add special function that just checks the key
|
||||||
if bytes.Equal(key, addr) {
|
if bytes.Equal(key, addr) {
|
||||||
val, _ = g.Next(nil)
|
val, _ = g.Next(nil)
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("readAccount %x: found [%x] in file [%d-%d]\n", addr, val, item.startBlock, item.endBlock)
|
||||||
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -844,10 +853,13 @@ func (a *Aggregator) readAccount(blockNum uint64, addr []byte) []byte {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Aggregator) readCode(blockNum uint64, addr []byte) []byte {
|
func (a *Aggregator) readCode(blockNum uint64, addr []byte, trace bool) []byte {
|
||||||
var val []byte
|
var val []byte
|
||||||
a.byEndBlock.DescendLessOrEqual(&byEndBlockItem{endBlock: blockNum}, func(i btree.Item) bool {
|
a.byEndBlock.DescendLessOrEqual(&byEndBlockItem{endBlock: blockNum}, func(i btree.Item) bool {
|
||||||
item := i.(*byEndBlockItem)
|
item := i.(*byEndBlockItem)
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("readCode %x: search in file [%d-%d]\n", addr, item.startBlock, item.endBlock)
|
||||||
|
}
|
||||||
if item.codeIdx.Empty() {
|
if item.codeIdx.Empty() {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
@ -858,6 +870,9 @@ func (a *Aggregator) readCode(blockNum uint64, addr []byte) []byte {
|
|||||||
key, _ := g.Next(nil) // Add special function that just checks the key
|
key, _ := g.Next(nil) // Add special function that just checks the key
|
||||||
if bytes.Equal(key, addr) {
|
if bytes.Equal(key, addr) {
|
||||||
val, _ = g.Next(nil)
|
val, _ = g.Next(nil)
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("readCode %x: found [%x] in file [%d-%d]\n", addr, val, item.startBlock, item.endBlock)
|
||||||
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -869,10 +884,13 @@ func (a *Aggregator) readCode(blockNum uint64, addr []byte) []byte {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Aggregator) readStorage(blockNum uint64, filekey []byte) []byte {
|
func (a *Aggregator) readStorage(blockNum uint64, filekey []byte, trace bool) []byte {
|
||||||
var val []byte
|
var val []byte
|
||||||
a.byEndBlock.DescendLessOrEqual(&byEndBlockItem{endBlock: blockNum}, func(i btree.Item) bool {
|
a.byEndBlock.DescendLessOrEqual(&byEndBlockItem{endBlock: blockNum}, func(i btree.Item) bool {
|
||||||
item := i.(*byEndBlockItem)
|
item := i.(*byEndBlockItem)
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("readStorage %x: search in file [%d-%d]\n", filekey, item.startBlock, item.endBlock)
|
||||||
|
}
|
||||||
if item.storageIdx.Empty() {
|
if item.storageIdx.Empty() {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
@ -883,6 +901,9 @@ func (a *Aggregator) readStorage(blockNum uint64, filekey []byte) []byte {
|
|||||||
key, _ := g.Next(nil) // Add special function that just checks the key
|
key, _ := g.Next(nil) // Add special function that just checks the key
|
||||||
if bytes.Equal(key, filekey) {
|
if bytes.Equal(key, filekey) {
|
||||||
val, _ = g.Next(nil)
|
val, _ = g.Next(nil)
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("readStorage %x: found [%x] in file [%d-%d]\n", filekey, val, item.startBlock, item.endBlock)
|
||||||
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -909,7 +930,7 @@ type Reader struct {
|
|||||||
blockNum uint64
|
blockNum uint64
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Reader) ReadAccountData(addr []byte) ([]byte, error) {
|
func (r *Reader) ReadAccountData(addr []byte, trace bool) ([]byte, error) {
|
||||||
// Look in the summary table first
|
// Look in the summary table first
|
||||||
v, err := r.tx.GetOne(kv.StateAccounts, addr)
|
v, err := r.tx.GetOne(kv.StateAccounts, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -917,14 +938,17 @@ func (r *Reader) ReadAccountData(addr []byte) ([]byte, error) {
|
|||||||
}
|
}
|
||||||
if v != nil {
|
if v != nil {
|
||||||
// First 4 bytes is the number of 1-block state diffs containing the key
|
// First 4 bytes is the number of 1-block state diffs containing the key
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("ReadAccountData %x, found in DB: %x, number of diffs: %d\n", addr, v[4:], binary.BigEndian.Uint32(v[:4]))
|
||||||
|
}
|
||||||
return v[4:], nil
|
return v[4:], nil
|
||||||
}
|
}
|
||||||
// Look in the files
|
// Look in the files
|
||||||
val := r.a.readAccount(r.blockNum, addr)
|
val := r.a.readAccount(r.blockNum, addr, trace)
|
||||||
return val, nil
|
return val, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Reader) ReadAccountStorage(addr []byte, loc []byte) (*uint256.Int, error) {
|
func (r *Reader) ReadAccountStorage(addr []byte, loc []byte, trace bool) (*uint256.Int, error) {
|
||||||
// Look in the summary table first
|
// Look in the summary table first
|
||||||
dbkey := make([]byte, len(addr)+len(loc))
|
dbkey := make([]byte, len(addr)+len(loc))
|
||||||
copy(dbkey[0:], addr)
|
copy(dbkey[0:], addr)
|
||||||
@ -934,6 +958,9 @@ func (r *Reader) ReadAccountStorage(addr []byte, loc []byte) (*uint256.Int, erro
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if v != nil {
|
if v != nil {
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("ReadAccountStorage %x %x, found in DB: %x, number of diffs: %d\n", addr, loc, v[4:], binary.BigEndian.Uint32(v[:4]))
|
||||||
|
}
|
||||||
if len(v) == 4 {
|
if len(v) == 4 {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
@ -941,14 +968,14 @@ func (r *Reader) ReadAccountStorage(addr []byte, loc []byte) (*uint256.Int, erro
|
|||||||
return new(uint256.Int).SetBytes(v[4:]), nil
|
return new(uint256.Int).SetBytes(v[4:]), nil
|
||||||
}
|
}
|
||||||
// Look in the files
|
// Look in the files
|
||||||
val := r.a.readStorage(r.blockNum, dbkey)
|
val := r.a.readStorage(r.blockNum, dbkey, trace)
|
||||||
if val != nil {
|
if val != nil {
|
||||||
return new(uint256.Int).SetBytes(val), nil
|
return new(uint256.Int).SetBytes(val), nil
|
||||||
}
|
}
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Reader) ReadAccountCode(addr []byte) ([]byte, error) {
|
func (r *Reader) ReadAccountCode(addr []byte, trace bool) ([]byte, error) {
|
||||||
// Look in the summary table first
|
// Look in the summary table first
|
||||||
v, err := r.tx.GetOne(kv.StateCode, addr)
|
v, err := r.tx.GetOne(kv.StateCode, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -956,10 +983,13 @@ func (r *Reader) ReadAccountCode(addr []byte) ([]byte, error) {
|
|||||||
}
|
}
|
||||||
if v != nil {
|
if v != nil {
|
||||||
// First 4 bytes is the number of 1-block state diffs containing the key
|
// First 4 bytes is the number of 1-block state diffs containing the key
|
||||||
|
if trace {
|
||||||
|
fmt.Printf("ReadAccountCode %x, found in DB: %x, number of diffs: %d\n", addr, v[4:], binary.BigEndian.Uint32(v[:4]))
|
||||||
|
}
|
||||||
return v[4:], nil
|
return v[4:], nil
|
||||||
}
|
}
|
||||||
// Look in the files
|
// Look in the files
|
||||||
val := r.a.readCode(r.blockNum, addr)
|
val := r.a.readCode(r.blockNum, addr, trace)
|
||||||
return val, nil
|
return val, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1027,7 +1057,7 @@ func (w *Writer) Finish() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Writer) UpdateAccountData(addr []byte, account []byte) error {
|
func (w *Writer) UpdateAccountData(addr []byte, account []byte, trace bool) error {
|
||||||
prevV, err := w.tx.GetOne(kv.StateAccounts, addr)
|
prevV, err := w.tx.GetOne(kv.StateAccounts, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -1035,7 +1065,7 @@ func (w *Writer) UpdateAccountData(addr []byte, account []byte) error {
|
|||||||
var prevNum uint32
|
var prevNum uint32
|
||||||
var original []byte
|
var original []byte
|
||||||
if prevV == nil {
|
if prevV == nil {
|
||||||
original = w.a.readAccount(w.blockNum, addr)
|
original = w.a.readAccount(w.blockNum, addr, trace)
|
||||||
} else {
|
} else {
|
||||||
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
||||||
}
|
}
|
||||||
@ -1057,10 +1087,14 @@ func (w *Writer) UpdateAccountData(addr []byte, account []byte) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if trace {
|
||||||
|
w.a.trace = true
|
||||||
|
w.a.tracedKeys[string(addr)] = struct{}{}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Writer) UpdateAccountCode(addr []byte, code []byte) error {
|
func (w *Writer) UpdateAccountCode(addr []byte, code []byte, trace bool) error {
|
||||||
prevV, err := w.tx.GetOne(kv.StateCode, addr)
|
prevV, err := w.tx.GetOne(kv.StateCode, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -1068,7 +1102,7 @@ func (w *Writer) UpdateAccountCode(addr []byte, code []byte) error {
|
|||||||
var prevNum uint32
|
var prevNum uint32
|
||||||
var original []byte
|
var original []byte
|
||||||
if prevV == nil {
|
if prevV == nil {
|
||||||
original = w.a.readCode(w.blockNum, addr)
|
original = w.a.readCode(w.blockNum, addr, trace)
|
||||||
} else {
|
} else {
|
||||||
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
||||||
}
|
}
|
||||||
@ -1090,6 +1124,10 @@ func (w *Writer) UpdateAccountCode(addr []byte, code []byte) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if trace {
|
||||||
|
w.a.trace = true
|
||||||
|
w.a.tracedKeys[string(addr)] = struct{}{}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1134,7 +1172,7 @@ func (ch *CursorHeap) Pop() interface{} {
|
|||||||
return x
|
return x
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Writer) deleteAccount(addr []byte) error {
|
func (w *Writer) deleteAccount(addr []byte, trace bool) error {
|
||||||
prevV, err := w.tx.GetOne(kv.StateAccounts, addr)
|
prevV, err := w.tx.GetOne(kv.StateAccounts, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -1142,7 +1180,7 @@ func (w *Writer) deleteAccount(addr []byte) error {
|
|||||||
var prevNum uint32
|
var prevNum uint32
|
||||||
var original []byte
|
var original []byte
|
||||||
if prevV == nil {
|
if prevV == nil {
|
||||||
original = w.a.readAccount(w.blockNum, addr)
|
original = w.a.readAccount(w.blockNum, addr, trace)
|
||||||
} else {
|
} else {
|
||||||
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
||||||
}
|
}
|
||||||
@ -1162,7 +1200,7 @@ func (w *Writer) deleteAccount(addr []byte) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Writer) deleteCode(addr []byte) error {
|
func (w *Writer) deleteCode(addr []byte, trace bool) error {
|
||||||
prevV, err := w.tx.GetOne(kv.StateCode, addr)
|
prevV, err := w.tx.GetOne(kv.StateCode, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -1170,7 +1208,7 @@ func (w *Writer) deleteCode(addr []byte) error {
|
|||||||
var prevNum uint32
|
var prevNum uint32
|
||||||
var original []byte
|
var original []byte
|
||||||
if prevV == nil {
|
if prevV == nil {
|
||||||
original = w.a.readCode(w.blockNum, addr)
|
original = w.a.readCode(w.blockNum, addr, trace)
|
||||||
} else {
|
} else {
|
||||||
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
||||||
}
|
}
|
||||||
@ -1191,11 +1229,11 @@ func (w *Writer) deleteCode(addr []byte) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Writer) DeleteAccount(addr []byte) error {
|
func (w *Writer) DeleteAccount(addr []byte, trace bool) error {
|
||||||
if err := w.deleteAccount(addr); err != nil {
|
if err := w.deleteAccount(addr, trace); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if err := w.deleteCode(addr); err != nil {
|
if err := w.deleteCode(addr, trace); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
// Find all storage items for this address
|
// Find all storage items for this address
|
||||||
@ -1286,10 +1324,14 @@ func (w *Writer) DeleteAccount(addr []byte) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if trace {
|
||||||
|
w.a.trace = true
|
||||||
|
w.a.tracedKeys[string(addr)] = struct{}{}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Writer) WriteAccountStorage(addr []byte, loc []byte, value *uint256.Int) error {
|
func (w *Writer) WriteAccountStorage(addr []byte, loc []byte, value *uint256.Int, trace bool) error {
|
||||||
dbkey := make([]byte, len(addr)+len(loc))
|
dbkey := make([]byte, len(addr)+len(loc))
|
||||||
copy(dbkey[0:], addr)
|
copy(dbkey[0:], addr)
|
||||||
copy(dbkey[len(addr):], loc)
|
copy(dbkey[len(addr):], loc)
|
||||||
@ -1300,7 +1342,7 @@ func (w *Writer) WriteAccountStorage(addr []byte, loc []byte, value *uint256.Int
|
|||||||
var prevNum uint32
|
var prevNum uint32
|
||||||
var original []byte
|
var original []byte
|
||||||
if prevV == nil {
|
if prevV == nil {
|
||||||
original = w.a.readStorage(w.blockNum, dbkey)
|
original = w.a.readStorage(w.blockNum, dbkey, trace)
|
||||||
} else {
|
} else {
|
||||||
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
prevNum = binary.BigEndian.Uint32(prevV[:4])
|
||||||
}
|
}
|
||||||
@ -1323,6 +1365,10 @@ func (w *Writer) WriteAccountStorage(addr []byte, loc []byte, value *uint256.Int
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if trace {
|
||||||
|
w.a.trace = true
|
||||||
|
w.a.tracedKeys[string(dbkey)] = struct{}{}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1418,7 +1464,7 @@ func (w *Writer) aggregateUpto(blockFrom, blockTo uint64) error {
|
|||||||
heap.Push(&cp, &CursorItem{file: true, dg: g, key: key, val: val, endBlock: ag.endBlock})
|
heap.Push(&cp, &CursorItem{file: true, dg: g, key: key, val: val, endBlock: ag.endBlock})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if item2.accountsD, item2.accountsIdx, err = mergeIntoStateFile(&cp, 0, "accounts", lastStart, blockTo, w.a.diffDir); err != nil {
|
if item2.accountsD, item2.accountsIdx, err = w.a.mergeIntoStateFile(&cp, 0, "accounts", lastStart, blockTo, w.a.diffDir); err != nil {
|
||||||
return fmt.Errorf("mergeIntoStateFile accounts [%d-%d]: %w", lastStart, blockTo, err)
|
return fmt.Errorf("mergeIntoStateFile accounts [%d-%d]: %w", lastStart, blockTo, err)
|
||||||
}
|
}
|
||||||
cp = cp[:0]
|
cp = cp[:0]
|
||||||
@ -1431,7 +1477,7 @@ func (w *Writer) aggregateUpto(blockFrom, blockTo uint64) error {
|
|||||||
heap.Push(&cp, &CursorItem{file: true, dg: g, key: key, val: val, endBlock: ag.endBlock})
|
heap.Push(&cp, &CursorItem{file: true, dg: g, key: key, val: val, endBlock: ag.endBlock})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if item2.codeD, item2.codeIdx, err = mergeIntoStateFile(&cp, 0, "code", lastStart, blockTo, w.a.diffDir); err != nil {
|
if item2.codeD, item2.codeIdx, err = w.a.mergeIntoStateFile(&cp, 0, "code", lastStart, blockTo, w.a.diffDir); err != nil {
|
||||||
return fmt.Errorf("mergeIntoStateFile code [%d-%d]: %w", lastStart, blockTo, err)
|
return fmt.Errorf("mergeIntoStateFile code [%d-%d]: %w", lastStart, blockTo, err)
|
||||||
}
|
}
|
||||||
cp = cp[:0]
|
cp = cp[:0]
|
||||||
@ -1446,7 +1492,7 @@ func (w *Writer) aggregateUpto(blockFrom, blockTo uint64) error {
|
|||||||
//fmt.Printf("starting with %x => %x\n", key, val)
|
//fmt.Printf("starting with %x => %x\n", key, val)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if item2.storageD, item2.storageIdx, err = mergeIntoStateFile(&cp, 20, "storage", lastStart, blockTo, w.a.diffDir); err != nil {
|
if item2.storageD, item2.storageIdx, err = w.a.mergeIntoStateFile(&cp, 20, "storage", lastStart, blockTo, w.a.diffDir); err != nil {
|
||||||
return fmt.Errorf("mergeIntoStateFile storage [%d-%d]: %w", lastStart, blockTo, err)
|
return fmt.Errorf("mergeIntoStateFile storage [%d-%d]: %w", lastStart, blockTo, err)
|
||||||
}
|
}
|
||||||
// Remove all items in toAggregate and insert item2 instead
|
// Remove all items in toAggregate and insert item2 instead
|
||||||
@ -1503,7 +1549,7 @@ func (w *Writer) aggregateUpto(blockFrom, blockTo uint64) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func mergeIntoStateFile(cp *CursorHeap, prefixLen int, basename string, startBlock, endBlock uint64, dir string) (*compress.Decompressor, *recsplit.Index, error) {
|
func (a *Aggregator) mergeIntoStateFile(cp *CursorHeap, prefixLen int, basename string, startBlock, endBlock uint64, dir string) (*compress.Decompressor, *recsplit.Index, error) {
|
||||||
datPath := path.Join(dir, fmt.Sprintf("%s.%d-%d.dat", basename, startBlock, endBlock))
|
datPath := path.Join(dir, fmt.Sprintf("%s.%d-%d.dat", basename, startBlock, endBlock))
|
||||||
idxPath := path.Join(dir, fmt.Sprintf("%s.%d-%d.idx", basename, startBlock, endBlock))
|
idxPath := path.Join(dir, fmt.Sprintf("%s.%d-%d.idx", basename, startBlock, endBlock))
|
||||||
var comp *compress.Compressor
|
var comp *compress.Compressor
|
||||||
@ -1515,12 +1561,21 @@ func mergeIntoStateFile(cp *CursorHeap, prefixLen int, basename string, startBlo
|
|||||||
var keyBuf, valBuf []byte
|
var keyBuf, valBuf []byte
|
||||||
for cp.Len() > 0 {
|
for cp.Len() > 0 {
|
||||||
lastKey := common.Copy((*cp)[0].key)
|
lastKey := common.Copy((*cp)[0].key)
|
||||||
//fmt.Printf("looking at key %x to merge into [%d-%d]\n", lastKey, startBlock, endBlock)
|
|
||||||
lastVal := common.Copy((*cp)[0].val)
|
lastVal := common.Copy((*cp)[0].val)
|
||||||
|
if a.trace {
|
||||||
|
if _, ok := a.tracedKeys[string(lastKey)]; ok {
|
||||||
|
fmt.Printf("looking at key %x val [%x] endBlock %d to merge into [%d-%d]\n", lastKey, lastVal, (*cp)[0].endBlock, startBlock, endBlock)
|
||||||
|
}
|
||||||
|
}
|
||||||
var first, firstDelete, firstInsert bool
|
var first, firstDelete, firstInsert bool
|
||||||
// Advance all the items that have this key (including the top)
|
// Advance all the items that have this key (including the top)
|
||||||
for cp.Len() > 0 && bytes.Equal((*cp)[0].key, lastKey) {
|
for cp.Len() > 0 && bytes.Equal((*cp)[0].key, lastKey) {
|
||||||
ci1 := (*cp)[0]
|
ci1 := (*cp)[0]
|
||||||
|
if a.trace {
|
||||||
|
if _, ok := a.tracedKeys[string(ci1.key)]; ok {
|
||||||
|
fmt.Printf("skipping same key %x val [%x] endBlock %d to merge into [%d-%d]\n", ci1.key, ci1.val, ci1.endBlock, startBlock, endBlock)
|
||||||
|
}
|
||||||
|
}
|
||||||
first = true
|
first = true
|
||||||
firstDelete = len(ci1.val) == 0
|
firstDelete = len(ci1.val) == 0
|
||||||
firstInsert = !firstDelete && ci1.val[0] != 0
|
firstInsert = !firstDelete && ci1.val[0] != 0
|
||||||
@ -1553,12 +1608,16 @@ func mergeIntoStateFile(cp *CursorHeap, prefixLen int, basename string, startBlo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if !skip {
|
if startBlock != 0 || !skip {
|
||||||
if keyBuf != nil && (prefixLen == 0 || len(keyBuf) != prefixLen || bytes.HasPrefix(lastKey, keyBuf)) {
|
if keyBuf != nil && (prefixLen == 0 || len(keyBuf) != prefixLen || bytes.HasPrefix(lastKey, keyBuf)) {
|
||||||
if err = comp.AddWord(keyBuf); err != nil {
|
if err = comp.AddWord(keyBuf); err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
}
|
}
|
||||||
//fmt.Printf("merge key %x into [%d-%d]\n", keyBuf, startBlock, endBlock)
|
if a.trace {
|
||||||
|
if _, ok := a.tracedKeys[string(keyBuf)]; ok {
|
||||||
|
fmt.Printf("merge key %x val [%x] into [%d-%d]\n", keyBuf, valBuf, startBlock, endBlock)
|
||||||
|
}
|
||||||
|
}
|
||||||
count++ // Only counting keys, not values
|
count++ // Only counting keys, not values
|
||||||
if err = comp.AddWord(valBuf); err != nil {
|
if err = comp.AddWord(valBuf); err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
@ -1566,15 +1625,21 @@ func mergeIntoStateFile(cp *CursorHeap, prefixLen int, basename string, startBlo
|
|||||||
}
|
}
|
||||||
keyBuf = append(keyBuf[:0], lastKey...)
|
keyBuf = append(keyBuf[:0], lastKey...)
|
||||||
valBuf = append(valBuf[:0], lastVal...)
|
valBuf = append(valBuf[:0], lastVal...)
|
||||||
//} else {
|
} else if a.trace {
|
||||||
// fmt.Printf("skipped key %x for [%d-%d]\n", keyBuf, startBlock, endBlock)
|
if _, ok := a.tracedKeys[string(keyBuf)]; ok {
|
||||||
|
fmt.Printf("skipped key %x for [%d-%d]\n", keyBuf, startBlock, endBlock)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if keyBuf != nil {
|
if keyBuf != nil {
|
||||||
if err = comp.AddWord(keyBuf); err != nil {
|
if err = comp.AddWord(keyBuf); err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
}
|
}
|
||||||
//fmt.Printf("merge key %x into [%d-%d]\n", keyBuf, startBlock, endBlock)
|
if a.trace {
|
||||||
|
if _, ok := a.tracedKeys[string(keyBuf)]; ok {
|
||||||
|
fmt.Printf("merge key %x val [%x] into [%d-%d]\n", keyBuf, valBuf, startBlock, endBlock)
|
||||||
|
}
|
||||||
|
}
|
||||||
count++ // Only counting keys, not values
|
count++ // Only counting keys, not values
|
||||||
if err = comp.AddWord(valBuf); err != nil {
|
if err = comp.AddWord(valBuf); err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
|
@ -58,7 +58,7 @@ func TestSimpleAggregator(t *testing.T) {
|
|||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
var account1 = int256(1)
|
var account1 = int256(1)
|
||||||
if err = w.UpdateAccountData(int160(1), account1); err != nil {
|
if err = w.UpdateAccountData(int160(1), account1, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if err = w.Finish(); err != nil {
|
if err = w.Finish(); err != nil {
|
||||||
@ -74,7 +74,7 @@ func TestSimpleAggregator(t *testing.T) {
|
|||||||
defer tx.Rollback()
|
defer tx.Rollback()
|
||||||
r := a.MakeStateReader(tx, 2)
|
r := a.MakeStateReader(tx, 2)
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(int160(1)); err != nil {
|
if acc, err = r.ReadAccountData(int160(1), false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !bytes.Equal(acc, account1) {
|
if !bytes.Equal(acc, account1) {
|
||||||
@ -111,7 +111,7 @@ func TestLoopAggregator(t *testing.T) {
|
|||||||
if w, err = a.MakeStateWriter(rwTx, blockNum); err != nil {
|
if w, err = a.MakeStateWriter(rwTx, blockNum); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if err = w.UpdateAccountData(accountKey, account1); err != nil {
|
if err = w.UpdateAccountData(accountKey, account1, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if err = w.Finish(); err != nil {
|
if err = w.Finish(); err != nil {
|
||||||
@ -125,7 +125,7 @@ func TestLoopAggregator(t *testing.T) {
|
|||||||
}
|
}
|
||||||
r := a.MakeStateReader(tx, blockNum+1)
|
r := a.MakeStateReader(tx, blockNum+1)
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(accountKey); err != nil {
|
if acc, err = r.ReadAccountData(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
tx.Rollback()
|
tx.Rollback()
|
||||||
@ -146,7 +146,7 @@ func TestLoopAggregator(t *testing.T) {
|
|||||||
expected = int256(i * 10)
|
expected = int256(i * 10)
|
||||||
}
|
}
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(accountKey); err != nil {
|
if acc, err = r.ReadAccountData(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !bytes.Equal(acc, expected) {
|
if !bytes.Equal(acc, expected) {
|
||||||
@ -187,24 +187,24 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
switch blockNum {
|
switch blockNum {
|
||||||
case 1:
|
case 1:
|
||||||
if err = w.UpdateAccountData(accountKey, account1); err != nil {
|
if err = w.UpdateAccountData(accountKey, account1, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
for s := uint64(0); s < 100; s++ {
|
for s := uint64(0); s < 100; s++ {
|
||||||
if err = w.WriteAccountStorage(accountKey, int256(s), uint256.NewInt(s+1)); err != nil {
|
if err = w.WriteAccountStorage(accountKey, int256(s), uint256.NewInt(s+1), false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case 22:
|
case 22:
|
||||||
if err = w.DeleteAccount(accountKey); err != nil {
|
if err = w.DeleteAccount(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
case 45:
|
case 45:
|
||||||
if err = w.UpdateAccountData(accountKey, account2); err != nil {
|
if err = w.UpdateAccountData(accountKey, account2, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
for s := uint64(50); s < 150; s++ {
|
for s := uint64(50); s < 150; s++ {
|
||||||
if err = w.WriteAccountStorage(accountKey, int256(s), uint256.NewInt(2*s+1)); err != nil {
|
if err = w.WriteAccountStorage(accountKey, int256(s), uint256.NewInt(2*s+1), false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -222,7 +222,7 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
switch blockNum {
|
switch blockNum {
|
||||||
case 1:
|
case 1:
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(accountKey); err != nil {
|
if acc, err = r.ReadAccountData(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !bytes.Equal(account1, acc) {
|
if !bytes.Equal(account1, acc) {
|
||||||
@ -230,7 +230,7 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
for s := uint64(0); s < 100; s++ {
|
for s := uint64(0); s < 100; s++ {
|
||||||
var v *uint256.Int
|
var v *uint256.Int
|
||||||
if v, err = r.ReadAccountStorage(accountKey, int256(s)); err != nil {
|
if v, err = r.ReadAccountStorage(accountKey, int256(s), false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !uint256.NewInt(s + 1).Eq(v) {
|
if !uint256.NewInt(s + 1).Eq(v) {
|
||||||
@ -239,7 +239,7 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
case 22, 44:
|
case 22, 44:
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(accountKey); err != nil {
|
if acc, err = r.ReadAccountData(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if len(acc) > 0 {
|
if len(acc) > 0 {
|
||||||
@ -247,7 +247,7 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
for s := uint64(0); s < 100; s++ {
|
for s := uint64(0); s < 100; s++ {
|
||||||
var v *uint256.Int
|
var v *uint256.Int
|
||||||
if v, err = r.ReadAccountStorage(accountKey, int256(s)); err != nil {
|
if v, err = r.ReadAccountStorage(accountKey, int256(s), false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if v != nil {
|
if v != nil {
|
||||||
@ -256,7 +256,7 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
case 66:
|
case 66:
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(accountKey); err != nil {
|
if acc, err = r.ReadAccountData(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !bytes.Equal(account2, acc) {
|
if !bytes.Equal(account2, acc) {
|
||||||
@ -264,7 +264,7 @@ func TestRecreateAccountWithStorage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
for s := uint64(0); s < 150; s++ {
|
for s := uint64(0); s < 150; s++ {
|
||||||
var v *uint256.Int
|
var v *uint256.Int
|
||||||
if v, err = r.ReadAccountStorage(accountKey, int256(s)); err != nil {
|
if v, err = r.ReadAccountStorage(accountKey, int256(s), false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if s < 50 {
|
if s < 50 {
|
||||||
@ -313,14 +313,14 @@ func TestChangeCode(t *testing.T) {
|
|||||||
}
|
}
|
||||||
switch blockNum {
|
switch blockNum {
|
||||||
case 1:
|
case 1:
|
||||||
if err = w.UpdateAccountData(accountKey, account1); err != nil {
|
if err = w.UpdateAccountData(accountKey, account1, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if err = w.UpdateAccountCode(accountKey, code1); err != nil {
|
if err = w.UpdateAccountCode(accountKey, code1, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
case 25:
|
case 25:
|
||||||
if err = w.DeleteAccount(accountKey); err != nil {
|
if err = w.DeleteAccount(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -337,14 +337,14 @@ func TestChangeCode(t *testing.T) {
|
|||||||
switch blockNum {
|
switch blockNum {
|
||||||
case 22:
|
case 22:
|
||||||
var acc []byte
|
var acc []byte
|
||||||
if acc, err = r.ReadAccountData(accountKey); err != nil {
|
if acc, err = r.ReadAccountData(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !bytes.Equal(account1, acc) {
|
if !bytes.Equal(account1, acc) {
|
||||||
t.Errorf("wrong account after block %d, expected %x, got %x", blockNum, account1, acc)
|
t.Errorf("wrong account after block %d, expected %x, got %x", blockNum, account1, acc)
|
||||||
}
|
}
|
||||||
var code []byte
|
var code []byte
|
||||||
if code, err = r.ReadAccountCode(accountKey); err != nil {
|
if code, err = r.ReadAccountCode(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if !bytes.Equal(code1, code) {
|
if !bytes.Equal(code1, code) {
|
||||||
@ -352,7 +352,7 @@ func TestChangeCode(t *testing.T) {
|
|||||||
}
|
}
|
||||||
case 47:
|
case 47:
|
||||||
var code []byte
|
var code []byte
|
||||||
if code, err = r.ReadAccountCode(accountKey); err != nil {
|
if code, err = r.ReadAccountCode(accountKey, false /* trace */); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if code != nil {
|
if code != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user