繁体   English   中英

AWS JAVA IoT 客户端重新连接和超时

[英]AWS JAVA IoT client reconnections and timeouts

我在 CONNECTED/DISCONNECTED 主题上使用 IoT 规则(从这里开始)。 所以我想在连接或断开设备时获得 email 。 在我的设备上,我在启动时运行下一个代码(仅在启动时):

iotClient = new AWSIotMqttClient(Configuration.IOT_CLIENT_ENDPOINT,
                    deviceId,
                    keyStore,
                    keystorePass);
            
iotClient.setKeepAliveInterval(1200000); //20 minutes (maximum)
iotClient.connect();

但我得到了非常奇怪的行为。 我有 3 台设备,在每台设备上我都得到了这个堆栈跟踪,但由于不同的原因:

[pool-8-thread-1] com.amazonaws.services.iot.client.core.AwsIotConnection.onConnectionSuccess Connection successfully established
[pool-8-thread-1] com.amazonaws.services.iot.client.core.AbstractAwsIotClient.onConnectionSuccess Client connection active: <client ID>
[pool-8-thread-1] com.amazonaws.services.iot.client.core.AwsIotConnection.onConnectionFailure Connection temporarily lost
[pool-8-thread-1] com.amazonaws.services.iot.client.core.AbstractAwsIotClient.onConnectionFailure Client connection lost: <client ID>
[pool-8-thread-1] com.amazonaws.services.iot.client.core.AwsIotConnection$1.run Connection is being retried
[pool-8-thread-1] com.amazonaws.services.iot.client.core.AwsIotConnection.onConnectionSuccess Connection successfully established
[pool-8-thread-1] com.amazonaws.services.iot.client.core.AbstractAwsIotClient.onConnectionSuccess Client connection active: <client ID>

有时由于 DUPLICATE_CLIENTID 断开原因,或者有时由于 MQTT_KEEP_ALIVE_TIMEOUT 断开原因(MQTT_KEEP_ALIVE_TIMEOUT 每 30-35 分钟发生一次,DUPLICATE_CLIENTID 每 10 分钟发生一次),我得到这个堆栈跟踪

所以,我不明白为什么我需要处理 DUPLICATE_CLIENTID 如果每个客户端都有一个唯一的 ID ,并处理 MQTT_KEEP_ALIVE_TIMEOUT 如果没有间歇性连接问题(我每分钟都会收到日志到我的服务器,所以它不是WIFI/互联网问题)。 我从这里使用最新的 AWS IoT SDK - https://github.com/aws/aws-iot-device-sdk-java

我该如何解决这些问题?

我的棘手解决方案:

我添加了一个预定线程,该线程将空消息发送到主题 - ${iot:Connection.Thing.ThingName}/ping 每 20 分钟:

scheduledExecutor.scheduleAtFixedRate(() -> {
    try {
        iotClient.publish(String.format(Configuration.PING_TOPIC, deviceId), AWSIotQos.QOS0, "");
    } catch (AWSIotException e) {
        LOGGER.error("Failed to send ping", e);
    }
}, Configuration.PING_INITIAL_DELAY_IN_MINUTES, Configuration.PING_PERIOD_IN_MINUTES, TimeUnit.MINUTES);

所以这个解决方案解决了非活动问题,但我仍然想找到一个更优雅的解决方案......

查看您的日志,似乎连接丢失,然后重试连接。

在重新连接期间,它仍然使用您传递的 deviceID 进行连接(但是连接可能从 MQTT 端不存在),因此它看到它正在尝试使用相同的 id 进行连接。

阅读一些关于此的内容,看起来您可能实际上并未将您的设备注册为 aws 中的(事物)。

如果你是,当你创建一个 MQTT 连接并传递那个 thingId 时,即使在重新连接时,它也不会给你那个 DuplicateID 错误。

     AWSIotMqttClient client = new AWSIotMqttClient(...);
     
     SomeDevice someDevice = new SomeDevice(thingName);    // SomeDevice extends AWSIotDevice
     
     client.attach(someDevice);
     
     client.connect();

您还可以尝试使用iotClient.cleanSession(true/false)看看是否可以帮助您。

/** * 设置客户端和服务器是否应该在每个连接上建立一个干净的 session。 * 如果为 false,服务器应尝试在连接之间保持客户端的 state。 * 这必须在调用 {@link #connect()} 之前设置。 * * @param cleanSession * 如果为真,服务器在每个连接上与客户端启动一个干净的 session。 * 如果为 false,服务器应在连接之间保持客户端的 state。 */

@Override
public void setCleanSession(boolean cleanSession) { super.setCleanSession(cleanSession); }

https://docs.aws.amazon.com/iot/latest/developerguide/iot-thing-management.html

MQTT_KEEP_ALIVE_TIMEOUT 如果在客户端保持活动时间的 1.5 倍内没有客户端-服务器通信,则客户端断开连接。

这意味着你没有发送/接收消息..没有办法解决这个问题,除非你保持活跃的连接并做事

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM