-
Notifications
You must be signed in to change notification settings - Fork 0
/
pong.go
80 lines (70 loc) · 1.79 KB
/
pong.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
package handler
import (
"fmt"
"time"
"github.com/bsm/redislock"
"github.com/fishjar/gin-boilerplate/crons"
"github.com/fishjar/gin-boilerplate/db"
"github.com/fishjar/gin-boilerplate/locker"
"github.com/fishjar/gin-boilerplate/logger"
"github.com/fishjar/gin-boilerplate/model"
"github.com/fishjar/gin-boilerplate/tasks"
"github.com/gin-gonic/gin"
)
// Pong 测试handle
func Pong(c *gin.Context) {
// 获取锁
lock, err := locker.Locker.Obtain(locker.PING, 10*1000*time.Millisecond, nil)
if err == redislock.ErrNotObtained {
// fmt.Println("Could not obtain lock!")
c.JSON(200, gin.H{
"message": "Could not obtain lock!",
})
return
} else if err != nil {
// log.Fatalln(err)
c.JSON(200, gin.H{
"message": "obtain lock err",
})
return
}
// 释放锁
defer lock.Release()
// 日志
logger.Log.Info("测试日志")
// 测试创建任务队列
t := tasks.NewEmailDeliveryTask(42, "some:template:id") // 创建任务
if _, err := tasks.Client.Enqueue(t); err != nil { // 添加到任务队列
fmt.Println("添加任务队列失败", err)
c.JSON(200, gin.H{
"message": "添加任务队列失败",
})
return
}
// 测试原生SQL
var user model.User
db.DB.Raw("SELECT * FROM user WHERE nickname = ?", "gabe").Scan(&user)
rows, err := db.DB.Raw("SELECT * FROM menu").Rows()
if err != nil {
fmt.Println("sql", err)
c.JSON(200, gin.H{
"message": "SQL查询失败",
})
return
}
defer rows.Close()
var menus []model.Menu
for rows.Next() {
var menu model.Menu
db.DB.ScanRows(rows, &menu)
menus = append(menus, menu)
}
// 测试创建定时任务
crons.Cron.AddJob(crons.EVERY30SENCOND, &crons.TestJob{Value: "30s"})
time.Sleep(5 * 1000 * time.Millisecond)
c.JSON(200, gin.H{
"message": "pong..",
"user": user,
"menus": menus,
})
}