msg slice storage

pull/103/head
Gordon 3 years ago
parent 5782b85b02
commit 8d7897cd1e

@ -8,11 +8,13 @@ import (
"errors" "errors"
"github.com/golang/protobuf/proto" "github.com/golang/protobuf/proto"
"gopkg.in/mgo.v2/bson" "gopkg.in/mgo.v2/bson"
"strconv"
"time" "time"
) )
const cChat = "chat" const cChat = "chat"
const cGroup = "group" const cGroup = "group"
const singleGocMsgNum = 10000
type MsgInfo struct { type MsgInfo struct {
SendTime int64 SendTime int64
@ -86,7 +88,8 @@ func (d *DataBases) GetMsgBySeqRange(uid string, seqBegin, seqEnd int64) (Single
return SingleMsg, GroupMsg, MaxSeq, MinSeq, nil return SingleMsg, GroupMsg, MaxSeq, MinSeq, nil
} }
func (d *DataBases) GetMsgBySeqList(uid string, seqList []int64) (SingleMsg []*pbMsg.MsgFormat, GroupMsg []*pbMsg.MsgFormat, MaxSeq int64, MinSeq int64, err error) { func (d *DataBases) GetMsgBySeqList(uid string, seqList []int64) (SingleMsg []*pbMsg.MsgFormat, GroupMsg []*pbMsg.MsgFormat, MaxSeq int64, MinSeq int64, err error) {
count := 0 allCount := 0
singleCount := 0
session := d.mgoSession.Clone() session := d.mgoSession.Clone()
if session == nil { if session == nil {
return nil, nil, MaxSeq, MinSeq, errors.New("session == nil") return nil, nil, MaxSeq, MinSeq, errors.New("session == nil")
@ -94,54 +97,75 @@ func (d *DataBases) GetMsgBySeqList(uid string, seqList []int64) (SingleMsg []*p
defer session.Close() defer session.Close()
c := session.DB(config.Config.Mongo.DBDatabase).C(cChat) c := session.DB(config.Config.Mongo.DBDatabase).C(cChat)
m := func(uid string, seqList []int64) map[string][]int64 {
t := make(map[string][]int64)
for i := 0; i < len(seqList); i++ {
seqUid := getSeqUid(uid, seqList[i])
if value, ok := t[seqUid]; !ok {
var temp []int64
t[seqUid] = append(temp, seqList[i])
} else {
t[seqUid] = append(value, seqList[i])
}
}
return t
}(uid, seqList)
sChat := UserChat{} sChat := UserChat{}
if err = c.Find(bson.M{"uid": uid}).One(&sChat); err != nil {
return nil, nil, MaxSeq, MinSeq, err
}
pChat := pbMsg.MsgSvrToPushSvrChatMsg{} pChat := pbMsg.MsgSvrToPushSvrChatMsg{}
for i := 0; i < len(sChat.Msg); i++ { for seqUid, value := range m {
temp := new(pbMsg.MsgFormat) if err = c.Find(bson.M{"uid": seqUid}).One(&sChat); err != nil {
if err = proto.Unmarshal(sChat.Msg[i].Msg, &pChat); err != nil { log.NewError("", "not find seqUid", seqUid, value, uid, seqList)
return nil, nil, MaxSeq, MinSeq, err continue
} }
if isContainInt64(pChat.RecvSeq, seqList) { singleCount = 0
temp.SendID = pChat.SendID for i := 0; i < len(sChat.Msg); i++ {
temp.RecvID = pChat.RecvID temp := new(pbMsg.MsgFormat)
temp.MsgFrom = pChat.MsgFrom if err = proto.Unmarshal(sChat.Msg[i].Msg, &pChat); err != nil {
temp.Seq = pChat.RecvSeq log.NewError("", "not find seqUid", seqUid, value, uid, seqList)
temp.ServerMsgID = pChat.MsgID return nil, nil, MaxSeq, MinSeq, err
temp.SendTime = pChat.SendTime
temp.Content = pChat.Content
temp.ContentType = pChat.ContentType
temp.SenderPlatformID = pChat.PlatformID
temp.ClientMsgID = pChat.ClientMsgID
temp.SenderFaceURL = pChat.SenderFaceURL
temp.SenderNickName = pChat.SenderNickName
if pChat.RecvSeq > MaxSeq {
MaxSeq = pChat.RecvSeq
} }
if count == 0 { if isContainInt64(pChat.RecvSeq, value) {
MinSeq = pChat.RecvSeq temp.SendID = pChat.SendID
} temp.RecvID = pChat.RecvID
if pChat.RecvSeq < MinSeq { temp.MsgFrom = pChat.MsgFrom
MinSeq = pChat.RecvSeq temp.Seq = pChat.RecvSeq
} temp.ServerMsgID = pChat.MsgID
if pChat.SessionType == constant.SingleChatType { temp.SendTime = pChat.SendTime
SingleMsg = append(SingleMsg, temp) temp.Content = pChat.Content
} else { temp.ContentType = pChat.ContentType
GroupMsg = append(GroupMsg, temp) temp.SenderPlatformID = pChat.PlatformID
} temp.ClientMsgID = pChat.ClientMsgID
count++ temp.SenderFaceURL = pChat.SenderFaceURL
if count == len(seqList) { temp.SenderNickName = pChat.SenderNickName
break if pChat.RecvSeq > MaxSeq {
MaxSeq = pChat.RecvSeq
}
if allCount == 0 {
MinSeq = pChat.RecvSeq
}
if pChat.RecvSeq < MinSeq {
MinSeq = pChat.RecvSeq
}
if pChat.SessionType == constant.SingleChatType {
SingleMsg = append(SingleMsg, temp)
} else {
GroupMsg = append(GroupMsg, temp)
}
allCount++
singleCount++
if singleCount == len(value) {
break
}
} }
} }
if allCount == len(seqList) {
break
}
} }
return SingleMsg, GroupMsg, MaxSeq, MinSeq, nil return SingleMsg, GroupMsg, MaxSeq, MinSeq, nil
} }
func (d *DataBases) SaveUserChat(uid string, sendTime int64, m proto.Message) error { func (d *DataBases) SaveUserChat(uid string, sendTime int64, m *pbMsg.MsgSvrToPushSvrChatMsg) error {
var seqUid string
newTime := getCurrentTimestampByMill() newTime := getCurrentTimestampByMill()
session := d.mgoSession.Clone() session := d.mgoSession.Clone()
if session == nil { if session == nil {
@ -150,8 +174,8 @@ func (d *DataBases) SaveUserChat(uid string, sendTime int64, m proto.Message) er
defer session.Close() defer session.Close()
log.NewInfo("", "get mgoSession cost time", getCurrentTimestampByMill()-newTime) log.NewInfo("", "get mgoSession cost time", getCurrentTimestampByMill()-newTime)
c := session.DB(config.Config.Mongo.DBDatabase).C(cChat) c := session.DB(config.Config.Mongo.DBDatabase).C(cChat)
seqUid = getSeqUid(uid, m.RecvSeq)
n, err := c.Find(bson.M{"uid": uid}).Count() n, err := c.Find(bson.M{"uid": seqUid}).Count()
if err != nil { if err != nil {
return err return err
} }
@ -161,17 +185,16 @@ func (d *DataBases) SaveUserChat(uid string, sendTime int64, m proto.Message) er
if sMsg.Msg, err = proto.Marshal(m); err != nil { if sMsg.Msg, err = proto.Marshal(m); err != nil {
return err return err
} }
if n == 0 { if n == 0 {
sChat := UserChat{} sChat := UserChat{}
sChat.UID = uid sChat.UID = seqUid
sChat.Msg = append(sChat.Msg, sMsg) sChat.Msg = append(sChat.Msg, sMsg)
err = c.Insert(&sChat) err = c.Insert(&sChat)
if err != nil { if err != nil {
return err return err
} }
} else { } else {
err = c.Update(bson.M{"uid": uid}, bson.M{"$push": bson.M{"msg": sMsg}}) err = c.Update(bson.M{"uid": seqUid}, bson.M{"$push": bson.M{"msg": sMsg}})
if err != nil { if err != nil {
return err return err
} }
@ -304,3 +327,7 @@ func isContainInt64(target int64, List []int64) bool {
func getCurrentTimestampByMill() int64 { func getCurrentTimestampByMill() int64 {
return time.Now().UnixNano() / 1e6 return time.Now().UnixNano() / 1e6
} }
func getSeqUid(uid string, seq int64) string {
seqSuffix := seq / singleGocMsgNum
return uid + ":" + strconv.FormatInt(seqSuffix, 10)
}

Loading…
Cancel
Save