使用go_concurrent_map 管理 并发更新缓存

在后台服务中,为了提速,我在内存还做了一个告诉缓存来管理用户信息,根据更新通知,或者定时去redis中同步信息,那么在加载或者更新某个用户元素时,要防止并发,

当:

1)如果内存缓存没有;

2)去数据库或者redis加载;

3)添加到内存缓存;

这里就有个并发重复的可能性;

所以,这里要做一个加锁的插入或者更新,使用go_concurrent_map就十分方便:

// https://github.com/robinfoxnan/go_concurrent_map
// 这里使用一个支持高并发的map来管理会话
type UserCache struct {
	//lock sync.Mutex

	userMap utils.ConcurrentMap[int64, *User]
}

// 如果没有,则从redis中查找,如果redis中没有,则从数据库中查找
func (uc *UserCache) GetUser(uid int64) (*User, bool) {

	user, err := uc.userMap.Get(uid)
	return user, err
}

// 更新时候的回调函数,如果未设置,则
func updateInsertUser(exist bool, oldUser *User, newUser *User) *User {
	if exist == false {
		return newUser
	} else {
		oldUser.MergeUser(newUser)
		return oldUser
	}
}

// 这里可能会有并发冲突,需要解决的就是session列表需要合并
func (uc *UserCache) SetOrUpdateUser(uid int64, user *User) {
	uc.userMap.Upsert(uid, user, updateInsertUser)
}

这个类在插入时候,可以检测是否存在,并通过回调函数来决定是插入还是更新;这个加锁已经放在插入函数中完成了;

详细代码请查看:GitHub - robinfoxnan/BirdTalkServer: An open source IM system

相关推荐

  1. 使用go_concurrent_map 管理 并发更新缓存

    2024-04-22 11:20:03       15 阅读
  2. 使用Spring管理Caffeine缓存(CacheManager+Caffeine)

    2024-04-22 11:20:03       38 阅读
  3. 缓存更新策略

    2024-04-22 11:20:03       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-22 11:20:03       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-22 11:20:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-22 11:20:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-22 11:20:03       20 阅读

热门阅读

  1. html-docx-js网页转为word格式框架

    2024-04-22 11:20:03       11 阅读
  2. Es6Proxy基础用法

    2024-04-22 11:20:03       16 阅读
  3. 笔记:Python 选择结构练习题

    2024-04-22 11:20:03       17 阅读
  4. tcp inflight 守恒算法(tcp_ccr)

    2024-04-22 11:20:03       13 阅读
  5. 将数据库中的数据接入Echarts图表

    2024-04-22 11:20:03       13 阅读
  6. PostCSS概述

    2024-04-22 11:20:03       15 阅读
  7. 环境感知——自动驾驶模型训练(菜鸟版本)

    2024-04-22 11:20:03       16 阅读
  8. 考研依据数学思维导图,整理出的章节知识大纲

    2024-04-22 11:20:03       15 阅读
  9. ZooKeeper的分布式锁

    2024-04-22 11:20:03       15 阅读
  10. 程序员如何修炼线路

    2024-04-22 11:20:03       51 阅读
  11. 力扣第541题: 反转字符串 II

    2024-04-22 11:20:03       29 阅读