All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ecfront.ez.framework.service.masterslave.Executor.scala Maven / Gradle / Ivy

package com.ecfront.ez.framework.service.masterslave

import com.typesafe.scalalogging.slf4j.LazyLogging

import scala.annotation.tailrec

/**
  * 执行器
  *
  * @param dto 任务准备DTO
  */
case class Executor(dto: TaskPrepareDTO) extends LazyLogging {

  val category: String = dto.category
  var running: Boolean = false

  /**
    * 触发执行
    *
    * @param useNewThread 是否在新线程中执行
    */
  def run(useNewThread: Boolean): Unit = {
    logger.debug(s"Executor Running [${dto.instanceId}]")
    running = true
    if (useNewThread) {
      val self = this
      ExecutorPool.executeThreadPool.execute(new Runnable {
        override def run(): Unit = {
          Executor.execute(dto)
          ExecutorPool.finishExecute(self)
        }
      })
    } else {
      Executor.execute(dto)
      ExecutorPool.finishExecute(this)
    }
  }

}

object Executor extends Serializable with LazyLogging {

  private val DEFAULT_MAX_TRY_TIME: Int = 5

  private[masterslave] def maxTryTime: Int = DEFAULT_MAX_TRY_TIME

  private var processorContainer = Map[String, TaskBaseProcessor[_]]()

  private[masterslave] def registerProcessors(processors: List[TaskBaseProcessor[_]]): Unit = {
    processorContainer = processors.map {
      processor =>
        processor.category -> processor
    }.toMap
  }

  /**
    * 开始执行
    * @param dto 任务准备DTO
    */
  private[masterslave] def execute(dto: TaskPrepareDTO): Unit = {
    // 先通知开始任务
    Assigner.Worker.startTask(TaskStartDTO(dto.instanceId))
    val processorOpt = processorContainer.get(dto.category)
    if (processorOpt.isDefined) {
      doExecute(dto, processorOpt.get, 0)
    } else {
      logger.error("Processor NOT exist " + dto.category)
      Assigner.Worker.finishTask(TaskFinishDTO(
        dto.instanceId,
        isSuccess = false,
        hasChange = false,
        s"Not found process by category:${dto.category}",
        Map(),
        Map()
      ))
    }
  }

  @tailrec
  private def doExecute(dto: TaskPrepareDTO, processor: TaskBaseProcessor[_], tryTimes: Int): Unit = {
    try {
      if (tryTimes != 0) {
        logger.warn(s"Worker process error try [$tryTimes] times ")
      }
      val changeCheckResp = processor.hasChange(dto.taskInfo, dto.taskVar, dto.instanceParameters)
      if (changeCheckResp) {
        if (changeCheckResp.body) {
          logger.debug(s"Worker process execute [${dto.instanceId}]")
          val resp = processor.execute(dto.taskInfo, dto.taskVar, dto.instanceParameters, tryTimes != 0)
          if (resp) {
            Assigner.Worker.finishTask(TaskFinishDTO(
              dto.instanceId,
              isSuccess = true,
              hasChange = true,
              "",
              resp.body._1,
              resp.body._2
            ))
          } else {
            Assigner.Worker.finishTask(TaskFinishDTO(
              dto.instanceId,
              isSuccess = false,
              hasChange = false,
              resp.message,
              Map(),
              Map()
            ))
          }
        } else {
          Assigner.Worker.finishTask(TaskFinishDTO(
            dto.instanceId,
            isSuccess = true,
            hasChange = false,
            "",
            Map(),
            Map()
          ))
        }
      } else {
        // 没有变更
        Assigner.Worker.finishTask(TaskFinishDTO(
          dto.instanceId,
          isSuccess = false,
          hasChange = false,
          changeCheckResp.message,
          Map(),
          Map()
        ))
      }
    } catch {
      case e: Throwable =>
        if (tryTimes < maxTryTime) {
          logger.error("Worker process execute error , try again",e)
          doExecute(dto, processor, tryTimes + 1)
        } else {
          logger.error("Worker process execute error",e)
          Assigner.Worker.finishTask(TaskFinishDTO(
            dto.instanceId,
            isSuccess = false,
            hasChange = false,
            e.getMessage,
            Map(),
            Map()
          ))
        }
    }
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy