Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Вопросы по написанию скриптов

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    658

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.7k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

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

Scheduled Pinned Locked Moved ioBroker скрипты
358 Posts 29 Posters 116.1k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • A Offline
    A Offline
    Adav
    wrote on last edited by
    #333

    @instalator:

    @Adav:

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

    1 Reply Last reply
    0
    • S Offline
      S Offline
      spectrekr
      wrote on last edited by
      #334

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

      1 Reply Last reply
      0
      • A Offline
        A Offline
        Adav
        wrote on last edited by
        #335

        @spectrekr:

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

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

        1 Reply Last reply
        0
        • I Offline
          I Offline
          instalator
          wrote on last edited by
          #336

          @spectrekr:

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

          Высокий уровень Децибел вреден для здоровья!

          http://blog.instalator.ru/

          1 Reply Last reply
          0
          • A Offline
            A Offline
            Adav
            wrote on last edited by
            #337

            @instalator:

            @spectrekr:

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

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

            1 Reply Last reply
            0
            • S Offline
              S Offline
              spectrekr
              wrote on last edited by
              #338

              ! ````
              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
              0
              • I Offline
                I Offline
                instalator
                wrote on last edited by
                #339

                @Adav:

                @instalator:

                @spectrekr:

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

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

                Высокий уровень Децибел вреден для здоровья!

                http://blog.instalator.ru/

                1 Reply Last reply
                0
                • A Offline
                  A Offline
                  Adav
                  wrote on last edited by
                  #340

                  Вернулся к вопросу с рестартом сервиса 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
                  0
                  • A Offline
                    A Offline
                    andrey99986
                    wrote on last edited by
                    #341

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

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

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

                    1 Reply Last reply
                    0
                    • H Offline
                      H Offline
                      Haba
                      wrote on last edited by
                      #342

                      оно?

                      {
                        "_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
                      0
                      • A Offline
                        A Offline
                        andrey99986
                        wrote on last edited by
                        #343

                        @Haba:

                        оно?

                        "sql.0": {

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

                        1 Reply Last reply
                        0
                        • H Offline
                          H Offline
                          Haba
                          wrote on last edited by
                          #344

                          Получилось?

                          Предполагаю что так: 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
                          0
                          • A Offline
                            A Offline
                            andrey99986
                            wrote on last edited by
                            #345

                            @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
                            0
                            • S Offline
                              S Offline
                              smoker_vvo
                              wrote on last edited by
                              #346

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

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

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

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

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

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

                              1 Reply Last reply
                              0
                              • E Offline
                                E Offline
                                electric
                                wrote on last edited by
                                #347

                                @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
                                0
                                • E Offline
                                  E Offline
                                  electric
                                  wrote on last edited by
                                  #348

                                  @smoker_vvo:

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

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

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

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

                                  1 Reply Last reply
                                  0
                                  • S Offline
                                    S Offline
                                    smoker_vvo
                                    wrote on last edited by
                                    #349

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

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

                                    И слепил я себе Соню..... На уровень выше и стабильнее... ;) :D :D :D :D

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

                                    :P

                                    1 Reply Last reply
                                    0
                                    • S Offline
                                      S Offline
                                      smoker_vvo
                                      wrote on last edited by
                                      #350

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

                                      1 Reply Last reply
                                      0
                                      • E Offline
                                        E Offline
                                        electric
                                        wrote on last edited by
                                        #351

                                        @smoker_vvo:

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

                                        И слепил я себе Соню..... На уровень выше и стабильнее... `
                                        О_о, тогда коллеги! Тоже жил с Алисой года так 3-4 назад, потом переехал на CCU.IO (это папа iobroker) и далее на iobroker.

                                        1 Reply Last reply
                                        0
                                        • E Offline
                                          E Offline
                                          electric
                                          wrote on last edited by
                                          #352

                                          @smoker_vvo:

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

                                          По идее она true когда драйвер подключен к боту и false в противном случае…
                                          1238_pic_281.jpg

                                          1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          568

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe