• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    基于golang channel实现的轻量级异步任务分发器示例代码

    前言

    有时候我们为了更好的利用计算机资源,可以把一些耗时长的任务队列化异步执行。举个对应简单的生活中例子就是大多数餐厅里面点菜都是先找地方做,看了菜单选好菜之后找服务员点菜,此时再等待菜做好送上来。这里餐厅厨房就是计算机的底层资源,菜就是待执行的任务,而服务员就是我们的go channel。

    关于消息队列有很多好用的框架,如nsq,nats,kafka等等。但有时我们只需要轻量级的异步任务工具,而不需要太过于"复杂"的框架相对于我们的需求来说。于是借鉴一些项目框架,做了一个小小的封装。

    项目地址: https://github.com/chenhg5/go...  (本地下载)

    go-task的使用很简单,只需要初始化一个任务处理器,然后往处理器里面添加任务,然后处理器就会异步地去执行了。

    举餐厅的例子,代码如下:

    package main
    
    import (
     "runtime"
     "fmt"
     "time"
     "github.com/chenhg5/go-task"
    )
    
    func main() {
    
     // init
     task.InitTaskReceiver(runtime.NumCPU())
    
     // 有十个人同时点菜
     for i := 0; i  10; i++ {
      task.AddTask(task.NewTask(
       map[string]interface{}{
        "paramA" : "value",
       }, // 参数
       []task.FacFunc{ordering, cooking, deliverying}, // 任务列表
       -1), // -1代表任务不超时
      )
     }
    
     time.Sleep(time.Second * 50)
    }
    
    // 下单任务
    func ordering(uuid string, param map[string]interface{}) (string, error) {
     fmt.Println("i am ordering")
     time.Sleep(time.Second * 1)
     return uuid, nil
    }
    
    // 做菜任务
    func cooking(uuid string, param map[string]interface{}) (string, error) {
     fmt.Println("i am cooking")
     time.Sleep(time.Second * 1)
     return uuid, nil
    }
    
    // 配送任务
    func deliverying(uuid string, param map[string]interface{}) (string, error) {
     fmt.Println("i am deliverying")
     time.Sleep(time.Second * 1)
     return uuid, nil
    }

    跑一遍,就会看到:

    i am ordering
    i am ordering
    i am ordering
    i am ordering
    i am ordering
    i am ordering
    i am ordering
    i am ordering
    i am cooking
    i am cooking
    i am cooking
    i am cooking
    i am cooking
    i am cooking
    i am cooking
    i am cooking
    i am deliverying
    i am deliverying
    i am deliverying
    i am deliverying
    i am deliverying
    i am deliverying
    i am deliverying
    i am deliverying
    i am ordering
    i am ordering
    i am cooking
    i am cooking
    i am deliverying
    i am deliverying

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

    您可能感兴趣的文章:
    • golang中for循环遍历channel时需要注意的问题详解
    • golang实现基于channel的通用连接池详解
    • Golang优雅关闭channel的方法示例
    • golang中单向channel的语法介绍
    • golang判断chan channel是否关闭的方法
    • Golang中channel使用的一些小技巧
    • Golang中channel的原理解读(推荐)
    上一篇:golang如何实现抓取IP地址的蜘蛛程序详解
    下一篇:golang实战之truncate日志文件详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    基于golang channel实现的轻量级异步任务分发器示例代码 基于,golang,channel,实现,的,