Go语言web开发---Cronexpr 包实现并发定时任务
安装Cronexpr包:
go get -u github.com/gorhill/cronexpr
这个包支持七位时间控制
*(秒) *(分) *(时) *(日) *(月) *(周) *(年)
栗子:
每5秒执行一次: */5 * * * * * *
一个简单的小栗子
package main import (
"fmt"
"github.com/gorhill/cronexpr"
"time"
)
//* * * * * * *
//秒 分 时 日 月 周 年
func main() {
var expr *cronexpr.Expression
var err error
//每5秒执行一次
if expr, err = cronexpr.Parse("*/5 * * * * * *");err != nil{
fmt.Println("err=", err)
return
} //当前时间
now := time.Now()
fmt.Println("now=",now)
nextTime := expr.Next(now)
fmt.Println("nextTime=", nextTime) time.AfterFunc(nextTime.Sub(now), func() {
fmt.Println("被调用了")
}) time.Sleep(6*time.Second)
}
输出
now= 2020-05-03 00:58:48.6350048 +0800 CST m=+0.008000001
nextTime= 2020-05-03 00:58:50 +0800 CST
被调用了
注意:这里每5秒也好,每3分钟也好,都不是以现在的时间计时的:
例如:
每5秒:假设现在12:00:02,下次执行时间将会是12:00:05,他会从0秒开始累加计算下次时间,而不是现在的秒数
每3分钟:假设现在12:00:02,下次执行时间将会是12:03:00,他会从0分开始累加计算,并且秒数归零
一个并发多任务的定时任务小案例
package main import (
"fmt"
"github.com/gorhill/cronexpr"
"time"
) //代表任务
type CronJob struct {
expr *cronexpr.Expression
nextTime time.Time
} func main() {
//创建map,用于存储多个定时任务
scheduleTable := make(map[string]*CronJob) //当前时间
now := time.Now() expr, _ := cronexpr.Parse("*/5 * * * * * *")
cronJob := &CronJob{
expr:expr,
nextTime:expr.Next(now),
}
scheduleTable["job1"] = cronJob expr, _ = cronexpr.Parse("*/4 * * * * * *")
cronJob = &CronJob{
expr:expr,
nextTime:expr.Next(now),
}
scheduleTable["job2"] = cronJob go func() {
for{
now := time.Now()
//遍历map,取出每一个定时任务,检查是否过期
for jobName, cronJob := range scheduleTable{
//当前定时任务下次执行的时间在当前时间之前或者等于当前时间
if cronJob.nextTime.Before(now)||cronJob.nextTime.Equal(now){
//开启协程,执行定时任务
go func(jobName string) {
fmt.Println("执行:", jobName)
}(jobName)
//计算下一次调度的时间
cronJob.nextTime = cronJob.expr.Next(now)
fmt.Println(jobName, "下次执行时间:",cronJob.nextTime)
}
}
select {
case <-time.NewTimer(100 * time.Millisecond).C: }
}
}()
time.Sleep(100*time.Second)
}
Go语言web开发---Cronexpr 包实现并发定时任务的更多相关文章
- Go语言web开发---Beego基础
一.框架 框架:可复用的设计组件,它规定了应用的体系结构,明确了整个设计,协作各个组件之间的依赖关系,责任分配,和流程控制.通俗解释框架就是一堆代码的集合,为了提高软件的开发效率和质量,一般都会使用框 ...
- Go语言web开发---Beego的cookie
1.简介 (1)Http是无状态的协议,服务器不能记录浏览器的访问状态,也就是说服务器不能区分两次请求是否是同一个客户端,这样的设计严重阻碍了web程序的设计. (2)Cookie是解决Http协议无 ...
- Go语言web开发---Beego路由
参考链接(查看更多):https://beego.me/docs/mvc/controller/router.md 基础路由 从 beego 1.2 版本开始支持了基本的 RESTful 函数式路由, ...
- Go语言web开发---Beego的session
一.简介 Session是一段保存在服务器上的信息,当客户端第一次访问服务器时创建Session,同时也会创建一个名为beegosessionID,值为创建的Session的id的Cookie. 这个 ...
- 关于Web开发里并发、同步、异步以及事件驱动编程的相关技术
一.开篇语 我的上篇文章<关于如何提供Web服务端并发效率的异步编程技术>又成为了博客园里“编辑推荐”的文章,这是对我写博客很大的鼓励,也许是被推荐的原因很多童鞋在这篇文章里发表了评论,有 ...
- Spring整合web开发
正常整合Servlet和Spring没有问题的 public class UserServlet extends HttpServlet { public void doGet(HttpServlet ...
- 了不起的Node.js: 将JavaScript进行到底(Web开发首选,实时,跨多服务器,高并发)
了不起的Node.js: 将JavaScript进行到底(Web开发首选,实时,跨多服务器,高并发) Guillermo Rauch 编 赵静 译 ISBN 978-7-121-21769-2 2 ...
- 大数据平台R语言web UI应用架构 设计与开发
1. 系统拓扑图 在日常业务分析中,R是非常常用的分析工具,而当数据量较大时,用R语言需要需用更多的时间来完成训练模型,spark作为大规模数据处理框架,采用内存计算,可以短时间内完成大量的数据的处理 ...
- Java在Web开发语言上败给了PHP
PHP的主要语言开发者之一.Zend公司的创始人之一Andi Gutmans最近在blog中直言不讳地批评了Java语言.他指出,目前Java厂商试图在JVM上提供动态语言实现的路子根本不对,Java ...
随机推荐
- 通过Dapr实现一个简单的基于.net的微服务电商系统(八)——一步一步教你如何撸Dapr之链路追踪
Dapr提供了一些开箱即用的分布式链路追踪解决方案,今天我们来讲一讲如何通过dapr的configuration来实现非侵入式链路追踪的 目录:一.通过Dapr实现一个简单的基于.net的微服务电商系 ...
- zabbix容器化安装及监控docker应用
一.zabbix agent2 介绍 从Zabbix 4.4之后,官方推出了Zabbix Agent 2,意味着zabbix 不在只是物理机监控的代名词,现在你可以使用Go为Zabbix编写插件,来监 ...
- 漫画 | 公司测试因提Bug不规范,锒铛入狱~
互联网人罪状系列 1.上班第一天,前端把后端告上县衙,还列了 5 宗罪 2. 程序员状告产品经理八大罪状 (上) 3.程序员状告产品经理八大罪状(下) 开发人员与测试人员的关系,就如同程序员与产品经理 ...
- php正则表达式过滤空格 换行符 回车
我整理了几个比较适合的实例了,对于它们我们是有很多站长都测试过并用过了,不过文章最后我的总结也是生重要的哦,至于原因我也说不上了,因为chr是ascii编码了所以有时浏览器会自动转成ascii,特别像 ...
- Windows中的权限设置、文件压缩、文件加密、磁盘配额和卷影副本
目录 权限设置 文件夹的NTFS权限 文件的NTFS权限 NTFS权限的应用规则 文件压缩 文件加密 磁盘配额 卷影副本 权限设置的应用 遇到的一个权限问题的小bug 权限问题的实际应用 权限设置 ...
- hdu1305 字典树水题
题意: 给你一些字符串,然后问你他们中有没有一个串是另一个串的前缀. 思路: 字典树水题,(这种水题如果数据不大(这个题目不知道大不大,题目没说估计不大),hash下也行,把每个 ...
- java之Map和Collection
java中保存对象的容器可分为两类: 1.Map.Map是以键值对的形式来保存一组对象,可以通过键来查找值. 2.Collection.用来保存独立对象的序列.Collection又可分为三种类型: ...
- ConcurrentHashMap源码解读三
今天首先讲解helpTransfer方法 final Node<K,V>[] helpTransfer(Node<K,V>[] tab, Node<K,V> f) ...
- 简单聊聊VisualStudio的断点调试
这节聊聊如何使用VisualStudio进行断点调试. 在debug过程中,我们有时需要查看程序在运行到某一行代码时,上下文中的变量或者一些其他的数据是什么样的,我们就要设置断点(Breakpoint ...
- 用户对象/GDI对象/内核对象
对象的分类 Windows的对象可以分为三种,分别是用户对象,GDI对象和内核对象.系统使用用户对象支持窗口管理,使用GDI对象支持图形,并使用内核对象支持内存管理,进程执行和进程间通信(IPC) . ...