文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Go语言dolphinscheduler怎么使用

2023-07-02 05:59

关注

这篇文章主要介绍了Go语言dolphinscheduler怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Go语言dolphinscheduler怎么使用文章都会有所收获,下面我们一起来看看吧。

自动化

为什么需要自动化任务处理,当你的dolphinscheduler有几百上千个任务,管理是非常耗时的,如果每个任务都配置邮件告警,那一有问题整天都在救火

此时就需要任务结果监控和任务重跑来解决 失败任务和任务自动重跑,避免浪费过多时间在维护dolphinscheduler任务上

使用

在调用api之前需要为用户申请token,按图操作

Go语言dolphinscheduler怎么使用

dolphinscheduler提供类似swagge接口UI工具

Go语言dolphinscheduler怎么使用

例子

该demo还是使用了http请求包(HttpRequest),json数据搜索包(go-jmespath)

任务结果检查

填坑说明

该方法可以做成周期性任务运行,将失败的job查出来,后续是要告警通知,还是根据job名称查出对应id进行重跑任务

package mainimport (   "encoding/json"   "fmt"   "github.com/jmespath/go-jmespath"   "github.com/kirinlabs/HttpRequest"   "time")var (   url = "http://ip:12345/dolphinscheduler"   token = "xxxxxxx"   req *HttpRequest.Request)func init() {   req = HttpRequest.NewRequest().Debug(true).SetTimeout(time.Second*5).      SetHeaders(map[string]string{         "token":token,      })}func main() {   //testConn()   jobCheck()}func jobCheck()  {   //获取日期   today := time.Now().Format("2006-01-02")   tomorrow := time.Now().AddDate(0, 0, +1).Format("2006-01-02")   //拼接日期 %20是空格的转译   fmt.Println(fmt.Sprintf("%v%v",today,"%2000:00:00"))   fmt.Println(fmt.Sprintf("%v%v",tomorrow,"%2000:00:00"))   //需要检查的项目名称   projects := []string{"jdOrder","jdPlay"}   //需要检查的时间段 页码是int类型,日期是string类型   m := make(map[string]interface{})   m["pageNo"] = 1   m["pageSize"] = 22   m["stateType"] = "FAILURE"   m["startDate"] = fmt.Sprintf("%v%v",today,"%2000:00:00")   m["endDate"] = fmt.Sprintf("%v%v",tomorrow,"%2000:00:00")   for _, project := range projects {      resp, _ := req.Get(url+"/projects/"+project+"/task-instance/list-paging",m)      if resp.StatusCode() != 200 {         fmt.Println("job检查状态码不符期望: ",resp.StatusCode())         return      }      fmt.Println("resp",resp)      //将返回数据从byte转成json格式      body, _ := resp.Body()      var i interface{}      var s []string      _ = json.Unmarshal(body, &i)      //搜索出需要的字段对应数据      processInstanceNames, _ := jmespath.Search("data.totalList[*].processInstanceName", i)      //将interface转成[]string      for _,v := range processInstanceNames.([]interface{}) {         s = append(s,v.(string))      }      //打印出结果      for _,v := range s {         fmt.Println(v)      }   }}

测试连接

如果上小节任务跑不成功,可以先运行该方法,测试连接正确性

func testConn() {   resp, _ := req.Get(url + "/projects/query-project-list")   fmt.Println("resp",resp)   body, _ := resp.Body()   var i interface{}   _ = json.Unmarshal(body, &i)   fmt.Println("i",i)}

重跑任务

重跑任务其实就是再次启动任务,直接调用start_job既可

项目名称和ID需要通过该接口获取,这个是固定的

调用示例: startJob("ads_jd_order",678)

func startJob(projectName string,projectId int)  {   m := make(map[string]interface{})   m["failureStrategy"] = "CONTINUE"   m["warningGroupId"] = 0   m["warningType"] = "NONE"   m["runMode"] = "RUN_MODE_SERIAL"   m["processInstancePriority"] = "MEDIUM"   m["workerGroup"] = "default"   m["processDefinitionId"] = projectId   resp, _ := req.JSON().Post(url+"projects/" + projectName+"/executors/start-process-instance",m)   if resp.StatusCode() != 200 {      fmt.Println("job开始状态码不符期望: ",resp.StatusCode())      return   }}

关于“Go语言dolphinscheduler怎么使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Go语言dolphinscheduler怎么使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯