当前位置: 首页>>代码示例>>Golang>>正文


Golang automation.Task类代码示例

本文整理汇总了Golang中github.com/youtube/vitess/go/vt/proto/automation.Task的典型用法代码示例。如果您正苦于以下问题:Golang Task类的具体用法?Golang Task怎么用?Golang Task使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了Task类的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。

示例1: runTask

func (s *Scheduler) runTask(taskProto *pb.Task, clusterOpID string) ([]*pb.TaskContainer, string, error) {
	if taskProto.State == pb.TaskState_DONE {
		// Task is already done (e.g. because we resume from a checkpoint).
		if taskProto.Error != "" {
			log.Errorf("Task: %v (%v/%v) failed before. Aborting the ClusterOperation. Error: %v Details: %v", taskProto.Name, clusterOpID, taskProto.Id, taskProto.Error, taskProto)
			return nil, "", errors.New(taskProto.Error)
		}
		log.Infof("Task: %v (%v/%v) skipped because it is already done. Full Details: %v", taskProto.Name, clusterOpID, taskProto.Id, taskProto)
		return nil, taskProto.Output, nil
	}

	task, err := s.createTaskInstance(taskProto.Name)
	if err != nil {
		log.Errorf("Task: %v (%v/%v) could not be instantiated. Error: %v Details: %v", taskProto.Name, clusterOpID, taskProto.Id, err, taskProto)
		return nil, "", err
	}

	taskProto.State = pb.TaskState_RUNNING
	log.Infof("Task: %v (%v/%v) running. Details: %v", taskProto.Name, clusterOpID, taskProto.Id, taskProto)
	newTaskContainers, output, err := task.Run(taskProto.Parameters)
	log.Infof("Task: %v (%v/%v) finished. newTaskContainers: %v, output: %v, error: %v", taskProto.Name, clusterOpID, taskProto.Id, newTaskContainers, output, err)

	return newTaskContainers, output, err
}
开发者ID:springlee,项目名称:vitess,代码行数:24,代码来源:scheduler.go

示例2: MarkTaskSucceeded

// MarkTaskSucceeded marks the task as done.
func MarkTaskSucceeded(t *automationpb.Task, output string) {
	t.State = automationpb.TaskState_DONE
	t.Output = output
}
开发者ID:littleyang,项目名称:vitess,代码行数:5,代码来源:tasks.go

示例3: MarkTaskFailed

// MarkTaskFailed marks the task as failed.
func MarkTaskFailed(t *automationpb.Task, output string, err error) {
	t.State = automationpb.TaskState_DONE
	t.Output = output
	t.Error = err.Error()
}
开发者ID:littleyang,项目名称:vitess,代码行数:6,代码来源:tasks.go

示例4: MarkTaskSucceeded

// MarkTaskSucceeded marks the task as done.
func MarkTaskSucceeded(t *pb.Task, output string) {
	t.State = pb.TaskState_DONE
	t.Output = output
}
开发者ID:pranjal5215,项目名称:vitess,代码行数:5,代码来源:tasks.go


注:本文中的github.com/youtube/vitess/go/vt/proto/automation.Task类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。