golang协程池之gopool

简介

goroutine协程,是golang的轻量级线程。协程池利用池化技术,复用对象,减少了内存分配的频率以及协程创建开销。

gopool是字节跳动开源节流的gopkg包中协程池的一个实现。

gopool

github.com/bytedance/g...

gopool是字节官方开源的gopkg库提供的协程池实现

demo try

go 复制代码
gopool.Go(func(){}
    // do your job
)

一探究竟

Task

task是链表结构,记录了待执行任务的信息

go 复制代码
type task struct {
	ctx context.Context
	f   func()

	next *task
}
Worker

worker关联了协程池的实例

Pool

Pool定义了协程池的接口

pool是协程池的实现,包含了task的链表结构。

pool通过workerpool和taskpool来创建worker和task实例

核心逻辑

新增执行任务task时,通过taskpool创建task对象。视需创建worker,执行worker的run方法

css 复制代码
    t := taskPool.Get().(*task)
    // ...
    if () {
        p.incWorkerCount()
        w := workerPool.Get().(*worker)
        w.pool = p
        w.run()
    }

worker执行时,会获取pool锁,从pool中取出待执行任务,执行任务

scss 复制代码
go func() {
		for {
			var t *task
			w.pool.taskLock.Lock()
            // get task
            w.pool.taskLock.Unlock()
            // ...
            t.f()
        }
}
相关配置

pool支持传入ScaleThreshold,当等待任务执行数超过此配置时,创建新的worker

默认实现

defaultPool是pool的默认实现,支持配置容量Cap、panicHandler等

go 复制代码
func SetCap(cap int32) {
	defaultPool.SetCap(cap)
}

func SetPanicHandler(f func(context.Context, interface{})) {
	defaultPool.SetPanicHandler(f)
}

总结

pool是gopool的一个逻辑协程池,管理着待执行的task,可以动态创建worker来多协程并发处理task对象。同时,通过sync.pool来优化了task和worker对象的创建。

相关推荐
言慢行善12 分钟前
SpringBoot中的注解介绍
java·spring boot·后端
小村儿17 分钟前
连载05-Claude Skill 不是抄模板:真正管用的 Skill,都是从实战里提炼出来的
前端·后端·ai编程
光电大美美-见合八方中国芯39 分钟前
用于无色波分复用光网络的 10.7 Gb/s 反射式电吸收调制器与半导体光放大器单片集成
网络·后端·ai·云计算·wpf·信息与通信·模块测试
MX_93591 小时前
Spring MVC拦截器
java·后端·spring·mvc
MgArcher1 小时前
Python高级特性:高阶函数完全指南
后端·面试
databook1 小时前
逃离SQL丛林:实用主义的数据救赎
后端·sql·数据分析
舒一笑2 小时前
AI 系统落地难的,从来不只是模型:一次企业级部署实施复盘
运维·后端·程序员
心勤则明2 小时前
Spring AI Alibaba Skills 的渐进式披露与热更新实战
java·后端·spring
金融数据出海3 小时前
java对接美股股票api涵盖实时行情、K 线、指数等核心接口。
后端
认真的小羽❅3 小时前
从入门到精通:Spring Boot 整合 MyBatis 全攻略
spring boot·后端·mybatis