|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.entity.DeviceConfig; | 
|---|
|  |  |  | import com.zy.asrs.service.DeviceConfigService; | 
|---|
|  |  |  | import com.zy.common.utils.RedisUtil; | 
|---|
|  |  |  | import com.zy.core.News; | 
|---|
|  |  |  | import com.zy.core.action.ShuttleAction; | 
|---|
|  |  |  | import com.zy.core.enums.RedisKeyType; | 
|---|
|  |  |  | import com.zy.core.enums.SlaveType; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import com.zy.core.utils.TimeoutExecutor; | 
|---|
|  |  |  | import org.springframework.scheduling.annotation.Scheduled; | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.concurrent.TimeUnit; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | @Component | 
|---|
|  |  |  | public class ShuttleExecuteScheduler { | 
|---|
|  |  |  | public class ShuttleExecuteScheduler implements Runnable { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ShuttleAction shuttleAction; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DeviceConfigService deviceConfigService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private RedisUtil redisUtil; | 
|---|
|  |  |  | private int threadControlCount; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0/1 * * * * ? ") | 
|---|
|  |  |  | public void execute() { | 
|---|
|  |  |  | public ShuttleExecuteScheduler(ShuttleAction shuttleAction, DeviceConfigService deviceConfigService, RedisUtil redisUtil, int threadControlCount) { | 
|---|
|  |  |  | this.shuttleAction = shuttleAction; | 
|---|
|  |  |  | this.deviceConfigService = deviceConfigService; | 
|---|
|  |  |  | this.redisUtil = redisUtil; | 
|---|
|  |  |  | this.threadControlCount = threadControlCount; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void run() { | 
|---|
|  |  |  | List<DeviceConfig> shuttleList = deviceConfigService.selectList(new EntityWrapper<DeviceConfig>() | 
|---|
|  |  |  | .eq("device_type", String.valueOf(SlaveType.Shuttle))); | 
|---|
|  |  |  | for (DeviceConfig deviceConfig : shuttleList) { | 
|---|
|  |  |  | Object object = redisUtil.get(RedisKeyType.SHUTTLE_FLAG.key + deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | if (object == null) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<List<DeviceConfig>> lists = new ArrayList<>(); | 
|---|
|  |  |  | List<DeviceConfig> tmp = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (int i = 0; i < shuttleList.size(); i++) { | 
|---|
|  |  |  | DeviceConfig deviceConfig = shuttleList.get(i); | 
|---|
|  |  |  | if (i != 0 && i % threadControlCount == 0) { | 
|---|
|  |  |  | lists.add(tmp); | 
|---|
|  |  |  | tmp = new ArrayList<>(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tmp.add(deviceConfig); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | lists.add(tmp); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (List<DeviceConfig> list : lists) { | 
|---|
|  |  |  | if (list.isEmpty()) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int taskNo = Integer.parseInt(String.valueOf(object)); | 
|---|
|  |  |  | if (taskNo != 0) { | 
|---|
|  |  |  | //存在任务需要执行 | 
|---|
|  |  |  | boolean result = shuttleAction.executeWork(deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | new Thread(() -> { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | for (DeviceConfig deviceConfig : list) { | 
|---|
|  |  |  | Object object = redisUtil.get(RedisKeyType.SHUTTLE_FLAG.key + deviceConfig.getDeviceNo()); | 
|---|
|  |  |  | if (object == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int taskNo = Integer.parseInt(String.valueOf(object)); | 
|---|
|  |  |  | if (taskNo != 0) { | 
|---|
|  |  |  | //存在任务需要执行 | 
|---|
|  |  |  | long startTime = System.currentTimeMillis(); | 
|---|
|  |  |  | News.info("[RCS Debug] Execute {},{}", deviceConfig.getDeviceNo(), taskNo); | 
|---|
|  |  |  | // 在循环中使用 | 
|---|
|  |  |  | boolean result = TimeoutExecutor.executeWithTimeout( | 
|---|
|  |  |  | () -> shuttleAction.executeWork(deviceConfig.getDeviceNo(), taskNo), | 
|---|
|  |  |  | 30,  // 30秒超时 | 
|---|
|  |  |  | TimeUnit.SECONDS | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | Thread.sleep(100); | 
|---|
|  |  |  | News.info("[RCS Debug] Execute end {},{},{}", deviceConfig.getDeviceNo(), taskNo, System.currentTimeMillis() - startTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }).start(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|