From d3cc456ffe53a2423c80377d4d96b79459405e29 Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期六, 09 九月 2023 16:21:09 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/NyShuttleThread.java | 124 +++++++++++++++++++++++++++++++++++++---- 1 files changed, 111 insertions(+), 13 deletions(-) diff --git a/src/main/java/com/zy/core/thread/NyShuttleThread.java b/src/main/java/com/zy/core/thread/NyShuttleThread.java index f829281..788a303f 100644 --- a/src/main/java/com/zy/core/thread/NyShuttleThread.java +++ b/src/main/java/com/zy/core/thread/NyShuttleThread.java @@ -10,6 +10,7 @@ import com.zy.asrs.utils.Utils; import com.zy.common.model.NavigateNode; +import com.zy.common.model.NyShuttleOperaResult; import com.zy.common.utils.*; import com.zy.core.News; import com.zy.core.ThreadHandler; @@ -27,6 +28,8 @@ import lombok.Data; import lombok.extern.slf4j.Slf4j; +import java.io.IOException; +import java.net.Socket; import java.text.MessageFormat; import java.util.ArrayList; import java.util.Date; @@ -42,6 +45,7 @@ private ShuttleSlave slave; private NyShuttleProtocol shuttleProtocol; private RedisUtil redisUtil; + private Socket socket; public NyShuttleThread(ShuttleSlave slave,RedisUtil redisUtil) { this.slave = slave; @@ -83,6 +87,10 @@ private void read() { try { + if (this.socket == null || this.socket.isClosed()) { + //閾炬帴鏂紑閲嶆柊閾炬帴 + this.connect(); + } readStatus(); //鍥涘悜绌挎杞︾┖闂层�佹湁浠诲姟銆佹爣璁颁负true銆佸瓨鍦ㄤ换鍔℃寚浠わ紝闇�瑕佹墽琛屼换鍔$殑涓嬩竴鏉℃寚浠� if (shuttleProtocol.getFree() == ShuttleStatusType.IDLE.id @@ -107,9 +115,10 @@ //----------璇诲彇鍥涘悜绌挎杞︾姸鎬�----------- NyShuttleHttpCommand readStatusCommand = NyHttpUtils.getReadStatusCommand(slave.getId()); - JSONObject jsonObject = NyHttpUtils.requestCommand(readStatusCommand); + JSONObject jsonObject = NyHttpUtils.requestCommand(socket, readStatusCommand); if (jsonObject == null) { - OutputQueue.SHUTTLE.offer(MessageFormat.format("銆恵0}銆戝洓鍚戠┛姊溅plc鐘舵�佷俊鎭け璐� ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); + shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.OFFLINE); + OutputQueue.SHUTTLE.offer(MessageFormat.format("銆恵0}銆戝洓鍚戠┛姊溅Socket鐘舵�佷俊鎭け璐� ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); }else { //鎵嬪姩鐘舵��/鑷姩鐘舵�� shuttleProtocol.setWorkingMode(jsonObject.getInteger("workingMode")); @@ -158,7 +167,7 @@ errCode.add(Integer.parseInt(o.toString())); } //鏁呴殰鐮� - shuttleProtocol.setErrCode(errCode); + shuttleProtocol.setErrCode(errCode.get(0)); //鎬婚噷绋嬫暟 shuttleProtocol.setStatusSum(jsonObject.getObject("statusSum", NyShuttleProtocol.StatusSumClass.class)); //闈炶嚜鍔ㄧ姸鎬佹椂闂磋鏃� @@ -235,12 +244,29 @@ } } catch (Exception e) { e.printStackTrace(); - OutputQueue.SHUTTLE.offer(MessageFormat.format("銆恵0}銆戝洓鍚戠┛姊溅plc鐘舵�佷俊鎭け璐� ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); + OutputQueue.SHUTTLE.offer(MessageFormat.format("銆恵0}銆戝洓鍚戠┛姊溅Socket鐘舵�佷俊鎭け璐� ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); + try { + this.socket.close(); + this.socket = null; + Thread.sleep(1000); + this.connect(); + } catch (IOException | InterruptedException exception) { + e.printStackTrace(); + } } } @Override public boolean connect() { + try { + Socket socket = new Socket(slave.getIp(),slave.getPort()); + socket.setSoTimeout(60000); + socket.setKeepAlive(true); + this.socket = socket; + log.info(MessageFormat.format("銆恵0}銆戝洓鍚戠┛姊溅Socket閾炬帴鎴愬姛 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); + } catch (IOException e) { + OutputQueue.SHUTTLE.offer(MessageFormat.format("銆恵0}銆戝洓鍚戠┛姊溅Socket閾炬帴澶辫触 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); + } return true; } @@ -267,7 +293,21 @@ } //鍙戝嚭璇锋眰 - JSONObject result = NyHttpUtils.requestCommand(command); + JSONObject result = null; + try { + result = NyHttpUtils.requestCommand(socket, command); + } catch (IOException e) { + try { + this.socket.close(); + this.socket = null; + Thread.sleep(1000); + this.connect(); + } catch (IOException exception) { + exception.printStackTrace(); + } catch (InterruptedException ex) { + throw new RuntimeException(ex); + } + } if (result == null) { return false;//璇锋眰澶辫触 } @@ -298,15 +338,16 @@ return false; } - WrkMastService wrkMastService = SpringUtils.getBean(WrkMastService.class); + WrkMastMapper wrkMastMapper = SpringUtils.getBean(WrkMastMapper.class); Object o = redisUtil.get("shuttle_wrk_no_" + wrkNo); if (o == null) { return false; } + ShuttleRedisCommand redisCommand = JSON.parseObject(o.toString(), ShuttleRedisCommand.class); - List<NyShuttleHttpCommand> commands = redisCommand.getAssignCommand().getCommands(); ShuttleAssignCommand assignCommand = redisCommand.getAssignCommand(); + List<NyShuttleHttpCommand> commands = redisCommand.getAssignCommand().getCommands(); //褰撳墠姝ュ簭 int commandStep = redisCommand.getCommandStep(); if (commands.size() == 0) { @@ -363,13 +404,11 @@ return false; } - //妫�鏌ヨ矾寰勬槸鍚﹀彲琛岃蛋(妫�鏌ヨ矾寰勯攣瀹氱姸鎬侊紝妫�娴嬭矾寰勬槸鍚︽湁鍏朵粬灏忚溅) - //妫�娴嬪綋鍓嶈璧拌矾寰勶紝鍜屼笅涓�姝ヨ矾寰� - boolean checkPathIsAvailable = NavigateUtils.checkPathIsAvailable(command.getNodes(), shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo())); - boolean checkPathIsAvailable2 = NavigateUtils.checkPathIsAvailable(nextNodes, shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo())); - if (!checkPathIsAvailable && !checkPathIsAvailable2) { + //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋 + if (!checkPath(command.getNodes(), nextNodes, redisCommand)) { return false; } + //閿佸畾璺緞锛岄攣瀹氬綋鍓嶈矾寰勫拰涓嬩竴姝ヨ矾寰� List<NavigateNode> nodes = command.getNodes(); nodes.addAll(nextNodes); @@ -399,7 +438,8 @@ null, null, JSON.toJSONString(command), - null + null, + JSON.toJSONString(shuttleProtocol) ); shuttleOptService.insert(opt); } @@ -442,6 +482,8 @@ return false; } + WrkMastMapper wrkMastMapper = SpringUtils.getBean(WrkMastMapper.class); + ShuttleRedisCommand redisCommand = JSON.parseObject(o.toString(), ShuttleRedisCommand.class); //褰撳墠姝ュ簭 int commandStep = redisCommand.getCommandStep(); @@ -482,6 +524,12 @@ if (liftProtocol.getLev().intValue() == Utils.getLev(shuttleProtocol.getCurrentLocNo())) { return true;//鎻愬崌鏈鸿揪鍒板皬杞︽ゼ灞傦紝鏀捐 + } + + //鎼滅储鏄惁鏈夊叾浠栦换鍔″崰鐢ㄤ簡鎻愬崌鏈猴紝濡傛灉鍗犵敤鎻愬崌鏈虹殑浠诲姟鍜屽綋鍓嶄换鍔$浉鍚岋紝鍒欒繍琛屾墽琛� + WrkMast wrkMast1 = wrkMastMapper.selectLiftWrkMast(liftProtocol.getLiftNo().intValue()); + if (wrkMast1 != null && wrkMast1.getWrkNo() != wrkNo.intValue()) { + return false; } //鎻愬崌鏈烘湭鍒拌揪灏忚溅妤煎眰锛屽懠鍙彁鍗囨満 @@ -545,4 +593,54 @@ return false;//榛樿涓嶆斁琛� } + /** + * 妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋 + * 濡傛灉璺緞涓虹洰鏍囧簱浣嶏紝浣嗕笉鍙璧帮紝绯荤粺灏嗗皾璇曢噸鏂拌绠楄矾寰� + */ + private boolean checkPath(List<NavigateNode> currentNodes, List<NavigateNode> nextNodes, ShuttleRedisCommand redisCommand) { + //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋(妫�鏌ヨ矾寰勯攣瀹氱姸鎬侊紝妫�娴嬭矾寰勬槸鍚︽湁鍏朵粬灏忚溅) + //妫�娴嬪綋鍓嶈璧拌矾寰勶紝鍜屼笅涓�姝ヨ矾寰� + boolean checkPathIsAvailable = NavigateUtils.checkPathIsAvailable(currentNodes, shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo())); + boolean checkPathIsAvailable2 = NavigateUtils.checkPathIsAvailable(nextNodes, shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo())); + if (checkPathIsAvailable && checkPathIsAvailable2) { + return true;//鍙璧� + } + + ShuttleAssignCommand assignCommand = redisCommand.getAssignCommand(); + NavigateNode currentTarget = currentNodes.get(currentNodes.size() - 1); + String currentLocNo = NavigatePositionConvert.nodeToLocNo(currentTarget); + NavigateNode nextTarget = nextNodes.get(nextNodes.size() - 1); + String nextLocNo = NavigatePositionConvert.nodeToLocNo(nextTarget); + if (assignCommand.getLocNo().equals(currentLocNo) || assignCommand.getLocNo().equals(nextLocNo)) { + //褰撳墠璺緞鏈�鍚庝竴涓妭鐐规槸鐩爣搴撲綅锛岃繘琛岃矾寰勬娴嬶紝濡傛灉涓嶅彲琛岃蛋锛岄噸鏂拌绠楄矾寰� + //涓嶅彲琛岃蛋锛岄噸鏂拌绠楄矾寰� + NyShuttleOperaResult result = NyShuttleOperaUtils.getStartToTargetCommands(shuttleProtocol.getShuttleNo().intValue(), shuttleProtocol.getTaskNo(), shuttleProtocol.getCurrentLocNo(), assignCommand.getLocNo()); + if (result == null) { + return false;//璺緞璁$畻澶辫触锛屼笉鍙璧� + } + + List<NyShuttleHttpCommand> newCommands = result.getCommands();//鏂拌矾寰� + + //褰撳墠姝ュ簭 + int commandStep = redisCommand.getCommandStep(); + List<NyShuttleHttpCommand> commands = assignCommand.getCommands(); + + commands.remove(commandStep);//绉婚櫎褰撳墠姝ュ簭鎸囦护 + if (assignCommand.getLocNo().equals(currentLocNo)) { + //褰撳墠璺緞锛岄渶瑕佸啀澶氱Щ闄や笅涓�姝ユ寚浠� + commands.remove(commandStep + 1); + } + + //灏嗘柊璺緞娣诲姞杩涙寚浠ら泦鍚� + commands.addAll(commandStep, newCommands); + assignCommand.setCommands(commands); + redisCommand.setAssignCommand(assignCommand); + //浠诲姟鏁版嵁淇濆瓨鍒皉edis + redisUtil.set("shuttle_wrk_no_" + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand)); + return false;//褰撳墠涓嶅彲琛岃蛋锛岀瓑寰呬笅涓�娆℃墽琛岃蛋鏂拌矾寰� + } + + return false;//涓嶅彲琛岃蛋 + } + } -- Gitblit v1.9.1