Плагин MegaD



  • @amgstone

    Создайте кнопку.
    В ней выбирете "команда плагина", выберите свою мегу и напишите эту команду.
    /%pwd%/?cmd=all
    вместо pwd - свой пароль на меге.
    Кнопка будет обновлять состояния всех каналов этой меги.



  • @Erik у маня созданы ACTOR для каждой ролокасети, можно как то чтобы в ACTORе обновлялось состояние, нету описания на эту тему. Чтобы использовать эти значения в сценарии.
    Ну и у меня открытие и закрытие подключено к 2 разных реле через: ```

    this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p200;'+jalusi.getParam('point_open')+':0'});
    

    ну и по аналогии закрытие
    Вопрос как мне с 2 реле собрать информацию в одном акторе чтобы видеть последнее состояния с реле, чтобы ІН знал жалюзя сейчас открыта или закрыта, нету обратной связи.

    скрипт

    /** 
    * @name Новый мультисценарий 
    * @desc  
    * @version 4 
    */
    const switch_1 = Device("ActorE","Switch");
    const jalusi = Device("ActorD","Actor",[
        {"name":"point_open", "note":"Пін відкриття", "type":"number", "val":15},
        {"name":"point_close", "note":"Пін закриття", "type":"number", "val":16}
      ]);
    
    startOnChange([switch_1,jalusi]); 
    
    script({
        start() {
          if(this.isChanged(switch_1)){
            this.onSwitch();
          }
          if(this.isChanged(jalusi)){
            this.onJalusi();
          }
        },
        onSwitch(){
          switch(switch_1.value){
              case 0:
                if(jalusi.id === "ACTOR7"){
                  jalusi.on();
                  this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p200;'+jalusi.getParam('point_open')+':0'});
                }
                if(jalusi.id === "ACTOR8"){
                  //this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p210;'+jalusi.getParam('point_open')+':0'});
                }
                if(jalusi.id === "ACTOR9"){
                  //this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p230;'+jalusi.getParam('point_open')+':0'});
                }
              break;
              case 1:
                //this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':0;'+jalusi.getParam('point_close')+':0'});
              break;
              case 2:
                if(jalusi.id === "ACTOR7"){
                  jalusi.off();
                  this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p200;'+jalusi.getParam('point_close')+':0'});
                }
                if(jalusi.id === "ACTOR8"){
                  jalusi.off();
                  this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p210;'+jalusi.getParam('point_close')+':0'});
                }
                if(jalusi.id === "ACTOR9"){
                  this.startTimer('T1', 30, 'turnAllOff');
                }
              break;
            }
            this.log('Жалюзі статус : '+switch_1.value+' '+jalusi.id);
        },
        turnAllOff(){
          jalusi.off();
          this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p240;'+jalusi.getParam('point_close')+':0'});
          this.exit();
        },
        onJalusi(){
          //this.log(this.isChanged(jalusi)+' 38 line');
          if(jalusi.isOn()){
            //this.log('jalusi On');
            if(jalusi.id === "ACTOR7"){
              this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p200;'+jalusi.getParam('point_open')+':0'});
            }
            if(jalusi.id === "ACTOR8"){
              this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p210;'+jalusi.getParam('point_open')+':0'});
            }
            if(jalusi.id === "ACTOR9"){
              this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p240;'+jalusi.getParam('point_open')+':0'});
            }
          }else{
            //this.log('jalusi Off');
            if(jalusi.id === "ACTOR7"){
              this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p200;'+jalusi.getParam('point_close')+':0'});
            }
            if(jalusi.id === "ACTOR8"){
              this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p210;'+jalusi.getParam('point_close')+':0'});
            }
            if(jalusi.id === "ACTOR9"){
              this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p240;'+jalusi.getParam('point_close')+':0'});
            }
          }
          this.exit();
        }
    });
    

    а так в админке http://joxi.ru/DmBRwpQSJvnMNm



  • В этом же скрипте после действия присвойте атуатору нужное значение.
    После каждого действия присвоение соответствующего значения.
    Актуатор будет всегда иметь значение, соответствующее последнему действию.



  • версию 1.1.14 убрали?
    Обновление предлагается на 1.1.13 сегодня.
    alt text



  • Участник @Erik написал в Плагин MegaD:

    версию 1.1.14 убрали?

    Версия 1.1.14 была сделана для тестирования и официально еще не публиковалась.
    При желании ее можно взять на гитхабе.



  • Значит это нервное уже.
    А что в ней нового?



  • @Erik можете подсказать что дописать?



  • После открытия
    Actor.On();
    после закрытия
    Actor.Off();

    Вместо Actor - название нужного актуатора.



  • Участник @Erik написал в Плагин MegaD:

    А что в ней нового?

    В версии v1.1.14 изменение только для параметра канала
    "Использовать функцию обработки при получении данных от контроллера"

    Ранее функция была привязана к номеру порта контроллера, теперь - к идентификатору канала, чтобы это работало для расширенных портов (MCP, I2C)

    Сегодня на github планируем выложить версию v1.1.15, в которой будет:

    1. Решение для одновременной сработки датчиков, подключенных к MCP
      (модуль MegaD-16I-XT)

    2. Возможность обработать в сценарии ответ от контроллера для команды pluginCommand

    Также на github выложен список изменений плагина за этот год :
    https://github.com/intrahouseio/intraHouse.plugin-MegaD файл CHANGELOG



  • @intrapro будет реализована обратная связь (pluginCommand) с ролокасетами? То что я так долго ждал?



  • @amgstone, реализовано получение ответа от контроллера в сценарий:

    script({
        start() {
            // Передать запрос на megad1, ответ придет в сценарий (onResponse:'raw')
            this.pluginCommand({unit:'megad1', command:{url:'/sec/?pt=7&cmd=get', onResponse:'raw'}}, 'getResponse');
            // Взвести таймер на случай, если ответа от контроллера нет
            this.startTimer('T1', 3, 'onTimeout');
        },
        
        getResponse(body) {
          // body 
          this.log('getResponse body= '+body);
         // Анализируем body ....
          this.exit();
        },
        
        onTimeout() {
          this.log('Истек таймаут, ответ от megad1 не получен');
          this.exit();
        }
    });
    

    Если это поможет, то да 🙂



  • @intrapro, так в body будет всего лишь "Done". Какой смысл его анализировать? Собственно, тут написал как правильнее сделать @amgstone



  • @Alex_Jet а у Вас ролета подключена к 2 реле, одно на открытие а второе на закрытие?



  • @amgstone, нет - у меня одно выбирает направление, другое подает питание))). Но от этого суть не меняется.



  • @intrapro, даже не представляю какая полезность будет от доработки по п.2...
    А вы мои выкладки тут не анализировали?
    И да - для Формулы расчета входного значения нужно добавить конвертацию типа данных чтобы не писать "Number(value)+2".

    Update: тестируя версию 1.1.14, я на старом форуме в личных сообщениях писал что не работает.



  • Участник @Alex_Jet написал в Плагин MegaD:

    @intrapro, даже не представляю какая полезность будет от доработки по п.2...

    • Во-первых, такой функционал (функция-обработчик для ответа при выполнении pluginCommand ) добавлен в ядре, и при доработке плагинов добавляем всем, тут просто совпало.
    • Во-вторых, можно ведь послать команду на опрос канала, как в примере:
    this.pluginCommand({unit:'megad1', command:{url:'/sec/?pt=7&cmd=get', onResponse:'raw'}}, 'getResponse');
    

    Для выхода контроллер вернет "ON" или "OFF". Можно иногда использовать, если выход постоянно не опрашивать. Или еще какой экзотический запрос. Да, не несущая конструкция, но пригодится

    И да - для Формулы расчета входного значения нужно добавить конвертацию типа данных чтобы не писать "Number(value)+2".

    Это на сервере считается, в релизе нужно будет поправить

    Update: тестируя версию 1.1.14, я на старом форуме в личных сообщениях писал что не работает.

    Не работает функция для подканала? А мы так поняли что работает 🙂 Личка старого форума к сожалению больше не доступна.

    А вы мои выкладки тут не анализировали?

    Конечно, анализировали, спасибо за подробное описание и предложения. Но пока не хочется ничего менять сущностно. Для версии сервера 5.x будем переделывать плагин с использованием иерархических структур.
    Цель последнего изменения - решение для датчиков, подключенных к MCP. Сейчас нет никакой возможности обработать одновременные сработки.



  • Участник @gis написал в Плагин MegaD:

    Подскажите, будет ли доработан плагин для обработки одновременных срабатываний каналов MegaD-16I-XT?
    Подключил датчики движения, там через раз происходят одновременные срабатывания которые не обрабатываются плагином. Периодически опрашивать датчики движения, как вы понимаете, нет ни какого смысла.

    На github выложена новая версия плагина v1.1.15:
    https://github.com/intrahouseio/intraHouse.plugin-MegaD/releases/tag/v1.1.15

    Нужно скачать zip архив и загрузить его:
    Плагины -> меню Command -> Загрузить из .zip файла

    В новой версии плагина в Расширениях добавлен флаг:
    Расширенный порт (одновременная сработка датчиков)

    Все датчики одного порта pt, которые могут сработать одновременно, нужно прописать в одном запросе (обратите внимание, что MCP расширения (ext) нумеруются с 0, а каналы на сервере с 1, т е ext0 - это 32_1 )

    Пример настройки расширений для порта 32:
    Входящее от контроллера:
    /?pt=32&ext0=*&ext1=*&ext2=*&ext3=*&ext4=*&ext5=*&ext6=*&ext7=*

    Установить состояния каналов:
    32_1=%ext0%&32_2=%ext1%&32_3=%ext2%&32_4=%ext3%&32_5=%ext4%&32_6=%ext5%&32_7=%ext6%&32_8=%ext7%

    Расширенный порт: Да

    В результате, например, такого входящего запроса /pt=32&ext1=1&ext7=0 будут присвоены значения 32_2=1 и 32_8=0

    Просьба счастливых обладателей расширенных портов протестировать функционал 🙂



  • Участник @intrapro написал в Плагин MegaD:

    Не работает функция для подканала? А мы так поняли что работает Личка старого форума к сожалению больше не доступна.

    Да, вот посмотрите лог плагина. Обратите внимание на каналы 30 и 33_ff48a6701605 - для обоих включена функция обработки значений (пишем 5 в массив, сортируем, откидываем крайние и вычисляем среднее с округлением до 2-х знаков после запятой).
    Не буду томить - для канала в режиме DSen->1W все работает, а для DSen->1WBUS не работает, то есть при каждом получении значения оно присваивается устройству сразу же.

    25.12 21:45:56.722 megad1: 
    25.12 21:45:56.723 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=30&cmd=get
    25.12 21:45:56.731 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:45:56.731 megad1:  body: temp:4.62
    25.12 21:45:56.924 megad1: 
    25.12 21:45:56.925 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=31&cmd=get
    25.12 21:45:56.932 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:45:56.933 megad1:  body: temp:3.18
    25.12 21:45:56.933 IH: get [ { id: '31', value: '3.18' } ]
    set { ST_SEWERAGE2: { aval: 3.18, err: 0 } }
    25.12 21:45:57.125 megad1: 
    25.12 21:45:57.126 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=32&cmd=get
    25.12 21:45:57.133 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:45:57.134 megad1:  body: temp:1.62
    25.12 21:45:57.135 IH: get [ { id: '32', value: '1.62' } ]
    set { ST_SEWERAGE3: { aval: 1.62, err: 0 } }
    25.12 21:45:57.327 megad1: 
    25.12 21:45:57.328 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=33&cmd=list
    25.12 21:45:57.387 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:45:57.387 megad1:  body: ff48a6701605:4.12;ff779e701604:2.06
    25.12 21:45:57.390 IH: get [ { id: '33_ff48a6701605', value: '4.12' },
      { id: '33_ff779e701604', value: '2.06' } ]
    set { ST_SEWERAGE4: { aval: 4.12, err: 0 },
      ST_SEWERAGE5: { aval: 2.06, err: 0 } }
    25.12 21:46:56.907 megad1: 
    25.12 21:46:56.908 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=30&cmd=get
    25.12 21:46:56.915 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:46:56.916 megad1:  body: temp:4.62
    25.12 21:46:57.109 megad1: 
    25.12 21:46:57.110 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=31&cmd=get
    25.12 21:46:57.117 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:46:57.118 megad1:  body: temp:3.18
    25.12 21:46:57.118 IH: get [ { id: '31', value: '3.18' } ]
    set { ST_SEWERAGE2: { aval: 3.18, err: 0 } }
    25.12 21:46:57.310 megad1: 
    25.12 21:46:57.310 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=32&cmd=get
    25.12 21:46:57.317 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:46:57.318 megad1:  body: temp:1.62
    25.12 21:46:57.319 IH: get [ { id: '32', value: '1.62' } ]
    set { ST_SEWERAGE3: { aval: 1.62, err: 0 } }
    25.12 21:46:57.511 megad1: 
    25.12 21:46:57.511 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=33&cmd=list
    25.12 21:46:57.571 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:46:57.571 megad1:  body: ff48a6701605:4.12;ff779e701604:2.06
    25.12 21:46:57.573 IH: get [ { id: '33_ff48a6701605', value: '4.12' },
      { id: '33_ff779e701604', value: '2.06' } ]
    set { ST_SEWERAGE4: { aval: 4.12, err: 0 },
      ST_SEWERAGE5: { aval: 2.06, err: 0 } }
    25.12 21:47:57.090 megad1: 
    25.12 21:47:57.092 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=30&cmd=get
    25.12 21:47:57.097 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:47:57.098 megad1:  body: temp:4.56
    25.12 21:47:57.292 megad1: 
    25.12 21:47:57.292 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=31&cmd=get
    25.12 21:47:57.300 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:47:57.300 megad1:  body: temp:3.18
    25.12 21:47:57.301 IH: get [ { id: '31', value: '3.18' } ]
    set { ST_SEWERAGE2: { aval: 3.18, err: 0 } }
    25.12 21:47:57.492 megad1: 
    25.12 21:47:57.493 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=32&cmd=get
    25.12 21:47:57.500 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:47:57.501 megad1:  body: temp:1.62
    25.12 21:47:57.501 IH: get [ { id: '32', value: '1.62' } ]
    set { ST_SEWERAGE3: { aval: 1.62, err: 0 } }
    25.12 21:47:57.694 megad1: 
    25.12 21:47:57.694 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=33&cmd=list
    25.12 21:47:57.754 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:47:57.755 megad1:  body: ff48a6701605:4.12;ff779e701604:2.06
    25.12 21:47:57.756 IH: get [ { id: '33_ff48a6701605', value: '4.12' },
      { id: '33_ff779e701604', value: '2.06' } ]
    set { ST_SEWERAGE4: { aval: 4.12, err: 0 },
      ST_SEWERAGE5: { aval: 2.06, err: 0 } }
    25.12 21:48:57.273 megad1: 
    25.12 21:48:57.273 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=30&cmd=get
    25.12 21:48:57.281 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:48:57.281 megad1:  body: temp:4.56
    25.12 21:48:57.285 IH: get [ { id: '30', value: '4.60' } ]
    set { ST_SEWERAGE1: { aval: 4.6, err: 0 } }
    25.12 21:48:57.474 megad1: 
    25.12 21:48:57.475 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=31&cmd=get
    25.12 21:48:57.482 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:48:57.483 megad1:  body: temp:3.18
    25.12 21:48:57.484 IH: get [ { id: '31', value: '3.18' } ]
    set { ST_SEWERAGE2: { aval: 3.18, err: 0 } }
    25.12 21:48:57.676 megad1: 
    25.12 21:48:57.676 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=32&cmd=get
    25.12 21:48:57.683 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:48:57.684 megad1:  body: temp:1.62
    25.12 21:48:57.685 IH: get [ { id: '32', value: '1.62' } ]
    set { ST_SEWERAGE3: { aval: 1.62, err: 0 } }
    25.12 21:48:57.877 megad1: 
    25.12 21:48:57.877 megad1: localhost => 192.168.11.21 HTTP GET /sec/?pt=33&cmd=list
    25.12 21:48:57.936 megad1: localhost <= 192.168.11.21  response: statusCode=200 contentType = text/html
    25.12 21:48:57.937 megad1:  body: ff48a6701605:4.12;ff779e701604:2.06
    25.12 21:48:57.938 IH: get [ { id: '33_ff48a6701605', value: '4.12' },
      { id: '33_ff779e701604', value: '2.06' } ]
    set { ST_SEWERAGE4: { aval: 4.12, err: 0 },
      ST_SEWERAGE5: { aval: 2.06, err: 0 } }
    

    Но есть нюанс...вот такая функция для DSen->1WBUS вроде работает, поскольку ошибочных значений на графиках нет совсем, и датчики в ошибку не вываливаются:

    function (val, depo)
    {  if(val > 100) return; //Проверяем значение - если ошибочное то выходим
       else return val;        //Иначе возвращаем значение
    }
    

    Функция усреднения такая:

    function (val, depo)
    {  var result;
    
       if (!depo.res) depo.res = [];
       depo.res.push(val);
    
       if (depo.res.length < 5) //Нужны еще измерения, значение не возвращаем
       return;
       else
       { depo.res.sort();
         result = ((depo.res[1] + depo.res[2] + depo.res[3]) / 3).toFixed(2);
       }
    
       depo.res = []; //Перед следующими измерениями сбрасываем массив
       return result; //Возвращаем значение
    }
    


  • @intrapro, еще посмотрите лог плагина - я вам уже говорил, что у меня плагины часто перезапускаются и мы вроде выяснили, что почему-то MegaD иногда либо долго отвечают, либо вообще не отвечают... но сейчас увидел другую картину и не понимаю из-за чего это произошло:

    25.12 22:18:39.941 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:18:42.410 megad4: 
    25.12 22:18:42.411 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=30&cmd=get
    25.12 22:18:42.418 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:18:42.419 megad4:  body: temp:-14.50
    25.12 22:18:42.612 megad4: 
    25.12 22:18:42.612 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=31&cmd=list
    25.12 22:18:42.694 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:18:42.695 megad4:  body: e46477910b02:43.75;666877911402:43.93;35e977910902:42.68
    25.12 22:18:42.698 IH: get [ { id: '31_e46477910b02', value: '43.75' },
      { id: '31_666877911402', value: '43.93' },
      { id: '31_35e977910902', value: '42.68' } ]
    set { ST_HEATING_SYS_02: { aval: 46.75, err: 0 },
      ST_HEATING_SYS_03: { aval: 47.93, err: 0 },
      ST_HEATING_SYS_01: { aval: 47.31, err: 0 } }
    25.12 22:18:42.813 megad4: 
    25.12 22:18:42.813 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=1
    25.12 22:18:42.829 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:18:42.830 megad4:  body: -14.60
    25.12 22:18:43.014 megad4: 
    25.12 22:18:43.014 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280
    25.12 22:18:43.030 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:18:43.031 megad4:  body: 746.94
    25.12 22:18:43.215 megad4: 
    25.12 22:18:43.215 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=2
    25.12 22:18:43.232 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:18:43.232 megad4:  body: 92.73
    25.12 22:19:11.027 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&cnt=6592&mdid=
    25.12 22:19:11.028 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:19:12.023 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&m=2&cnt=6592&mdid=
    25.12 22:19:12.025 IH: get [ { id: '7', value: 6582.6 } ]
    set { METER1_01: { aval: 6582.6, err: 0 } }
    25.12 22:19:12.025 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:19:42.587 megad4: 
    25.12 22:19:42.588 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=30&cmd=get
    25.12 22:19:42.594 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:19:42.595 megad4:  body: temp:-14.43
    25.12 22:19:42.788 megad4: 
    25.12 22:19:42.788 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=31&cmd=list
    25.12 22:19:42.871 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:19:42.871 megad4:  body: e46477910b02:43.75;666877911402:43.87;35e977910902:42.68
    25.12 22:19:42.873 IH: get [ { id: '31_e46477910b02', value: '43.75' },
      { id: '31_666877911402', value: '43.87' },
      { id: '31_35e977910902', value: '42.68' } ]
    set { ST_HEATING_SYS_02: { aval: 46.75, err: 0 },
      ST_HEATING_SYS_03: { aval: 47.87, err: 0 },
      ST_HEATING_SYS_01: { aval: 47.31, err: 0 } }
    25.12 22:19:42.988 megad4: 
    25.12 22:19:42.989 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=1
    25.12 22:19:43.006 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:19:43.006 megad4:  body: -14.55
    25.12 22:19:43.189 megad4: 
    25.12 22:19:43.190 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280
    25.12 22:19:43.207 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:19:43.207 megad4:  body: 746.96
    25.12 22:19:43.287 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&cnt=6593&mdid=
    25.12 22:19:43.288 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:19:43.391 megad4: 
    25.12 22:19:43.393 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=2
    25.12 22:19:43.408 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:19:43.409 megad4:  body: 92.156
    25.12 22:19:44.282 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&m=2&cnt=6593&mdid=
    25.12 22:19:44.284 IH: get [ { id: '7', value: 6582.61 } ]
    set { METER1_01: { aval: 6582.61, err: 0 } }
    25.12 22:19:44.284 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:20:15.916 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&cnt=6594&mdid=
    25.12 22:20:15.916 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:20:16.911 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&m=2&cnt=6594&mdid=
    25.12 22:20:16.913 IH: get [ { id: '7', value: 6582.62 } ]
    set { METER1_01: { aval: 6582.62, err: 0 } }
    25.12 22:20:16.913 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:20:42.762 megad4: 
    25.12 22:20:42.762 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=30&cmd=get
    25.12 22:20:42.769 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:20:42.770 megad4:  body: temp:-14.43
    25.12 22:20:42.772 IH: get [ { id: '30', value: '-14.50' } ]
    set { ST_HEATING_SYS_00: { aval: -14.5, err: 0 } }
    25.12 22:20:42.963 megad4: 
    25.12 22:20:42.963 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=31&cmd=list
    25.12 22:20:43.164 megad4: 
    25.12 22:20:43.164 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=1
    25.12 22:20:43.181 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:20:43.182 megad4:  body: -14.55
    25.12 22:20:43.185 IH: get [ { id: '34_1', value: '-14.59' } ]
    set { STEMP4_01: { aval: -14.59, err: 0 } }
    25.12 22:20:43.364 megad4: 
    25.12 22:20:43.365 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280
    25.12 22:20:43.380 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:20:43.381 megad4:  body: 747.02
    25.12 22:20:43.382 IH: get [ { id: '34_2', value: '746.99' } ]
    set { SPRESSURE4_01: { aval: 746.99, err: 0 } }
    25.12 22:20:43.566 megad4: 
    25.12 22:20:43.567 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=2
    25.12 22:20:43.583 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:20:43.584 megad4:  body: 92.76
    25.12 22:20:43.586 IH: get [ { id: '34_3', value: '92.25' } ]
    set { SHUMIDITY4_01: { aval: 92.25, err: 0 } }
    25.12 22:20:48.430 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&cnt=6595&mdid=
    25.12 22:20:48.431 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:20:49.426 megad4: 192.168.11.24 => localhost:11024 HTTP GET /mod_megad.php?pt=7&m=2&cnt=6595&mdid=
    25.12 22:20:49.428 IH: get [ { id: '7', value: 6582.63 } ]
    set { METER1_01: { aval: 6582.63, err: 0 } }
    25.12 22:20:49.429 megad4: 192.168.11.24 <= localhost:11024 
    25.12 22:21:12.966 megad4: localhost <=> 192.168.11.24 Socket timed out - abort!
    25.12 22:21:12.968 megad4: localhost <= 192.168.11.24 Error ECONNRESET.  Stopped.
    25.12 22:21:12.972 IH: Plugin exit with code 3
    25.12 22:21:13.015 IH: restart timer 60
    


  • @Alex_Jet, контроллер перестал отвечать на запросы к 31 порту (1WBUS):

    22:19:42 Здесь еще все ОК

    25.12 22:19:42.788 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=31&cmd=list
    25.12 22:19:42.871 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:19:42.871 megad4:  body: e46477910b02:43.75;666877911402:43.87;35e977910902:42.68
    

    22:20:42 через минуту ответа уже нет . Через 200 мсек передается следующий запрос

    25.12 22:20:42.963 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=31&cmd=list
    25.12 22:20:43.164 megad4: // ??????????? Нет ответа. 
    25.12 22:20:43.164 megad4: localhost => 192.168.11.24 HTTP GET /sec/?pt=34&scl=35&i2c_dev=bmx280&i2c_par=1
    25.12 22:20:43.181 megad4: localhost <= 192.168.11.24  response: statusCode=200 contentType = text/html
    25.12 22:20:43.182 megad4:  body: -14.55
    

    Но этот сокет остался открытым, с таймаутом 30 сек.
    Поэтому через 30 сек (22:20:42+30 сек = 22:21:12) происходит сброс этого сокета и генерируется ошибка

    25.12 22:21:12.966 megad4: localhost <=> 192.168.11.24 Socket timed out - abort!
    25.12 22:21:12.968 megad4: localhost <= 192.168.11.24 Error ECONNRESET.  Stopped.
    

    Поскольку раньше контроллер зависал, при таких ошибках сделана перезагрузка плагина.
    Если сейчас контроллер не виснет, а перезагружается сам, можно эту перезагрузку плагина убрать, просто сбросить запрос и игнорировать.
    Это обсуждали полгода назад тут, но так и пришли к окончательному решению, что лучше.

    Может сделать интервал больше 200 мсек?
    И реже опрашивать порт с 1WBUS, так как по документации конвертация происходит каждые 30 сек. Или хотя бы не кратно 30 сек - 67 сек, например


Авторизуйтесь, чтобы ответить