suite

package
v0.6.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 9, 2020 License: Apache-2.0 Imports: 13 Imported by: 0

Documentation

Index

Constants

View Source
const BatchSize = 100
View Source
const Iterations = 500_000

Variables

View Source
var Concurrency = runtime.NumCPU()
View Source
var FunctionBenchmarks = []bm.Bm{

	{
		CreateStore: true,
		Name:        "sequential write (baseline)",
		Concurrency: Concurrency,
		Iterations:  1_000_000,
		Work: func(bm *bm.Bm, start int, end int) error {
			for i := start; i < end; i++ {
				kv := schema.KeyValue{Key: []byte(strconv.FormatUint(uint64(i), 10)), Value: V}
				if _, err := bm.Store.Set(kv); err != nil {
					return err
				}
			}
			return nil
		},
	},
	{
		CreateStore: true,
		Name:        "sequential write (async commit)",
		Concurrency: Concurrency,
		Iterations:  1_000_000,
		Work: func(bm *bm.Bm, start int, end int) error {
			opt := store.WithAsyncCommit(true)
			for i := start; i < end; i++ {
				kv := schema.KeyValue{Key: []byte(strconv.FormatUint(uint64(i), 10)), Value: V}
				if _, err := bm.Store.Set(kv, opt); err != nil {
					return err
				}
			}
			return nil
		},
	},
	{
		CreateStore: true,
		Name:        "sequential write (concurrency++)",
		Concurrency: Concurrency * 8,
		Iterations:  1_000_000,
		Work: func(bm *bm.Bm, start int, end int) error {
			for i := start; i < end; i++ {
				kv := schema.KeyValue{Key: []byte(strconv.FormatUint(uint64(i), 10)), Value: V}
				if _, err := bm.Store.Set(kv); err != nil {
					return err
				}
			}
			return nil
		},
	},
	{
		CreateStore: true,
		Name:        "sequential write (async commit / concurrency++)",
		Concurrency: Concurrency * 8,
		Iterations:  1_000_000,
		Work: func(bm *bm.Bm, start int, end int) error {
			opt := store.WithAsyncCommit(true)
			for i := start; i < end; i++ {
				kv := schema.KeyValue{Key: []byte(strconv.FormatUint(uint64(i), 10)), Value: V}
				if _, err := bm.Store.Set(kv, opt); err != nil {
					return err
				}
			}
			return nil
		},
	},
	{
		CreateStore: true,
		Name:        "sequential write (GOMAXPROCS=128 / concurrency++)",
		Concurrency: Concurrency * 8,
		Iterations:  1_000_000,
		Before: func(bm *bm.Bm) {
			maxProcs = runtime.GOMAXPROCS(128)
		},
		After: func(bm *bm.Bm) {
			runtime.GOMAXPROCS(maxProcs)
		},
		Work: func(bm *bm.Bm, start int, end int) error {
			for i := start; i < end; i++ {
				kv := schema.KeyValue{Key: []byte(strconv.FormatUint(uint64(i), 10)), Value: V}
				if _, err := bm.Store.Set(kv); err != nil {
					return err
				}
			}
			return nil
		},
	},
	{
		CreateStore: true,
		Name:        "batch write",

		Concurrency: func() int {
			if Concurrency < 10 {
				return 10
			}
			return Concurrency
		}(),
		Iterations: 1_000_000,

		Work: func(bm *bm.Bm, start int, end int) error {
			list := schema.KVList{}
			for i := start; i < end; i++ {
				list.KVs = append(list.KVs, &schema.KeyValue{
					Key:   []byte(strconv.FormatUint(uint64(i), 10)),
					Value: V,
				})
			}
			if _, err := bm.Store.SetBatch(list); err != nil {
				return err
			}
			return nil
		},
	},
	{
		CreateStore: true,
		Name:        "batch write (async commit)",

		Concurrency: func() int {
			if Concurrency < 10 {
				return 10
			}
			return Concurrency
		}(),
		Iterations: 1_000_000,

		Work: func(bm *bm.Bm, start int, end int) error {
			opt := store.WithAsyncCommit(true)
			list := schema.KVList{}
			for i := start; i < end; i++ {
				list.KVs = append(list.KVs, &schema.KeyValue{
					Key:   []byte(strconv.FormatUint(uint64(i), 10)),
					Value: V,
				})
			}
			if _, err := bm.Store.SetBatch(list, opt); err != nil {
				return err
			}
			return nil
		},
	},
}
View Source
var RpcBenchmarks = []bm.Bm{
	makeRpcBenchmark("sequential write", Concurrency, Iterations, sequentialSet),
	makeRpcBenchmark("batch write", Concurrency, Iterations, batchSet),
	makeRpcBenchmark("batch write no concurrency", 1, Iterations, batchSet),
}
View Source
var V = []byte{0, 1, 3, 4, 5, 6, 7}

Functions

This section is empty.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL