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实现的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-20go-zero 框架的 RPC 服务 启动start和停止 底层是怎么实现的?-icode9专业技术文章分享
- 2024-12-19Go-Zero 框架的 RPC 服务启动和停止的基本机制和过程是怎么实现的?-icode9专业技术文章分享
- 2024-12-18怎么在golang中使用gRPC测试mock数据?-icode9专业技术文章分享
- 2024-12-15掌握PageRank算法核心!你离Google优化高手只差一步!
- 2024-12-15GORM 中的标签 gorm:"index"是什么?-icode9专业技术文章分享
- 2024-12-11怎么在 Go 语言中获取 Open vSwitch (OVS) 的桥接信息(Bridge)?-icode9专业技术文章分享
- 2024-12-11怎么用Go 语言的库来与 Open vSwitch 进行交互?-icode9专业技术文章分享
- 2024-12-11怎么在 go-zero 项目中发送阿里云短信?-icode9专业技术文章分享
- 2024-12-11怎么使用阿里云 Go SDK (alibaba-cloud-sdk-go) 发送短信?-icode9专业技术文章分享
- 2024-12-10搭建个人博客网站之一、使用hugo创建个人博客网站