Go-zero微服务个人探究之路(十二)定时任务的选择调研

前言

很多时候后台需要做定时任务的需求,笔者的项目采用go-zero框架微服务框架,需要做定时任务,于是做了如下方法调研,共有大概三种主要选择

方案

难度总体由容易到复杂

go的timer库

通过Go的标准库time中的TickerTick功能来设置和管理定时任务,可以直接集成在服务启动逻辑中,不需要额外的文件或复杂的配置

Go 复制代码
func startTicker() {
	ticker := time.NewTicker(1 * time.Hour) // 每小时执行一次
	defer ticker.Stop()

	for {
		select {
		case <-ticker.C:
			// 执行定时任务
			fmt.Println("执行定时任务...")
			// 这里可以放置你的业务逻辑
		}
	}
}

cron库

使用robfig/cron这个Go库,作为大型复杂项目的定时任务,cron非常常见也非常强大

大概要在go-zero的服务启动文件里添加如下代码

Go 复制代码
    // 初始化Cron调度器
	cronScheduler := cron.New(cron.WithSeconds()) // 使用WithSeconds选项支持秒级调度

	// 添加定时任务
	_, err := cronScheduler.AddFunc("0 */1 * * * *", func() { // 每分钟执行一次
		// 定时任务的逻辑
	})
	if err != nil {
		logx.Errorf("添加定时任务失败: %v", err)
		return
	}

	// 启动Cron调度器
	cronScheduler.Start()

	// 停止Cron调度器
	defer cronScheduler.Stop()

go-queue

这是一种官方更加推荐的方法,不过需要配置消息队列集群,大概代码如下

Go 复制代码
package main

import (
    "fmt"
    "strconv"
    "time"

    "github.com/zeromicro/go-queue/dq"
)

func main() {
    producer := dq.NewProducer([]dq.Beanstalk{
        {
            Endpoint: "localhost:11300",
            Tube:     "tube",
        },
        {
            Endpoint: "localhost:11301",
            Tube:     "tube",
        },
    })

    // 延迟 5s 后处理
    _, err := producer.Delay([]byte("hello"), time.Second*5)
    if err != nil {
        fmt.Println(err)
    }

    // 在指定时间点处理
    _, err = producer.At([]byte("hello"), time.Now().Add(time.Second*10))
    if err != nil {
        fmt.Println(err)
    }
}

总结

go-queue的方案直接被笔者排除了,不再额外配置消息队列集群,

其他两个方法比较也很明显


使用Cron库,可以在同一个调度器中管理多个任务,每个任务都有自己的Cron表达式

使用timer,如果有很多不同的任务,需要不同的时间间隔,管理这些会很麻烦


使用timer不需要引入依赖,使用cron需要引入依赖


相关推荐
归寻太乙4 分钟前
C++函数重载完成日期类相关计算
开发语言·c++
尽蝶叙7 分钟前
C++:分苹果【排列组合】
开发语言·c++·算法
ღ᭄ꦿ࿐Never say never꧂11 分钟前
微服务架构中的负载均衡与服务注册中心(Nacos)
java·spring boot·后端·spring cloud·微服务·架构·负载均衡
.生产的驴21 分钟前
SpringBoot 消息队列RabbitMQ 消息确认机制确保消息发送成功和失败 生产者确认
java·javascript·spring boot·后端·rabbitmq·负载均衡·java-rabbitmq
海里真的有鱼29 分钟前
Spring Boot 中整合 Kafka
后端
憧憬成为原神糕手32 分钟前
c++_list
开发语言·c++
idealzouhu34 分钟前
Java 并发编程 —— AQS 抽象队列同步器
java·开发语言
布瑞泽的童话35 分钟前
无需切换平台?TuneFree如何搜罗所有你爱的音乐
前端·vue.js·后端·开源
爱吃油淋鸡的莫何35 分钟前
Conda新建python虚拟环境问题
开发语言·python·conda
闲人编程42 分钟前
Python实现日志采集功能
开发语言·python·fluentd·filebeat·日志采集