使用golang编写一个并发工作队列
作者:u010278923 时间:2023-09-02 20:54:08
其实golang用一个函数可以构建一个并发队列,现在编写一个灵活可控的队列程序
先定义一个工作
type Worker struct {
ID int
RepJobs chan int64
SM *SM
quit chan bool
}
包含了workid和执行任务的id,上面的SM只是任务具体内容,这个和具体业务相关,大家自己编写自己的SM业务逻辑
然后定义工作池
type workerPool struct {
workerChan chan *Worker
workerList []*Worker
}
这个里面定义了一个工作队列的切片,可以自定义工作队列的个数,甚至后期还可以添加work,还定义了一个队列类型的管道。
定义完成过后就可以初始化工作池了
func InitWorkerPool() error {
n := 3
WorkerPool = &workerPool{
workerChan: make(chan *Worker, n),
workerList: make([]*Worker, 0, n),
}
for i := 0; i < n; i++ {
worker := NewWorker(i)
WorkerPool.workerList = append(WorkerPool.workerList, worker)
worker.Start()
log.Debugf("worker %d started", worker.ID)
}
return nil
}
这个里面我写死了worker的个数是3,当然这个可以通过读取配置文件或者参数传递的方式;这个里面逐一启动work
worker.Start(),这个是关键
func (w *Worker) Start() {
go func() {
for {
WorkerPool.workerChan <- w
select {
case jobID := <-w.RepJobs:
log.Debugf("worker: %d, will handle job: %d", w.ID, jobID)
w.handleRepJob(jobID)
case q := <-w.quit:
if q {
log.Debugf("worker: %d, will stop.", w.ID)
return
}
}
}
}()
}
这个就是go 启动一个协程,先把自己放到workerChan中,然后不断从w.RepJobs管道中获取任务并执行,如果执行完成后又把自己放回到队列中。
所以如果你要有任务需要执行,放到这个管道中即可
func Dispatch() {
for {
select {
case job := <-jobQueue:
go func(jobID int64) {
println("Trying to dispatch job: %d", jobID)
worker := <-WorkerPool.workerChan
worker.RepJobs <- jobID
}(job)
}
}
}
从管道中拿出一个worker并把任务id放到worker中去执行。
当然你可以停止worker,甚至可以停止job
func (w *Worker) Stop() {
go func() {
w.quit <- true
}()
}
func (wp *workerPool) StopJobs(jobs []int64) {
log.Debugf("Works working on jobs: %v will be stopped", jobs)
for _, id := range jobs {
for _, w := range wp.workerList {
if w.SM.JobID == id {
log.Debugf("found a worker whose job ID is %d, will try to stop it", id)
w.SM.Stop(id)
}
}
}
}
补充一下,int64和字符串转换。
string到int
int,err:=strconv.Atoi(string)
string到int64
int64, err := strconv.ParseInt(string, 10, 64)
int到string
string:=strconv.Itoa(int)
int64到string
string:=strconv.FormatInt(int64,10)
以上为个人经验,希望能给大家一个参考
来源:https://chenxy.blog.csdn.net/article/details/72582200
标签:golang,并发,队列
0
投稿
猜你喜欢
关于mysql基础知识的介绍
2024-01-18 10:57:28
Python找出列表中出现次数最多的元素三种方式
2021-04-11 11:45:40
MYSQL不能从远程连接的一个解决方法(s not allowed to connect to this MySQL server)
2024-01-19 02:57:34
基于Python实现签到脚本过程解析
2023-01-13 03:14:56
mysql获取字符串长度函数(CHAR_LENGTH)
2024-01-26 02:42:51
pycharm2022没有manage repositories配置镜像源的解决方法
2022-06-27 05:30:24
Django + Taro 前后端分离项目实现企业微信登录功能
2023-05-31 18:48:46
PHP MVC模式在网站架构中的实现分析
2023-07-22 21:05:14
Golang 正则匹配效率详解
2024-01-30 03:41:47
Tensorflow使用tfrecord输入数据格式
2022-06-18 22:55:40
Python如何向SQLServer存储二进制图片
2021-01-06 08:23:54
jsp+servlet简单实现上传文件功能(保存目录改进)
2023-07-20 17:57:07
python 函数传参之传值还是传引用的分析
2021-08-20 13:06:34
深入浅析Python2.x和3.x版本的主要区别
2023-06-21 04:12:52
php ios推送(代码)
2024-03-26 14:22:34
Python编程中归并排序算法的实现步骤详解
2023-06-05 09:38:23
分享Pytest fixture参数传递的几种方式
2023-06-15 01:25:28
Python中选择结构实例讲解
2023-06-26 14:56:09
vue2.0+vue-dplayer实现hls播放的示例
2024-05-29 22:46:56
对tensorflow中的strides参数使用详解
2022-06-12 06:00:38