mirror of https://github.com/milvus-io/milvus.git
98 lines
2.3 KiB
Go
98 lines
2.3 KiB
Go
package msgstream
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"math/rand"
|
|
"os"
|
|
"sync"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/milvus-io/milvus/pkg/mq/common"
|
|
"github.com/milvus-io/milvus/pkg/mq/msgstream/mqwrapper"
|
|
"github.com/milvus-io/milvus/pkg/mq/msgstream/mqwrapper/nmq"
|
|
"github.com/milvus-io/milvus/pkg/util/funcutil"
|
|
"github.com/milvus-io/milvus/pkg/util/paramtable"
|
|
)
|
|
|
|
func BenchmarkProduceAndConsumeNatsMQ(b *testing.B) {
|
|
storeDir, err := os.MkdirTemp("", "milvus_mq_nmq")
|
|
assert.NoError(b, err)
|
|
defer os.RemoveAll(storeDir)
|
|
|
|
paramtable.Init()
|
|
cfg := nmq.ParseServerOption(paramtable.Get())
|
|
cfg.Opts.StoreDir = storeDir
|
|
nmq.MustInitNatsMQ(cfg)
|
|
|
|
client, err := nmq.NewClientWithDefaultOptions(context.Background())
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
cases := generateRandBytes(64*1024, 10000)
|
|
b.ResetTimer()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
benchmarkProduceAndConsume(b, client, cases)
|
|
}
|
|
}
|
|
|
|
func benchmarkProduceAndConsume(b *testing.B, mqClient mqwrapper.Client, cases [][]byte) {
|
|
topic := fmt.Sprintf("test_produce_and_consume_topic_%d", rand.Int31n(100000))
|
|
wg := sync.WaitGroup{}
|
|
wg.Add(2)
|
|
|
|
go func() {
|
|
defer wg.Done()
|
|
p, err := mqClient.CreateProducer(common.ProducerOptions{
|
|
Topic: topic,
|
|
})
|
|
assert.NoError(b, err)
|
|
defer p.Close()
|
|
benchmarkMQProduce(b, p, cases)
|
|
}()
|
|
go func() {
|
|
defer wg.Done()
|
|
c, _ := mqClient.Subscribe(mqwrapper.ConsumerOptions{
|
|
Topic: topic,
|
|
SubscriptionName: topic,
|
|
SubscriptionInitialPosition: common.SubscriptionPositionEarliest,
|
|
BufSize: 1024,
|
|
})
|
|
defer c.Close()
|
|
benchmarkMQConsume(b, c, cases)
|
|
}()
|
|
wg.Wait()
|
|
}
|
|
|
|
func benchmarkMQConsume(b *testing.B, c mqwrapper.Consumer, cases [][]byte) {
|
|
ch := c.Chan()
|
|
for range cases {
|
|
msg := <-ch
|
|
c.Ack(msg)
|
|
}
|
|
c.Close()
|
|
}
|
|
|
|
func benchmarkMQProduce(b *testing.B, p mqwrapper.Producer, cases [][]byte) {
|
|
for _, c := range cases {
|
|
p.Send(context.Background(), &common.ProducerMessage{
|
|
Payload: c,
|
|
})
|
|
}
|
|
}
|
|
|
|
func generateRandBytes(m int, n int) [][]byte {
|
|
letterRunes := funcutil.RandomBytes(2 * m)
|
|
cases := make([][]byte, 0, n)
|
|
for i := 0; i < n; i++ {
|
|
startOffset := rand.Intn(m)
|
|
endOffset := startOffset + m
|
|
|
|
cases = append(cases, letterRunes[startOffset:endOffset])
|
|
}
|
|
return cases
|
|
}
|