This repository has been archived by the owner on Nov 14, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathtask.go
86 lines (75 loc) · 1.63 KB
/
task.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package main
import (
"encoding/json"
"sync"
"time"
)
/*
* 任务列表管理(添加,删除,更新)
*/
type job struct {
Time string `json:"time"` //任务执行时间
Cmd string `json:"cmd"` //可执行程序
Args []string `json:"args"` //执行参数
Out string `json:"out"` //输出文件
Comment string `json:"comment"` //任务备注
Start string `json:"start"` //任务单次执行仅用作状态使用
minute []int
hour []int
dom []int
month []int
dow []int
}
func NewJobs() *Jobs {
return &Jobs{mj: make(map[string]*job), lk: new(sync.RWMutex)}
}
type Jobs struct {
mj map[string]*job
lk *sync.RWMutex
}
func (jobs *Jobs) add(k string, v *job) {
jobs.lk.Lock()
defer jobs.lk.Unlock()
jobs.mj[k] = v
}
func (jobs *Jobs) del(k string) {
jobs.lk.Lock()
defer jobs.lk.Unlock()
delete(jobs.mj, k)
}
func (jobs *Jobs) json() ([]byte, error) {
jobs.lk.RLock()
defer jobs.lk.RUnlock()
return json.Marshal(jobs.mj)
}
func (jobs *Jobs) getJobs() map[string]*job {
jobs.lk.RLock()
defer jobs.lk.RUnlock()
return jobs.mj
}
func (jobs *Jobs) replaceJobs(mj map[string]*job) {
jobs.lk.Lock()
defer jobs.lk.Unlock()
jobs.mj = mj
}
func (jobs *Jobs) runJobs() {
t := time.Now()
if t.Second() == 0 {
jobs.lk.Lock()
defer jobs.lk.Unlock()
minute := t.Minute()
hour := t.Hour()
dom := t.Day()
month := int(t.Month())
dow := int(t.Weekday())
for _, j := range jobs.mj {
if inArray(j.minute, minute) &&
inArray(j.hour, hour) &&
inArray(j.dom, dom) &&
inArray(j.month, month) &&
inArray(j.dow, dow) {
go runJob(*j)
}
}
}
}