zinx框架分析
服務器流程
1、首先調用Server模塊的NewServer方法初始化一個Server方法
2、在NewServer方法中會初始化Server模塊的
MsgHandler 和 ConnMgr,msgHandler是路由管理模塊。ConnMgr是管理客戶端連接的模塊
?
3、注冊鉤子函數,這兩個函數分別是框架留給用戶的接口方法,用戶處理當有用戶連接進來之后和當用戶斷開鏈接之前需要處理的業務(比如斷開鏈接我們需要進行一些資源的回收)
s.SetOnConnStart(DoConnectionBegin) s.SetOnConnStop(DoConnectionStop)函數原型:
func (IConnection)4、添加消息路由通過Server模塊的AddRouter方法,向模塊的MsgHandler中添加路由
5、最后調用Server模塊的Serve方法,啟動服務器,等待用戶連接
在Serve方法中首先調用Server的start方法,啟動一個tcp監聽的協程,等待用戶連接
然后再調用Server模塊中msgHandler的StartWorkerPool工作池協程
msgHandler的StartWorkerPool協程主要是把客戶端發送來的數據,通過負載均衡算法存放到消息隊列中,排隊等待處理,
工作池主要是為了防止服務器開辟大量的協程,消耗服務器資源,通過控制服務器協程數量,保證服務器穩定性能
StartWorkerPool方法會根據配置文件啟動一定數量的協程首先初始化消息隊列,一個消息隊列對應一個工作協程,工作協程里面一個死循環等待從消息隊列中取出數據,然后發送給對應的路由進行處理
?
?
?
?
總結
- 上一篇: Linux 设备驱动的固件加载
- 下一篇: Linux USB 驱动开发实例(二)—