Mqtt Paho客户端连接始终打开

时间:2016-10-05 07:40:18

标签: java tomcat7 mqtt paho

我创建了mqtt连接 suscribeData(),如下所示,从多个设备24/7接收数据

@RequestMapping("/suscribe")
@ResponseBody
public String suscribeData(){

    connOpt= new MqttConnectOptions();
    connOptPublish= new MqttConnectOptions();
    boolean result=false;
    int retry=0;
    while(!result){
        try{
            result=initializeMqTTParameters(retry); 
            retry++;
            if(!result){
                Thread.sleep(1000);
            }

        }catch(Exception ex){

        }
        if(retry>10){
            return "mqtterror";
        }

    }
        suscribeReceivedData("DATA/#",2);
        Calendar cal=TimeZoneJu.getCalenderInstance();
        ModemOnlineStatus status=new ModemOnlineStatus();
        status.setActiondate(cal.getTime());
        status.setActiontime(cal.getTime());
        status.setModemid("mqttreceive");
        status.setRemark("online");
        status.setStatus(true);
        try{

            service.checkAndInsertModemStatus(true, status);    
        }catch(Exception ex1){

        }
        return "ok";
}

checkAndInsertModemStatus()函数用于保存联机的在线脱机状态我使用cronjobs检查来自其他网址的连接。

以下是我的 initializeMqTTParameters

public boolean initializeMqTTParameters(int retry){
        String clientID = M2MIO_THING;
        connOpt = new MqttConnectOptions();

        connOpt.setCleanSession(false);
        connOpt.setUserName(M2MIO_USERNAME);
        connOpt.setPassword(M2MIO_PASSWORD_MD5.toCharArray());
        connOpt.setWill("WILL/mqttreceive", "mqttreceive:disconnected".getBytes(), 2, true);
        try {

            if(retry%2==0){
                MQTTReceive.myClient = new MqttClient(BROKER_URL, "mqtt_virtual_received_sus_1");   
            }else{
                MQTTReceive.myClient = new MqttClient(BROKER_URL, "mqtt_virtual_received_sus_2");   
            }

            MQTTReceive.myClient.setCallback(this);
            MQTTReceive.myClient.connect(connOpt);

        } catch (MqttException e) {
            System.out.println(e.getMessage());
            return false;
        }
        return true;
    }

on connectionLost 我正在尝试在数据库中更新状态并尝试重新连接

@Override
    public void connectionLost(Throwable ex) {
        System.out.println("Mqtt Received Connection Lost"+ex.getMessage()); 
        Calendar cal=TimeZoneJu.getCalenderInstance();
        ModemOnlineStatus status=new ModemOnlineStatus();
        status.setActiondate(cal.getTime());
        status.setActiontime(cal.getTime());
        status.setModemid("mqttreceive");
        status.setRemark("offline");
        status.setStatus(false);
        try{

        service.updateModemStatus(false, status);   
    }catch(Exception ex1){

    }

    suscribeData();
}

从上面的代码我得到我的连接在线,但我停止接收订阅主题的数据所以另一种方法,我尝试,我从数据库中的另一个功能检查连接状态,如我在线连接和离线时设置连接connectionLost和我可以调用connect( suscribeData())但是在几天内我在tomcat中留下了太多打开的文件如何确保以前打开的文件应该关闭

connectionLost()上的System.exit(1)类似,以便当前进程关闭,我将在检查状态后重新连接

或者请建议我是否有任何其他逻辑我可以用来维持我的联系

1 个答案:

答案 0 :(得分:0)

你的catch块在方法 connectionLost 中什么都不做..它应该做这样的事情:

 catch (Exception e)
         {
              e.printStackTrace();
              System.exit(1);
          }

如果不需要,您还应该断开您的MQTT客户端。即处理:

myClient.disconnect();