-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.go
105 lines (87 loc) · 2.87 KB
/
test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
package main
import (
"context"
"flag"
"fmt"
"log"
"time"
"github.com/juguagua/lcache"
)
func main() {
// 添加命令行参数,用于区分不同节点
port := flag.Int("port", 8001, "节点端口")
nodeID := flag.String("node", "A", "节点标识符")
flag.Parse()
addr := fmt.Sprintf(":%d", *port)
log.Printf("[节点%s] 启动,地址: %s", *nodeID, addr)
// 创建节点
node, err := lcache.NewServer(addr, "lcache",
lcache.WithEtcdEndpoints([]string{"localhost:2379"}),
lcache.WithDialTimeout(5*time.Second),
)
if err != nil {
log.Fatal("创建节点失败:", err)
}
// 创建节点选择器
picker, err := lcache.NewClientPicker(addr)
if err != nil {
log.Fatal("创建节点选择器失败:", err)
}
// 创建缓存组
group := lcache.NewGroup("test", 2<<20, lcache.GetterFunc(
func(ctx context.Context, key string) ([]byte, error) {
log.Printf("[节点%s] 触发数据源加载: key=%s", *nodeID, key)
return []byte(fmt.Sprintf("节点%s的数据源值", *nodeID)), nil
}),
)
// 注册节点选择器
group.RegisterPeers(picker)
// 启动节点
go func() {
log.Printf("[节点%s] 开始启动服务...", *nodeID)
if err := node.Start(); err != nil {
log.Fatal("启动节点失败:", err)
}
}()
// 等待节点注册完成
log.Printf("[节点%s] 等待节点注册...", *nodeID)
time.Sleep(5 * time.Second)
ctx := context.Background()
// 设置本节点的特定键值对
localKey := fmt.Sprintf("key_%s", *nodeID)
localValue := []byte(fmt.Sprintf("这是节点%s的数据", *nodeID))
fmt.Printf("\n=== 节点%s:设置本地数据 ===\n", *nodeID)
err = group.Set(ctx, localKey, localValue)
if err != nil {
log.Fatal("设置本地数据失败:", err)
}
fmt.Printf("节点%s: 设置键 %s 成功\n", *nodeID, localKey)
// 等待其他节点也完成设置
log.Printf("[节点%s] 等待其他节点准备就绪...", *nodeID)
time.Sleep(30 * time.Second)
// 打印当前已发现的节点
picker.PrintPeers()
// 测试获取本地数据
fmt.Printf("\n=== 节点%s:获取本地数据 ===\n", *nodeID)
if val, err := group.Get(ctx, localKey); err == nil {
fmt.Printf("节点%s: 获取本地键 %s 成功: %s\n", *nodeID, localKey, val.String())
} else {
fmt.Printf("节点%s: 获取本地键失败: %v\n", *nodeID, err)
}
// 测试获取其他节点的数据
otherKeys := []string{"key_A", "key_B", "key_C"}
for _, key := range otherKeys {
if key == localKey {
continue // 跳过本节点的键
}
fmt.Printf("\n=== 节点%s:尝试获取远程数据 %s ===\n", *nodeID, key)
log.Printf("[节点%s] 开始查找键 %s 的远程节点", *nodeID, key)
if val, err := group.Get(ctx, key); err == nil {
fmt.Printf("节点%s: 获取远程键 %s 成功: %s\n", *nodeID, key, val.String())
} else {
fmt.Printf("节点%s: 获取远程键失败: %v\n", *nodeID, err)
}
}
// 保持程序运行
select {}
}