mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
8205166009
--- FAIL: TestNameList (0.00s) panic: exec: "redis-server": executable file not found in $PATH [recovered] panic: exec: "redis-server": executable file not found in $PATH goroutine 37 [running]: testing.tRunner.func1.2({0xde2f80, 0xc0003da160}) /opt/hostedtoolcache/go/1.17.1/x64/src/testing/testing.go:1209 +0x24e testing.tRunner.func1() /opt/hostedtoolcache/go/1.17.1/x64/src/testing/testing.go:1212 +0x218 panic({0xde2f80, 0xc0003da160}) /opt/hostedtoolcache/go/1.17.1/x64/src/runtime/panic.go:1038 +0x215 github.com/chrislusf/seaweedfs/weed/filer/redis3.TestNameList(0x407c59) /home/runner/work/seaweedfs/seaweedfs/weed/filer/redis3/kv_directory_children_test.go:45 +0x376 testing.tRunner(0xc0003e2680, 0xf57f48) /opt/hostedtoolcache/go/1.17.1/x64/src/testing/testing.go:1259 +0x102 created by testing.(*T).Run /opt/hostedtoolcache/go/1.17.1/x64/src/testing/testing.go:1306 +0x35a
211 lines
4.1 KiB
Go
211 lines
4.1 KiB
Go
package redis3
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"github.com/go-redis/redis/v8"
|
|
"github.com/stvp/tempredis"
|
|
"strconv"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
var names = []string{
|
|
"cassandra.in.sh",
|
|
"cassandra",
|
|
"debug-cql.bat",
|
|
"nodetool",
|
|
"nodetool.bat",
|
|
"source-conf.ps1",
|
|
"sstableloader",
|
|
"sstableloader.bat",
|
|
"sstablescrub",
|
|
"sstablescrub.bat",
|
|
"sstableupgrade",
|
|
"sstableupgrade.bat",
|
|
"sstableutil",
|
|
"sstableutil.bat",
|
|
"sstableverify",
|
|
"sstableverify.bat",
|
|
"stop-server",
|
|
"stop-server.bat",
|
|
"stop-server.ps1",
|
|
"cassandra.in.bat",
|
|
"cqlsh.py",
|
|
"cqlsh",
|
|
"cassandra.ps1",
|
|
"cqlsh.bat",
|
|
"debug-cql",
|
|
"cassandra.bat",
|
|
}
|
|
|
|
func xTestNameList(t *testing.T) {
|
|
server, err := tempredis.Start(tempredis.Config{})
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer server.Term()
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
Network: "unix",
|
|
Addr: server.Socket(),
|
|
})
|
|
|
|
store := newSkipListElementStore("/yyy/bin", client)
|
|
var data []byte
|
|
for _, name := range names {
|
|
nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit)
|
|
nameList.WriteName(name)
|
|
|
|
nameList.ListNames("", func(name string) bool {
|
|
println(name)
|
|
return true
|
|
})
|
|
|
|
if nameList.HasChanges() {
|
|
data = nameList.ToBytes()
|
|
}
|
|
println()
|
|
}
|
|
|
|
nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit)
|
|
nameList.ListNames("", func(name string) bool {
|
|
println(name)
|
|
return true
|
|
})
|
|
|
|
}
|
|
|
|
func xBenchmarkNameList(b *testing.B) {
|
|
|
|
server, err := tempredis.Start(tempredis.Config{})
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer server.Term()
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
Network: "unix",
|
|
Addr: server.Socket(),
|
|
})
|
|
|
|
store := newSkipListElementStore("/yyy/bin", client)
|
|
var data []byte
|
|
for i := 0; i < b.N; i++ {
|
|
nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit)
|
|
|
|
nameList.WriteName(strconv.Itoa(i) + "namexxxxxxxxxxxxxxxxxxx")
|
|
|
|
if nameList.HasChanges() {
|
|
data = nameList.ToBytes()
|
|
}
|
|
}
|
|
}
|
|
|
|
func BenchmarkRedis(b *testing.B) {
|
|
|
|
server, err := tempredis.Start(tempredis.Config{})
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer server.Term()
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
Network: "unix",
|
|
Addr: server.Socket(),
|
|
})
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
client.ZAddNX(context.Background(), "/yyy/bin", &redis.Z{Score: 0, Member: strconv.Itoa(i) + "namexxxxxxxxxxxxxxxxxxx"})
|
|
}
|
|
}
|
|
|
|
func xTestNameListAdd(t *testing.T) {
|
|
|
|
server, err := tempredis.Start(tempredis.Config{})
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer server.Term()
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
Addr: "localhost:6379",
|
|
Password: "",
|
|
DB: 0,
|
|
})
|
|
|
|
client.FlushAll(context.Background())
|
|
|
|
N := 364800
|
|
|
|
ts0 := time.Now()
|
|
store := newSkipListElementStore("/y", client)
|
|
var data []byte
|
|
nameList := LoadItemList(data, "/y", client, store, 100000)
|
|
for i := 0; i < N; i++ {
|
|
nameList.WriteName(fmt.Sprintf("%8d", i))
|
|
}
|
|
|
|
ts1 := time.Now()
|
|
|
|
for i := 0; i < N; i++ {
|
|
client.ZAddNX(context.Background(), "/x", &redis.Z{Score: 0, Member: fmt.Sprintf("name %8d", i)})
|
|
}
|
|
ts2 := time.Now()
|
|
|
|
fmt.Printf("%v %v", ts1.Sub(ts0), ts2.Sub(ts1))
|
|
|
|
/*
|
|
keys := client.Keys(context.Background(), "/*m").Val()
|
|
for _, k := range keys {
|
|
println("key", k)
|
|
for i, v := range client.ZRangeByLex(context.Background(), k, &redis.ZRangeBy{
|
|
Min: "-",
|
|
Max: "+",
|
|
}).Val() {
|
|
println(" ", i, v)
|
|
}
|
|
}
|
|
*/
|
|
}
|
|
|
|
func xBenchmarkNameList(b *testing.B) {
|
|
|
|
server, err := tempredis.Start(tempredis.Config{})
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer server.Term()
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
Addr: "localhost:6379",
|
|
Password: "",
|
|
DB: 0,
|
|
})
|
|
|
|
store := newSkipListElementStore("/yyy/bin", client)
|
|
var data []byte
|
|
for i := 0; i < b.N; i++ {
|
|
nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit)
|
|
|
|
nameList.WriteName(fmt.Sprintf("name %8d", i))
|
|
|
|
if nameList.HasChanges() {
|
|
data = nameList.ToBytes()
|
|
}
|
|
}
|
|
}
|
|
|
|
func xBenchmarkRedis(b *testing.B) {
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
Addr: "localhost:6379",
|
|
Password: "",
|
|
DB: 0,
|
|
})
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
client.ZAddNX(context.Background(), "/xxx/bin", &redis.Z{Score: 0, Member: fmt.Sprintf("name %8d", i)})
|
|
}
|
|
}
|