From 1b007b8d43f82cf86e3cf5f2a316f30bae51deb2 Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期五, 23 五月 2025 12:53:40 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/shuttle_rcs' into shuttle_rcs

---
 src/main/java/com/zy/core/thread/impl/NyShuttleThread.java |   21 ++++++++++++++-------
 1 files changed, 14 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/impl/NyShuttleThread.java b/src/main/java/com/zy/core/thread/impl/NyShuttleThread.java
index 126281a..33142bc 100644
--- a/src/main/java/com/zy/core/thread/impl/NyShuttleThread.java
+++ b/src/main/java/com/zy/core/thread/impl/NyShuttleThread.java
@@ -42,6 +42,7 @@
 import java.io.IOException;
 import java.io.InputStreamReader;
 import java.io.OutputStreamWriter;
+import java.net.InetAddress;
 import java.net.Socket;
 import java.text.MessageFormat;
 import java.util.*;
@@ -1067,12 +1068,15 @@
     @Override
     public boolean connect() {
         try {
-            Socket socket = new Socket(slave.getIp(), slave.getPort());
-            socket.setSoTimeout(10000);
-            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) {
+            InetAddress address = InetAddress.getByName(slave.getIp());
+            if (address.isReachable(10000)) {
+                Socket socket = new Socket(slave.getIp(), slave.getPort());
+                socket.setSoTimeout(10000);
+                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 (Exception 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 false;
         }
@@ -1194,7 +1198,10 @@
            writer.flush();
 //            System.out.println("Sent message to server: " + JSON.toJSONString(httpCommand));
        }catch (Exception e) {
-           e.printStackTrace();
+//           e.printStackTrace();
+//           System.out.println("socket write error");
+           this.socket.close();
+           this.socket = null;
        }
     }
 

--
Gitblit v1.9.1