java paho 库中的行为 setTimeToWait() 方法
Behaviour setTimeToWait() method in java paho library
我使用库 paho 与 mqtt 代理连接,发送消息,几乎一切正常,但我对 setTimeToWait() 方法有疑问。它不会影响我在方法 setTimeToWait(2000) 或 setTimeToWait(10) 中投入了多少毫秒。我总是收到来自 publiusher 的消息。
为什么我可以在几个小时内收到消息?如果我将等待时间设置为 2000 毫秒。 我认为在 2 秒后没有来自发布者的消息,我的订阅者无法从发布者接收消息并且控制将被返回。
我做错了什么?
出版商代码:
public class MqttPublishSample {
public static void main(String[] args) throws MqttException {
String messageString = "{\"device_status\": \"ready\"}";
if (
args.length == 2 ) {
messageString = args[1];
}
System.out.println("== START PUBLISHER ==");
MqttClient client = new MqttClient("tcp://localhost:1883" , MqttClient.generateClientId());
client.connect();
MqttMessage message = new MqttMessage();
message.setPayload(messageString.getBytes());
message.setQos(1);
client.publish("/catalog", message);
System.out.println("\tMessage '"+ messageString +"' to 'iot_data'");
client.disconnect();
System.out.println("== END PUBLISHER ==");
}
}
订阅者代码:
public class MqttSuscribeSample {
public static void main(String[] args) {
System.out.println("== START SUBSCRIBER ==");
try{
MqttClient client=new MqttClient("tcp://localhost:1883", MqttClient.generateClientId());
client.setTimeToWait(2000);
client.setCallback( new SimpleMqttCallback() );
client.connect();
client.subscribe( "/catalog");
}catch (Exception ex){
ex.printStackTrace();
}
}
}
SimpleMqttCallback 代码
public class SimpleMqttCallback implements MqttCallback {
public void connectionLost(Throwable throwable) {
System.out.println("Connection to MQTT broker lost!");
}
public void messageArrived(String s, MqttMessage mqttMessage) throws Exception {
System.out.println("Message received:\t"+ new String(mqttMessage.getPayload()) );
}
public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {
}
}
setTimeToWait()
方法是客户端在执行特定操作时等待代理响应的时间,例如
- 发布消息
- 进行订阅
- 连接或断开与代理的连接
这不是客户端应等待多长时间或为现有订阅传递消息。
如果您想要这种行为,您需要 运行 您自己的计时器,并在超时时取消订阅该主题或断开与代理的连接。
我使用库 paho 与 mqtt 代理连接,发送消息,几乎一切正常,但我对 setTimeToWait() 方法有疑问。它不会影响我在方法 setTimeToWait(2000) 或 setTimeToWait(10) 中投入了多少毫秒。我总是收到来自 publiusher 的消息。
为什么我可以在几个小时内收到消息?如果我将等待时间设置为 2000 毫秒。 我认为在 2 秒后没有来自发布者的消息,我的订阅者无法从发布者接收消息并且控制将被返回。
我做错了什么?
出版商代码:
public class MqttPublishSample {
public static void main(String[] args) throws MqttException {
String messageString = "{\"device_status\": \"ready\"}";
if (
args.length == 2 ) {
messageString = args[1];
}
System.out.println("== START PUBLISHER ==");
MqttClient client = new MqttClient("tcp://localhost:1883" , MqttClient.generateClientId());
client.connect();
MqttMessage message = new MqttMessage();
message.setPayload(messageString.getBytes());
message.setQos(1);
client.publish("/catalog", message);
System.out.println("\tMessage '"+ messageString +"' to 'iot_data'");
client.disconnect();
System.out.println("== END PUBLISHER ==");
}
}
订阅者代码:
public class MqttSuscribeSample {
public static void main(String[] args) {
System.out.println("== START SUBSCRIBER ==");
try{
MqttClient client=new MqttClient("tcp://localhost:1883", MqttClient.generateClientId());
client.setTimeToWait(2000);
client.setCallback( new SimpleMqttCallback() );
client.connect();
client.subscribe( "/catalog");
}catch (Exception ex){
ex.printStackTrace();
}
}
}
SimpleMqttCallback 代码
public class SimpleMqttCallback implements MqttCallback {
public void connectionLost(Throwable throwable) {
System.out.println("Connection to MQTT broker lost!");
}
public void messageArrived(String s, MqttMessage mqttMessage) throws Exception {
System.out.println("Message received:\t"+ new String(mqttMessage.getPayload()) );
}
public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {
}
}
setTimeToWait()
方法是客户端在执行特定操作时等待代理响应的时间,例如
- 发布消息
- 进行订阅
- 连接或断开与代理的连接
这不是客户端应等待多长时间或为现有订阅传递消息。
如果您想要这种行为,您需要 运行 您自己的计时器,并在超时时取消订阅该主题或断开与代理的连接。