Ron基于Redis滑动过期机制的定时任务实现
长安网站制作公司哪家好,找成都创新互联!从网页设计、网站建设、微信开发、APP开发、响应式网站建设等网站项目制作,到程序开发,运营维护。成都创新互联从2013年创立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联。
Ron是一款基于Redis的分布式定时任务调度系统。它提供了可靠的定时任务调度服务,允许多个任务同时执行,支持延迟执行和循环执行等功能。Ron的设计目标是高可用、高效率、易用性,同时具备分布式扩展能力。
Redis滑动过期机制是Ron实现高效率的关键技术。在Redis中,key的过期时间通常是静态的,即指定一个过期时间,当时间到达时,key会被自动删除。而滑动过期机制允许在key被访问时动态地更新过期时间,从而避免了过期时间被固定的缺点。
基于Redis滑动过期机制的实现,Ron在定时任务调度中引入了超时时间概念。当一个任务被添加到Ron中时,它会被设置一个超时时间T1,该任务会在T1时间内执行完毕,否则会被认为执行超时。此时,另一个定时任务会被启动,执行当前任务未完成的任务。这样可以保证任务的完整性和及时性。
Ron的代码结构如下:
“`text
.
├── README.md
├── app
│ └── mn.go
├── config
│ ├── config.go
│ └── config.json
├── handler
│ ├── client.go
│ ├── job_handler.go
│ └── server.go
├── job
│ ├── job.go
│ └── job_manager.go
└── util
├── logger.go
└── redis.go
在mn.go中,Ron采用了Go语言的goroutine和chan,并结合了Redis实现了高效的定时任务调度系统,示例代码如下:
```go
package mn
import (
"flag"
"github.com/liangdas/mqant"
"github.com/liangdas/mqant/conf"
"github.com/tidwall/gjson"
"runtime"
"strconv"
"time"
)
func mn() {
// 1. 读取配置文件
var configFile = flag.String("configFile", "config/config.json", "config file path")
flag.Parse()
config, err := conf.LoadConfig(*configFile)
if err != nil {
panic(err)
}
// 2. 启动rpc服务
srv := mqant.CreateServer(config)
srv.RegisterGO("Ron", Ron)
// 3. 启动goroutine,定时执行任务
go func() {
for {
// 3.1 从Redis中获取下一次执行的任务ID
nextID, err := util.GetRedis().Brpop("JobQueue", 1*time.Second).Result()
if err != nil {
continue
}
// 3.2 获取任务详情,判断是否超时
jobID := gjson.Get(nextID, "JobID").String()
job := job_manager.GetJobByID(jobID)
if job == nil {
continue
}
timeout, err := strconv.Atoi(gjson.Get(nextID, "Timeout").String())
if err != nil {
timeout = job.GetTimeout()
}
if time.Now().Unix() > job.GetStartTime()+int64(timeout) {
job.SetStatus(job_fled)
job_manager.UpdateJob(job)
continue
}
// 3.3 执行任务
go func() {
job.SetStatus(job_running)
job.Run()
job_manager.UpdateJob(job)
}()
}
}()
// 4. 启动服务器
srv.Run()
}
func Ron(args []byte) string {
return "Ron is running..."
}
在handler/server.go中,Ron定义了RPC接口,其中AddJob接口用于添加任务。
“`go
type Server struct{}
func (s *Server) AddJob(args []byte) string {
// 1. 解析参数
jobName := gjson.Get(args, “Name”).String()
jobDelay := gjson.Get(args, “Delay”).Int()
jobTimeout := gjson.Get(args, “Timeout”).Int()
// 2. 创建任务实例
job := job.NewJob(jobName, jobDelay, jobTimeout)
// 3. 添加到任务队列
jobID := job_manager.AddJob(job)
// 4. 添加到Redis队列
util.GetRedis().Lpush(“JobQueue”, fmt.Sprintf(`{“JobID”:%q,”Timeout”:%q}`, jobID, jobTimeout))
// 5. 返回任务ID
return jobID
}
通过Ron基于Redis滑动过期机制的定时任务实现,可以实现高效、可靠的定时任务调度服务。该方案具有易于扩展、高效、简单易用等优点,在实际项目中得到了广泛应用。
创新互联(cdcxhl.com)提供稳定的云服务器,香港云服务器,BGP云服务器,双线云服务器,高防云服务器,成都云服务器,服务器托管。精选钜惠,欢迎咨询:028-86922220。
文章标题:ron基于Redis滑动过期机制的定时任务实现(redis滑动过期c)
转载来于:http://www.csdahua.cn/qtweb/news23/218823.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网