Go语言实现长连接并发框架 - 任务管理器

文章目录

前言

你好,我是醉墨居士,我们上篇博客实现了路由分组的功能,接下来这篇博客我们将要实现任务管理模块

接口

trait/task_mgr.go

go 复制代码
type TaskMgr interface {
	RouterGroup

	Start()
	StartWorker(taskQueue chan Request)
	Submit(request Request)
}

结构体

gcore/task_mgr.go

go 复制代码
// TaskMgr 任务管理器
type TaskMgr struct {
	trait.RouterGroup

	taskQueues []chan trait.Request
}

// NewTaskMgr 创建任务管理器
func NewTaskMgr() trait.TaskMgr {
	taskQueues := make([]chan trait.Request, global.Config.TaskQueues)
	for i := 0; i < len(taskQueues); i++ {
		taskQueues[i] = make(chan trait.Request, global.Config.TaskQueueLen)
	}

	// 新建任务处理路由器与分组路由
	router := NewRouter()
	routerGroup := NewRouterGroup(router)

	return &TaskMgr{
		RouterGroup: routerGroup,
		taskQueues: taskQueues,
	}
}

接口实现

gcore/task_mgr.go

go 复制代码
// Start 启动任务管理器
func (m *TaskMgr) Start() {
	for i := 0; i < len(m.taskQueues); i++ {
		for j := 0; j < global.Config.WorkersPerTaskQueue; j++ {
			go m.StartWorker(m.taskQueues[i])
		}
	}
}

// StartWorker 启动任务消费者
func (m *TaskMgr) StartWorker(taskQueue chan trait.Request) {
	for request := range taskQueue {
		flow := m.TaskFlow(request.ID())
		ctx := NewContext(request, flow)
		ctx.Next()
	}
}

// Submit 提交任务
func (m *TaskMgr) Submit(request trait.Request) {
	m.taskQueues[int(request.ConnID()) % len(m.taskQueues)] <- request
}

// Use 注册插件
func (m *TaskMgr) Use(flow ...trait.TaskFunc) {
	m.RouterGroup.Use(flow...)
}

// Regist 注册任务流
func (m *TaskMgr) Regist(id uint16, flow ...trait.TaskFunc) {
	m.RouterGroup.Regist(id, flow...)
}

// Regist 注册任务流
func (m *TaskMgr) RegistFlow(id uint16, flow trait.TaskFlow) {
	m.RouterGroup.RegistFlow(id, flow)
}

项目地址

Github:https://github.com/zm50/gte

Giee:https://gitee.com/zm50/gte

最后

我是醉墨居士,我们完成了基本的任务管理器的开发,希望对你有所帮助,也希望你有所收获

相关推荐
Code blocks3 分钟前
GB28181视频服务wvp部署(一)
java·spring boot·后端
我命由我123459 分钟前
Spring Boot - Spring Boot 静态资源延迟响应(使用拦截器、使用过滤器、使用 ResourceResolver)
java·spring boot·后端·spring·java-ee·intellij-idea·intellij idea
纸带15 分钟前
USB --SETUP --STATUS阶段
linux·服务器·网络
小龙报16 分钟前
《算法通关指南---C++编程篇(2)》
c语言·开发语言·数据结构·c++·程序人生·算法·学习方法
古一|32 分钟前
Vue3中ref与reactive实战指南:使用场景与代码示例
开发语言·javascript·ecmascript
华仔啊41 分钟前
3 分钟让你彻底搞懂 Spring 观察者和发布者模式的本质区别
java·后端
言之。42 分钟前
LiteLLM:让LLM调用变得简单统一
后端·python·flask
---学无止境---43 分钟前
Linux中初始化空循环次数和pid位图初始化
linux
宠友信息44 分钟前
java微服务驱动的社区平台:友猫社区的功能模块与实现逻辑
java·开发语言·微服务
驰羽1 小时前
[GO]golang接口入门:从一个简单示例看懂接口的多态与实现
开发语言·后端·golang