IM后端项目 Golang实现

2021/12/3 6:06:40

本文主要是介绍IM后端项目 Golang实现,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

架构图示(截选IM部分)

项目源代码示例

 

调试示例(截选)

示例一:消息存储调试

示例二:gorpc消息调试代码

package main

import (
    "fmt"
    "github.com/valyala/gorpc"
    "time"
)

var server_summary *ServerSummary
var storage *Storage
var appid int64 = 0
var device_id int64 = 0
var master *Master
var config *StorageConfig

func main() {
    d := gorpc.NewDispatcher()
    d.AddFunc("SyncMessage", SyncMessage)
    d.AddFunc("SyncGroupMessage", SyncGroupMessage)
    d.AddFunc("SavePeerMessage", SavePeerMessage)
    c := gorpc.NewTCPClient("127.0.0.1:13333") //ims地址
    c.Start()
    defer c.Stop()
    dc := d.NewFuncClient(c)

    //-----------------测试核心代码/-----------------
    /*
        功能说明:模拟对IMS进行RPC调用,方法SavePeerMessage
        主要用作IMS端的调试
        需要注意:IMMessage,Message,PeerMessage三者的区别
    */

    im := &IMMessage{sender: 1, receiver: 1000, timestamp: int32(time.Now().Unix()), msgid: 5, content: "hello"}
    m := &Message{cmd: MSG_IM, seq: 5, version: 2, flag: 0, body: im}

    r, err := dc.Call("SavePeerMessage", &PeerMessage{
        0,
        1000,
        0,
        4,
        m.ToData(),
    })
    if err != nil {
        fmt.Println("调用错误")
    } else {
        fmt.Println(r)
    }
}

消息体定义



这篇关于IM后端项目 Golang实现的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程