Browse Source

Merge remote-tracking branch 'origin/master'

master
修宁 6 months ago
parent
commit
78641e1849
  1. 5
      servo/src/main/java/com/galaxis/rcs/ptr/AmrMessageHandler.java
  2. 95
      servo/src/main/java/com/galaxis/rcs/ptr/PtrMqttClient.java

5
servo/src/main/java/com/galaxis/rcs/ptr/AmrMessageHandler.java

@ -19,6 +19,7 @@ import org.clever.core.BannerUtils;
import org.clever.core.json.JsonWrapper; import org.clever.core.json.JsonWrapper;
import org.clever.core.mapper.BeanCopyUtils; import org.clever.core.mapper.BeanCopyUtils;
import org.clever.data.redis.Redis; import org.clever.data.redis.Redis;
import org.clever.data.redis.RedisAdmin;
import org.eclipse.paho.mqttv5.client.MqttClient; import org.eclipse.paho.mqttv5.client.MqttClient;
import org.eclipse.paho.mqttv5.common.MqttException; import org.eclipse.paho.mqttv5.common.MqttException;
import org.eclipse.paho.mqttv5.common.MqttMessage; import org.eclipse.paho.mqttv5.common.MqttMessage;
@ -65,7 +66,7 @@ public class AmrMessageHandler {
private static final TypeReference<AmrMessage<AmrExceptionMessage>> typeRef20250Message = new TypeReference<AmrMessage<AmrExceptionMessage>>() { private static final TypeReference<AmrMessage<AmrExceptionMessage>> typeRef20250Message = new TypeReference<AmrMessage<AmrExceptionMessage>>() {
}; };
private static final Redis redis = AppContextHolder.getBean("defaultRedis", Redis.class, true); private static final Redis redis = RedisAdmin.getRedis();
public final LogisticsRuntime runtime; public final LogisticsRuntime runtime;
private volatile PtrMqttClient ptrMqttClient; private volatile PtrMqttClient ptrMqttClient;
@ -162,7 +163,7 @@ public class AmrMessageHandler {
break; break;
case AMR_HEARTBEAT: case AMR_HEARTBEAT:
AmrMessage<AmrHeartbeatMessage> heartbeatMessage = JacksonUtils.parse(json, typeRef20100Message); AmrMessage<AmrHeartbeatMessage> heartbeatMessage = JacksonUtils.parse(json, typeRef20100Message);
sendCmdHeartBeat(heartbeatMessage.content.VehicleId + ""); // sendCmdHeartBeat(heartbeatMessage.content.VehicleId + "");
handleHeartbeatMessage(agvItem, heartbeatMessage.content); handleHeartbeatMessage(agvItem, heartbeatMessage.content);
break; break;
case AMR_BOOT: case AMR_BOOT:

95
servo/src/main/java/com/galaxis/rcs/ptr/PtrMqttClient.java

@ -1,84 +1,90 @@
package com.galaxis.rcs.ptr; package com.galaxis.rcs.ptr;
import com.google.common.base.Splitter;
import com.yvan.logisticsEnv.EnvPayload; import com.yvan.logisticsEnv.EnvPayload;
import com.yvan.logisticsModel.LogisticsRuntime;
import lombok.SneakyThrows; import lombok.SneakyThrows;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.clever.core.BannerUtils; import org.clever.core.BannerUtils;
import org.clever.core.json.JsonWrapper;
import org.eclipse.paho.mqttv5.client.*; import org.eclipse.paho.mqttv5.client.*;
import org.eclipse.paho.mqttv5.common.MqttException; import org.eclipse.paho.mqttv5.common.MqttException;
import org.eclipse.paho.mqttv5.common.MqttMessage; import org.eclipse.paho.mqttv5.common.MqttMessage;
import org.eclipse.paho.mqttv5.common.packet.MqttProperties; import org.eclipse.paho.mqttv5.common.packet.MqttProperties;
import java.net.InetAddress;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.concurrent.CountDownLatch;
@Slf4j @Slf4j
public class PtrMqttClient implements MqttCallback { public class PtrMqttClient implements MqttCallback {
public final AmrMessageHandler amrMessageHandler; public final AmrMessageHandler amrMessageHandler;
public final EnvPayload.MqttConfig mqttConfig; public final EnvPayload.MqttConfig mqttConfig;
private final MqttClient clientForSend;
private final MqttClient client; private final MqttClient client;
private final String clientId;
private CountDownLatch connectLatch = new CountDownLatch(1);
@SneakyThrows @SneakyThrows
public PtrMqttClient(AmrMessageHandler handler, EnvPayload.MqttConfig mqttConfig, String clientId) { public PtrMqttClient(AmrMessageHandler handler, EnvPayload.MqttConfig mqttConfig, String clientId) {
this.amrMessageHandler = handler; this.amrMessageHandler = handler;
this.mqttConfig = mqttConfig; this.mqttConfig = mqttConfig;
this.clientId = clientId;
String brokerUrl = mqttConfig.getBrokerUrl(); String brokerUrl = mqttConfig.getBrokerUrl(); // "tcp://10.10.203.239:1885"
String username = mqttConfig.getUsername(); String username = mqttConfig.getUsername(); // admin
String password = mqttConfig.getPassword(); String password = mqttConfig.getPassword(); // admin
client = new MqttClient(brokerUrl, clientId); clientForSend = new MqttClient(brokerUrl, clientId + "_send"); // String clientId = "LUOYIFAN-PC_send"
client = new MqttClient(brokerUrl, clientId); // String clientId = "LUOYIFAN-PC"
MqttConnectionOptions options = new MqttConnectionOptions(); MqttConnectionOptions options = new MqttConnectionOptions();
options.setServerURIs(new String[]{brokerUrl}); options.setServerURIs(new String[]{brokerUrl});
options.setAutomaticReconnect(true); options.setAutomaticReconnect(true);
options.setUserName(username); options.setUserName(username);
options.setPassword(password.getBytes()); options.setPassword(password.getBytes());
options.setConnectionTimeout(10); options.setConnectionTimeout(1);
options.setKeepAliveInterval(20); options.setKeepAliveInterval(20);
options.setExecutorServiceTimeout(1);
client.setCallback(this); client.setCallback(this);
client.connect(options); client.connect(options);
clientForSend.connect(options);
connectLatch.await();
BannerUtils.printConfig(log, "MQTT 开启监听成功", new String[]{
"brokerUrl: " + brokerUrl,
"userName: " + username,
"clientId: " + clientId,
"topic: /agv_robot/status"});
client.subscribe("/agv_robot/status", 0); client.subscribe("/agv_robot/status", 0);
} }
@SneakyThrows @SneakyThrows
public void publish(String topic, String payload) { public void publish(String topic, String payloadString) {
this.client.publish(topic, payload.getBytes(StandardCharsets.UTF_8), 0, false); MqttMessage message = new MqttMessage(payloadString.getBytes(StandardCharsets.UTF_8));
message.setQos(0);
message.setRetained(false);
if (this.clientForSend.isConnected()) {
this.clientForSend.publish(topic, message);
} else {
throw new RuntimeException("MQTT client is not connected, cannot publish message.");
}
log.info("Message published to topic {}: finish", topic);
} }
@SneakyThrows @SneakyThrows
public static void main(String[] args) { public static void main(String[] args) {
String brokerUrl = "tcp://10.10.203.239:1885"; var config = new EnvPayload.MqttConfig();
String clientId = "yvan-rcs-dev"; config.setBrokerUrl("tcp://10.10.203.239:1885");
String topic = "test/topic"; config.setUsername("admin");
String content = "Hello from Java"; config.setPassword("admin");
String username = "admin";
String password = "admin"; PtrMqttClient mqttClient = new PtrMqttClient(null, config, "LUOYIFAN-PC");
int qos = 0; for (int i = 0; i < 100; i++) {
mqttClient.publish("/agv_robot/status", "Hello from Java " + i);
MqttClient client = new MqttClient(brokerUrl, clientId); }
MqttConnectionOptions options = new MqttConnectionOptions(); log.info("Message published successfully.");
options.setServerURIs(new String[]{brokerUrl});
options.setAutomaticReconnect(true);
options.setUserName(username);
options.setPassword(password.getBytes());
options.setConnectionTimeout(10);
options.setKeepAliveInterval(20);
System.out.println("Connecting to broker...");
client.connect(options);
System.out.println("Connected");
System.out.println("Publishing message...");
long start = System.currentTimeMillis();
client.publish(topic, content.getBytes(), qos, false);
System.out.println("Published in " + (System.currentTimeMillis() - start) + " ms");
client.disconnect();
System.out.println("Disconnected");
} }
@Override @Override
@ -96,7 +102,11 @@ public class PtrMqttClient implements MqttCallback {
switch (topic) { switch (topic) {
case "/agv_robot/status": case "/agv_robot/status":
try { try {
amrMessageHandler.handleAgvRobotStatusMessage(message); if (this.amrMessageHandler == null) {
log.info("amrMessageHandler is null, skipping message handling {}", new String(message.getPayload(), StandardCharsets.UTF_8));
return;
}
this.amrMessageHandler.handleAgvRobotStatusMessage(message);
} catch (Exception e) { } catch (Exception e) {
log.error("amrMessageHandler.handleAgvRobotStatusMessage 异常", e); log.error("amrMessageHandler.handleAgvRobotStatusMessage 异常", e);
@ -109,11 +119,14 @@ public class PtrMqttClient implements MqttCallback {
@Override @Override
public void deliveryComplete(IMqttToken token) { public void deliveryComplete(IMqttToken token) {
log.info("Message delivery complete: {}", token);
} }
@Override @Override
public void connectComplete(boolean reconnect, String serverURI) { public void connectComplete(boolean reconnect, String serverURI) {
BannerUtils.printConfig(log, "MQTT 开启监听", new String[]{serverURI + " topic: /agv_robot/status"}); // BannerUtils.printConfig(log, "MQTT 开启监听", new String[]{serverURI + " topic: /agv_robot/status"});
log.info("MQTT client connected to server: {}", serverURI);
connectLatch.countDown(); // 放行
} }
@Override @Override

Loading…
Cancel
Save