Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 10 additions & 16 deletions bench/store_bench_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,8 @@ import (
"testing"
"time"

pb2 "github.com/cockroachdb/pebble"
"github.com/cockroachdb/pebble/bloom"
pb2 "github.com/cockroachdb/pebble/v2"
"github.com/cockroachdb/pebble/v2/bloom"
"github.com/ipni/go-indexer-core"
"github.com/ipni/go-indexer-core/store/memory"
"github.com/ipni/go-indexer-core/store/pebble"
Expand Down Expand Up @@ -85,7 +85,7 @@ func newPebbleSubject(b *testing.B) func() (indexer.Interface, error) {
pebbleOpts := &pb2.Options{
BytesPerSync: 10 << 20, // 10 MiB
WALBytesPerSync: 10 << 20, // 10 MiB
MaxConcurrentCompactions: func() int { return 10 },
CompactionConcurrencyRange: func() (int, int) { return 1, 10 },
MemTableSize: 64 << 20, // 64 MiB
MemTableStopWritesThreshold: 4,
LBaseMaxBytes: 64 << 20, // 64 MiB
Expand All @@ -96,21 +96,15 @@ func newPebbleSubject(b *testing.B) func() (indexer.Interface, error) {

pebbleOpts.Experimental.ReadCompactionRate = 10 << 20 // 20 MiB

const numLevels = 7
pebbleOpts.Levels = make([]pb2.LevelOptions, numLevels)
for i := 0; i < numLevels; i++ {
l := &pebbleOpts.Levels[i]
l.BlockSize = 32 << 10 // 32 KiB
l.IndexBlockSize = 256 << 10 // 256 KiB
l.FilterPolicy = bloom.FilterPolicy(10)
l.FilterType = pb2.TableFilter
if i > 0 {
l.TargetFileSize = pebbleOpts.Levels[i-1].TargetFileSize * 2
}
l.EnsureDefaults()
for i := range pebbleOpts.Levels {
pebbleOpts.Levels[i].BlockSize = 32 << 10 // 32 KiB
pebbleOpts.Levels[i].IndexBlockSize = 256 << 10 // 256 KiB
pebbleOpts.Levels[i].FilterPolicy = bloom.FilterPolicy(10)
pebbleOpts.Levels[i].FilterType = pb2.TableFilter
}
pebbleOpts.Levels[numLevels-1].FilterPolicy = nil
pebbleOpts.Levels[len(pebbleOpts.Levels)-1].FilterPolicy = nil
pebbleOpts.Cache = pb2.NewCache(1 << 30) // 1 GiB
pebbleOpts.EnsureDefaults()

return pebble.New(b.TempDir(), pebbleOpts)
}
Expand Down
37 changes: 20 additions & 17 deletions go.mod
Original file line number Diff line number Diff line change
@@ -1,44 +1,47 @@
module github.com/ipni/go-indexer-core

go 1.24.0
go 1.24.6

require (
github.com/cockroachdb/pebble v1.1.5
github.com/cockroachdb/pebble/v2 v2.1.0
github.com/gammazero/radixtree v0.4.0
github.com/ipfs/go-cid v0.5.0
github.com/ipfs/go-log/v2 v2.8.1
github.com/ipfs/go-log/v2 v2.8.2
github.com/ipfs/go-test v0.2.3
github.com/ipni/go-libipni v0.7.0
github.com/libp2p/go-libp2p v0.43.0
github.com/ipni/go-libipni v0.7.1
github.com/libp2p/go-libp2p v0.44.0
github.com/mr-tron/base58 v1.2.0
github.com/multiformats/go-multihash v0.2.3
github.com/multiformats/go-varint v0.0.7
github.com/multiformats/go-varint v0.1.0
go.opencensus.io v0.24.0
lukechampine.com/blake3 v1.4.1
)

require (
github.com/DataDog/zstd v1.5.6-0.20230824185856-869dae002e5e // indirect
github.com/DataDog/zstd v1.5.7 // indirect
github.com/RaduBerinde/axisds v0.0.0-20250419182453-5135a0650657 // indirect
github.com/RaduBerinde/btreemap v0.0.0-20250419174037-3d62b7205d54 // indirect
github.com/beorn7/perks v1.0.1 // indirect
github.com/cespare/xxhash/v2 v2.3.0 // indirect
github.com/cockroachdb/datadriven v1.0.3-0.20240530155848-7682d40af056 // indirect
github.com/cockroachdb/crlib v0.0.0-20241112164430-1264a2edc35b // indirect
github.com/cockroachdb/errors v1.11.3 // indirect
github.com/cockroachdb/fifo v0.0.0-20240606204812-0bbfbd93a7ce // indirect
github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b // indirect
github.com/cockroachdb/redact v1.1.5 // indirect
github.com/cockroachdb/swiss v0.0.0-20250624142022-d6e517c1d961 // indirect
github.com/cockroachdb/tokenbucket v0.0.0-20230807174530-cc333fc44b06 // indirect
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.4.0 // indirect
github.com/getsentry/sentry-go v0.27.0 // indirect
github.com/gogo/protobuf v1.3.2 // indirect
github.com/golang/snappy v0.0.5-0.20231225225746-43d5d4cd4e0e // indirect
github.com/ipfs/boxo v0.32.0 // indirect
github.com/ipfs/go-block-format v0.2.2 // indirect
github.com/ipfs/boxo v0.34.0 // indirect
github.com/ipfs/go-block-format v0.2.3 // indirect
github.com/klauspost/compress v1.18.0 // indirect
github.com/klauspost/cpuid/v2 v2.2.10 // indirect
github.com/klauspost/cpuid/v2 v2.3.0 // indirect
github.com/kr/pretty v0.3.1 // indirect
github.com/kr/text v0.2.0 // indirect
github.com/libp2p/go-buffer-pool v0.1.0 // indirect
github.com/mattn/go-isatty v0.0.20 // indirect
github.com/minio/minlz v1.0.1-0.20250507153514-87eb42fe8882 // indirect
github.com/minio/sha256-simd v1.0.1 // indirect
github.com/multiformats/go-base32 v0.1.0 // indirect
github.com/multiformats/go-base36 v0.2.0 // indirect
Expand All @@ -47,17 +50,17 @@ require (
github.com/multiformats/go-multicodec v0.9.2 // indirect
github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect
github.com/pkg/errors v0.9.1 // indirect
github.com/prometheus/client_golang v1.22.0 // indirect
github.com/prometheus/client_golang v1.23.0 // indirect
github.com/prometheus/client_model v0.6.2 // indirect
github.com/prometheus/common v0.64.0 // indirect
github.com/prometheus/procfs v0.16.1 // indirect
github.com/prometheus/common v0.65.0 // indirect
github.com/prometheus/procfs v0.17.0 // indirect
github.com/rogpeppe/go-internal v1.10.0 // indirect
github.com/spaolacci/murmur3 v1.1.0 // indirect
go.uber.org/multierr v1.11.0 // indirect
go.uber.org/zap v1.27.0 // indirect
golang.org/x/crypto v0.42.0 // indirect
golang.org/x/exp v0.0.0-20250718183923-645b1fa84792 // indirect
golang.org/x/exp v0.0.0-20250813145105-42675adae3e6 // indirect
golang.org/x/sys v0.36.0 // indirect
golang.org/x/text v0.29.0 // indirect
google.golang.org/protobuf v1.36.6 // indirect
google.golang.org/protobuf v1.36.10 // indirect
)
Loading