Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. Скрипты
    5. ioBroker скрипты
    6. Вопросы по написанию скриптов

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Вопросы по написанию скриптов

    This topic has been deleted. Only users with topic management privileges can see it.
    • A
      Adav last edited by

      Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart?

      1 Reply Last reply Reply Quote 0
      • I
        instalator last edited by

        @Adav:

        Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart? ` а какие объекты драйвер nut создаёт? Connection создаёт?

        1 Reply Last reply Reply Quote 0
        • A
          Adav last edited by

          @instalator:

          @Adav:

          Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart? а какие объекты драйвер nut создаёт? Connection создаёт?
          Там много всякого создается, касаемо самого бесперебойника. Connection - не получится использовать, при этой ошибке как бы все нормально, драйвер зелененький. Вот поэтому и спросил про возможность отслеживать события в логе. Собственно, удаленный сервис nut работает (поэтому и драйвер не ругается на соединение), но при этом перестает отдавать данные (что и видно в логе). Помогает только рестарт сервиса.

          1 Reply Last reply Reply Quote 0
          • S
            spectrekr last edited by

            Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия.

            1 Reply Last reply Reply Quote 0
            • A
              Adav last edited by

              @spectrekr:

              Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. `

              Как это сделать? Есть примеры? С действием тоже вопрос - через exec надо отправить команду на удаленную машину (со своим паролем и логином), а не выполнять локально.

              1 Reply Last reply Reply Quote 0
              • I
                instalator last edited by

                @spectrekr:

                Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. ` лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника

                1 Reply Last reply Reply Quote 0
                • A
                  Adav last edited by

                  @instalator:

                  @spectrekr:

                  Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника

                  Это было бы идеально, но тут вопрос к разработчику… Как вариант - отслеживать состояние сервиса непосредственно на удаленной машине bash скриптом, но тут я тоже не тяну сделать самостоятельно. По идее можно делать запрос upsc и если нет данных - перегружать сервис.

                  1 Reply Last reply Reply Quote 0
                  • S
                    spectrekr last edited by

                    ! ````
                    var fs = require('fs');
                    var date = formatDate(new Date(res.result[0].ReceivingDateTime), 'YYYY-MM-DD');
                    readFile ('/opt/iobroker/log/iobroker.log.'+date, function (error, bytes) {
                    if(bytes.indexOf('Ошибка') > 0){
                    exec('/bin/bash /opt/iobroker/tmp/restart.sh');
                    }
                    })

                    Примерно так.
                    1 Reply Last reply Reply Quote 0
                    • I
                      instalator last edited by

                      @Adav:

                      @instalator:

                      @spectrekr:

                      Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника

                      Это было бы идеально, но тут вопрос к разработчику… Как вариант - отслеживать состояние сервиса непосредственно на удаленной машине bash скриптом, но тут я тоже не тяну сделать самостоятельно. По идее можно делать запрос upsc и если нет данных - перегружать сервис. `
                      Задай ему вопрос на гитхабе https://github.com/Apollon77/ioBroker.nut/issues

                      1 Reply Last reply Reply Quote 0
                      • A
                        Adav last edited by

                        Вернулся к вопросу с рестартом сервиса nut (о чем выше). Спасибо spectrekr и instalator за два варианта решения проблемы. Но я нашел третий вариант, на мой взгляд проще. Отслеживается одна из переменных (в принципе любая, но лучше константа), приходящих от драйвера nut, и если она не обновлялась дольше, чем два цикла опроса (в моем случае цикл 5 сек), то идет команда на рестарт сервиса на удаленном сервере. Вроде работает… В скрипте это так (может кому пригодится):

                        //---------------------------Restart nut------------------
                        var nut_timer_timeout_ms = 12 * 1000;
                        var nut_timer_id = null;
                        
                        on({id: "nut.0.input.transfer-low", change: "eq"}, function (obj) { 
                        if (nut_timer_id) {
                            clearTimeout(nut_timer_id);
                                          }
                            nut_timer_id = setTimeout(function () {
                               exec('ssh root@192.168.118.115 service nut-driver restart');       
                               sendTo('telegram.0', {
                                  text:'Сервис NUT на сервере System завис и перезагружен.',
                                  disable_notification:   true
                            });          
                            nut_timer_id = null;   
                           	}, nut_timer_timeout_ms);      
                        });
                        
                        1 Reply Last reply Reply Quote 0
                        • A
                          andrey99986 last edited by

                          Есть ли возможность активировать и дезактивировать запись значений в БД (драйвер sql) объекта по условию - в зависимости от состояния другого объекта?

                          Например есть объект "Security" и "megad.0.Sensor1".

                          Надо чтобы состояние объекта "megad.0.Sensor1" писалось в БД только когда getState("Security").val == true.

                          1 Reply Last reply Reply Quote 0
                          • H
                            Haba last edited by

                            оно?

                            {
                              "_id": "mysensors.0.61.255_ARDUINO_NODE.I_BATTERY_LEVEL",
                              "common": {
                                "name": "2.2.0-beta.I_BATTERY_LEVEL",
                                "type": "number",
                                "role": "value",
                                "min": 0,
                                "max": 100,
                                "unit": "%",
                                "def": 100,
                                "read": true,
                                "write": false,
                                "custom": {
                                  "sql.0": {
                            

                            "enabled": true,

                                   "changesOnly": true,
                                    "debounce": 1000,
                                    "retention": 31536000,
                                    "changesRelogInterval": 0,
                                    "changesMinDelta": "",
                                    "storageType": ""
                                  }
                                }
                              },
                              "native": {
                                "id": "61",
                                "childId": "255",
                                "subType": "S_ARDUINO_NODE",
                                "subTypeNum": 17,
                                "varType": "I_BATTERY_LEVEL",
                                "varTypeNum": 0
                              },
                              "type": "state",
                              "acl": {
                                "object": 1638,
                                "state": 1638
                              }
                            }
                            
                            1 Reply Last reply Reply Quote 0
                            • A
                              andrey99986 last edited by

                              @Haba:

                              оно?

                              "sql.0": {

                              "enabled": true, `
                              Похоже что да. Как менять этот параметр в скрипте js ?

                              1 Reply Last reply Reply Quote 0
                              • H
                                Haba last edited by

                                Получилось?

                                Предполагаю что так: https://github.com/iobroker/ioBroker.ja … #setobject

                                или https://github.com/iobroker/ioBroker.ja ... tendobject

                                сам не пробовал, но скорей всего так:

                                extendObject('mysensors.0.63.255_ARDUINO_NODE.I_BATTERY_LEVEL', {common: {custom: {sql.0 {enabled: false}}}});
                                
                                
                                1 Reply Last reply Reply Quote 0
                                • A
                                  andrey99986 last edited by

                                  @Haba:

                                  Получилось?

                                  Предполагаю что так: https://github.com/iobroker/ioBroker.ja … #setobject

                                  или https://github.com/iobroker/ioBroker.ja ... tendobject

                                  сам не пробовал, но скорей всего так:

                                  extendObject('mysensors.0.63.255_ARDUINO_NODE.I_BATTERY_LEVEL', {common: {custom: {sql.0 {enabled: false}}}});
                                  
                                  ```` `  
                                  

                                  Вот так заработало:

                                  extendObject('megad.0.p0', {common: {custom: {"sql.0":{enabled: false}}}});
                                  
                                  1 Reply Last reply Reply Quote 0
                                  • S
                                    smoker_vvo last edited by

                                    Уважаемые коллеги по увлечению, прошу оказать помощь в решении следующей задачи:

                                    Система автоматически отправляет сообщения о своем статусе, о работе системы и температуру, но возникла необходимость получать некую сводку о состоянии охраны, насосов и прочего, при восстановлении пром сети.

                                    Сообщение о том что свет отключили Соня успевает отправить, а при включении - получаю сообщение Бот запущен.

                                    Работаем с Телеграммом.

                                    Ну и совсем фантастика - как бы научить Соню озвучивать события разными текстами, ну типа при включении насоса проговаривать текст из какого то списка…. Типа: Насос включен, Я тут насос запустила, У вас закончилась вода, решила подкачать......

                                    Хочу что бы при событии текст отличался от предыдущего... 😉 😉 😉

                                    1 Reply Last reply Reply Quote 0
                                    • E
                                      electric last edited by

                                      @smoker_vvo:

                                      Ну и совсем фантастика - как бы научить Соню озвучивать события разными текстами, ну типа при включении насоса проговаривать текст из какого то списка…. Типа: Насос включен, Я тут насос запустила, У вас закончилась вода, решила подкачать......

                                      Хочу что бы при событии текст отличался от предыдущего... 😉 😉 😉 `
                                      Мою Катя зовут.

                                      Я пользуюсь драйвером http://www.iobroker.net/docu/?page_id=4459&lang=ru.

                                      Вот https://github.com/ioBroker/ioBroker.text2command на гитхаб, там самое последнее описание.

                                      Скриншот вопросов и ответов и настройки в самом text2command прикрепил.

                                      В тексте подтверждения через слэш варианты накидываешь…
                                      1238_pic_279.jpg
                                      1238_pic_280.jpg

                                      1 Reply Last reply Reply Quote 0
                                      • E
                                        electric last edited by

                                        @smoker_vvo:

                                        Система автоматически отправляет сообщения о своем статусе, о работе системы и температуру, но возникла необходимость получать некую сводку о состоянии охраны, насосов и прочего, при восстановлении пром сети.

                                        Сообщение о том что свет отключили Соня успевает отправить, а при включении - получаю сообщение Бот запущен.

                                        Работаем с Телеграммом. `
                                        Ну попробуй организовать скрипт, который будет подписан на переменную подключения к телеграмму.

                                        Как только переменная в true (телеграмм подключился) - отправляешь всю сводку…

                                        1 Reply Last reply Reply Quote 0
                                        • S
                                          smoker_vvo last edited by

                                          Ну если немного в историю….. ТО

                                          И звали ее Алисой и работала она с Мажордомом..... Целых 6 лет.... А потом она оглохла и ослепла.....

                                          И слепил я себе Соню..... На уровень выше и стабильнее... 😉 😄 😄 😄 😄

                                          А вообще - Хочется стремиться к С.А.Р.А...... (Self Actuated Residential Automated Habitat) Сериал "Эврика"

                                          😛

                                          1 Reply Last reply Reply Quote 0
                                          • S
                                            smoker_vvo last edited by

                                            Не шибко силен в скриптах… Как контролировать подключение к телеграмму?

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            937
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            88179
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo