1 Star 1 Fork 0

凡卡 / libp2parea

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
bindcachedata.go 1.37 KB
一键复制 编辑 原始数据 按行查看 历史
凡卡 提交于 2023-11-29 11:01 . first commit
package raft
import (
"time"
cached "gitee.com/prestonTao/libp2parea/cache/cachedata"
"gitee.com/prestonTao/utils"
)
func init() {
go func() {
ticker := time.NewTicker(5 * time.Second)
defer ticker.Stop()
for {
<-ticker.C
RD.Team.Range(func(k, v interface{}) bool {
team, ok := v.(RaftTeam)
if !ok {
return false
}
if team.Role.Role == Leader {
syncData(team.TeamId)
}
return true
})
}
}()
}
// 初始化cachedata
func bindCacheData() {
cached.Register()
}
// 同步数据
func syncData(teamid *utils.Multihash) {
cached.SyncDataToQuarterLogicIds(teamid)
}
// 增加数据
func Add(key, value []byte) {
cachedata := cached.BuildCacheData(key, value)
//cachedata.AddOwnId(nodeStore.NodeSelf.IdInfo.Id)
//保存数据
cached.Save(cachedata)
teamid := BuildHash(key)
//广播出去
go cached.SyncDataToQuarterLogicIds(teamid)
FirstTeam(teamid)
}
// 修改数据
func Update(key, value []byte) {
cachedata := cached.BuildCacheData(key, value)
//保存数据
cached.Save(cachedata)
teamid := BuildHash(key)
//广播出去
go cached.SyncDataToQuarterLogicIds(teamid)
}
// 删除数据
func Del(key []byte) {
teamid := BuildHash(key)
cachedata := cached.GetCacheDataByHash(teamid)
if cachedata == nil {
return
}
cachedata.Del = true
//广播出去
go cached.SyncCacheDataToQuarterLogicIds(cachedata)
cached.Del(key)
}
Go
1
https://gitee.com/prestonTao/libp2parea.git
git@gitee.com:prestonTao/libp2parea.git
prestonTao
libp2parea
libp2parea
58a2b3547940

搜索帮助

53164aa7 5694891 3bd8fe86 5694891