forked from mirror/redis
77 lines
1.5 KiB
Go
77 lines
1.5 KiB
Go
package pool_test
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/go-redis/redis/internal/pool"
|
|
)
|
|
|
|
func benchmarkPoolGetPut(b *testing.B, poolSize int) {
|
|
connPool := pool.NewConnPool(&pool.Options{
|
|
Dialer: dummyDialer,
|
|
PoolSize: poolSize,
|
|
PoolTimeout: time.Second,
|
|
IdleTimeout: time.Hour,
|
|
IdleCheckFrequency: time.Hour,
|
|
})
|
|
|
|
b.ResetTimer()
|
|
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
for pb.Next() {
|
|
cn, err := connPool.Get()
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
connPool.Put(cn)
|
|
}
|
|
})
|
|
}
|
|
|
|
func BenchmarkPoolGetPut10Conns(b *testing.B) {
|
|
benchmarkPoolGetPut(b, 10)
|
|
}
|
|
|
|
func BenchmarkPoolGetPut100Conns(b *testing.B) {
|
|
benchmarkPoolGetPut(b, 100)
|
|
}
|
|
|
|
func BenchmarkPoolGetPut1000Conns(b *testing.B) {
|
|
benchmarkPoolGetPut(b, 1000)
|
|
}
|
|
|
|
func benchmarkPoolGetRemove(b *testing.B, poolSize int) {
|
|
connPool := pool.NewConnPool(&pool.Options{
|
|
Dialer: dummyDialer,
|
|
PoolSize: poolSize,
|
|
PoolTimeout: time.Second,
|
|
IdleTimeout: time.Hour,
|
|
IdleCheckFrequency: time.Hour,
|
|
})
|
|
|
|
b.ResetTimer()
|
|
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
for pb.Next() {
|
|
cn, err := connPool.Get()
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
connPool.Remove(cn)
|
|
}
|
|
})
|
|
}
|
|
|
|
func BenchmarkPoolGetRemove10Conns(b *testing.B) {
|
|
benchmarkPoolGetRemove(b, 10)
|
|
}
|
|
|
|
func BenchmarkPoolGetRemove100Conns(b *testing.B) {
|
|
benchmarkPoolGetRemove(b, 100)
|
|
}
|
|
|
|
func BenchmarkPoolGetRemove1000Conns(b *testing.B) {
|
|
benchmarkPoolGetRemove(b, 1000)
|
|
}
|