mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-11-04 19:32:17 +08:00 
			
		
		
		
	
		
			
				
	
	
	
		
			1.4 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			1.4 KiB
		
	
	
	
	
	
	
	
mongo
type Seq struct {
	ConversationID string `bson:"conversation_id"`
	MaxSeq         int64  `bson:"max_seq"`
	MinSeq         int64  `bson:"min_seq"`
}
type Seq interface {
  Malloc(ctx context.Context, conversationID string, size int64) (int64, error)
  GetMaxSeq(ctx context.Context, conversationID string) (int64, error)
  GetMinSeq(ctx context.Context, conversationID string) (int64, error)
  SetMinSeq(ctx context.Context, conversationID string, seq int64) error
}
- Malloc 申请seq数量,返回的已有seq的最大值,消息用的第一个seq是返回值+1
 - GetMaxSeq 获取申请的seq的最大值,在发消息的seq小于这个值
 - GetMinSeq 获取最小的seq,用于拉取历史消息
 - SetMinSeq 设置最小的seq,用于拉取历史消息
 
redis
type RedisSeq struct {
	Curr int64 // 当前的最大seq
	Last int64 // mongodb中申请的最大seq
	Lock *int64 // 锁,用于在mongodb中申请seq
}
- Malloc 申请seq数量,返回的已有seq的最大值,消息用的第一个seq是返回值+1,如果redis中申请数量够用,直接返回,并自增对应数量。如果redis中申请数量不够用,加锁,从mongodb中申请seq。
 - GetMaxSeq 获取已发消息的最大seq就是Curr的值。如果redis中缓存不存在就通过mongodb获取最大seq。存储在redis中。其中Curr和Last都是这个seq值。
 - GetMinSeq, SetMinSeq用之前rockscache的方案。