当前位置: 首页 > article >正文

Golang —协程池(panjf2000/ants/v2)

Golang —协程池(panjf2000/ants/v2)

  • 1 ants
    • 1.1 基本信息
    • 1.2 ants 是如何运行的(流程图)

1 ants

1.1 基本信息

代码地址:github.com/panjf2000/ants/v2
介绍:ants是一个高性能的 goroutine 池,实现了对大规模 goroutine 的调度管理、goroutine 复用,允许使用者在开发并发程序的时候限制 goroutine 数量,复用资源,达到更高效执行任务的效果。

功能

  • 自动调度海量的 goroutines,复用 goroutines。
  • 定期清理过期的 goroutines,进一步节省资源。
  • 提供了大量有用的接口:任务提交、获取运行中的 goroutine 数量、动态调整 Pool 大小、释放 Pool、重启 Pool。
  • 优雅处理 panic,防止程序崩溃。
  • 资源复用,极大节省内存使用量;在大规模批量并发任务场景下比原生 goroutine 并发具有更高的性能。
  • 非阻塞机制。

1.2 ants 是如何运行的(流程图)

在这里插入图片描述

  1. 这里每一个worker其实就是一个单独的协程。Submit()就是将一个任务交给worker(协程)来异步处理,等任务执行完后,worker会将自己交还给协程池。
  2. 倘若回归协程池失败,或者用户提交了一个空的任务包,则该 goWorker 会被销毁,销毁方式是将自身放回协程池的对象池 workerCache. 并且会调用协调器 cond 唤醒一个阻塞等待的协程。
  3. 通过使用 ants,可以实例化一个 goroutine 池,复用 goroutine ,节省资源,提升性能,它会自动管理worker(协程)的创建、回收、释放等工作。

http://www.kler.cn/a/526522.html

相关文章:

  • Leetcode 131 分割回文串(纯DFS)
  • ubuntu20.04.6下运行VLC-Qt例子simple-player
  • Linux Samba 低版本漏洞(远程控制)复现与剖析
  • 在AWS上使用KMS客户端密钥加密S3文件,同时支持PySpark读写和Snowflake导入
  • python3+TensorFlow 2.x(三)手写数字识别
  • WordPress event-monster插件存在信息泄露漏洞(CVE-2024-11396)
  • 智慧园区如何融合五大技术实现全方位智能管理与服务创新
  • 一文了解视觉Transformer解析 !!
  • 2022 年 12 月大学英语四级考试真题(第 3 套)——纯享题目版
  • PT站点自动签到
  • 2025数学建模美赛|赛题翻译|F题
  • 「 运动控制 」结构控制网络(Structured Control Network, SCN) ——多策略融合的高效控制架构
  • 高精度加法乘法
  • 详解python的修饰符
  • 数科OFD证照生成原理剖析与平替方案实现
  • 大一计算机的自学总结:位运算实现加减乘除
  • 用BGP的路由聚合功能聚合大陆路由,效果显著不?
  • rust如何操作sqlserver
  • 每日 Java 面试题分享【第 17 天】
  • 18、智能驾驶芯片外部接口要求
  • SpringBoot中运行Yolov5程序
  • 前端知识速记—JS篇:null 与 undefined
  • Linux实操篇-文件目录类>/>>/echo/head/tail/ln/history
  • leetcode-分割等和子集
  • Java中 instanceof 的用法(详解)
  • 安卓(android)饭堂广播【Android移动开发基础案例教程(第2版)黑马程序员】