ESP, IoT [BigClock] Большие часы на WS2812, ESP8266, Народный мониторинг

Какой вариант датчика используется у вас? Интересно, использует ли кто BME280, как у меня?)

  • BMP280

    Голосов: 26 26.8%
  • BME280

    Голосов: 71 73.2%

  • Всего проголосовало
    97

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
Вчера опять отключали электричество, и снова мониторинг остановился) странно это как-то)
Мониторинг же завязан на loop, раз все работает, то и он должен стартануть, тем более он с задержкой в 10 минут, сеть к этому времени поднимается)
C++:
static bool Monitoring = true;
int delay_narod = 600;
void loop() {
  if (Monitoring) {
    if (millis() - timing > delay_narod * 1000) {
      timing = millis();
      narod();
    }
  }
}
void narod() {
  WiFi.begin(ssid, password);
  byte tryss = 0;
  while (WiFi.status() != WL_CONNECTED) {
    tryss++;
    delay(500);
    if (tryss > 20)
    {
      Serial.println("Нет связи с роутером, narod!");
      return;
    }
  }
  Serial.println("Показания отправлены!");
}
вкратце это так)
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@Старик Похабыч, каждые 10 минут отправляет после старта ардуины.
потом сам перезагружаю, когда интернет есть, то все работает)
пока было отключение электричества, я смотрел ютуб на телефоне по WiFi, увидел только уведомление, что нет интернета, не придал этому значение, т.к. он быстро поднялся и только потом увидел, что мониторинг уведомил, что прибор не отправляет данные)
мыслей пока нет...
Возможно функция мониторинга не может поднять WiFi, не должно же быть такого, 20 попыток за 10 секунд...
Поставлю тогда побольше, понаблюдаю за ситуацией, 120 попыток) на минуту)
 

Старик Похабыч

★★★★★★★
14 Авг 2019
4,322
1,319
Москва
попытки отправить идут раз в 10 минут. Допустим 1-ый раз из 10 минут что то пошло не так. Вторая попытка еще через 10 минут удачна или нет?
Вопрос в том поднимается ли потом wifi или нет?

В принципе не сложно отрубать роутер и проверять чаще. И сделать не раз в 10 минут, а чаще. Отправлять при этом данные не обязательно
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
Можно попробовать смоделировать ситуацию и посмотреть...
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
Поставил 120 попыток, отключил роутер, пытался ровно минуту достучаться
C++:
  Serial.println("Start_narod");
  while (WiFi.status() != WL_CONNECTED) {
    tryss++;
    delay(500);
    Serial.print("_");
    if (tryss > 120)
    {
      Serial.println("Нет связи с роутером, narod!");
      return;
    }
  }
Код:
13:08:37.767 -> Start_narod
13:08:38.282 -> _________________________________________________________________________________________________________________________Нет связи с роутером, narod!
13:09:38.298 -> Освещенность: 15
включил роутер, наблюдаю...
Код:
13:18:37.768 -> Start_narod
13:18:46.066 -> Показания отправлены!
данные с мониторинга
Код:
Нет данных c 06.06.2021 13:00 UTC+3, find=''
вот где бяка зарылась)
пишет что отправлена, на самом деле данных на сервере нет)
сервер проверяет отправку по IP, никаких данных не пришло, ни пустых, ни ложных...
Код:
13:28:37.865 -> Start_narod
13:28:43.056 -> Показания отправлены!
13:28:43.103 -> 754 | 754.33
Код:
Нет данных c 06.06.2021 13:00 UTC+3, find=''
Возможно проблемы в том, что не поднимается клиент?
C++:
  WiFiClient client;
  client.connect("narodmon.ru", 8283);
я закончил с постом, можно комментировать)
 
Изменено:

Verholaz

★✩✩✩✩✩✩
6 Янв 2021
61
35
67
Добрый вечер. Спасибо автору и всем, кто ему помогал, за проделанную работу. А теперь о главном (для меня).
Датчик BME280 (прошивка с 6 страницы, я предполагаю последняя) показания влажности выводятся только как 00%. У меня 2 датчика и оба рабочие, и оба выводят 00%. Может в прошивке надо включить? А я не нашёл. Подскажите. Спасибо за ответ.
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@Verholaz, прошивка всегда в первом сообщении)
Разбирайся с подключением, пины D2, D1, проверь правильность)
По умолчанию всё включено...
 

Verholaz

★✩✩✩✩✩✩
6 Янв 2021
61
35
67
Доброе утро. Гонял часы около трёх часов. За это время показания с BME280, давление и температура, пропадали и появлялись, что привело к мысли о контактах в проводах и макетной плате. Но влажность всегда была 0%. Но проявилась другая проблема. За это время часы зависали 5 раз. Работать начинали только после отключения питания на 2-3 минуты (выдержка после отключения). По прошивке: после прошивки с первой страницы часы не включились, а с шестой подключились к интернету и заработали. Только время длительности режимов изменил, а то 6 и 2 секунды очень быстро было. Буду читать форум или посоветуйте что-нибудь по зависанию часов. А сам проект по большим часам я считаю одним из самых интересных среди подобных.
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@Verholaz, не знаю, что за прошивка на 6 странице, она одна на всех страницах в первом сообщении) Мысли только одни, где-то что-то не так поправлено в прошивке, при смене секунд. Нужно смотреть весь код, вставь его сюда текстом в тег код С++.
Также для начала запусти тестовый пример для датчика из библиотеки, проверь работу с ним)
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@maksland, для каких целей?) Есть же карты молний, можно онлайн наблюдать)
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@Старик Похабыч, в 6:30 отключали свет, в 8 часов увидел, что данные так и не пришли...
Уже не понятно) в любом случае за это время должно быть подключение, 60сек же ставил на попытку)
 

maksland

★★★✩✩✩✩
13 Янв 2019
615
144
Omsk
а датчик освещенности стандартный ? почему в схеме три вывода к нему подходят ? модуль времени на DS3231 ?
DS3231
DS3231
 
Изменено:

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@maksland, конечно стандартный) если думаешь, что фоторезистор имеет два вывода, откуда третий?) Так нужно притянуть через резистор один из выводов.
Часы на 3231, по ссылке не тот...
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@maksland, кнопок в этой версии нет, т.к. дата и время синхронизируются с интернетом. Плата то маленькая, как она не влезает?)
 

maksland

★★★✩✩✩✩
13 Янв 2019
615
144
Omsk
Это я мало места выделил, да и под ноде и не рассчитывал. Лучше нарисую новую

анемометр можно прикрутить ?
 

kDn

★★★★★✩✩
18 Ноя 2019
1,103
437
Данная прошивка проверяет время по NTP, часы RTC теоретически не нужны, но по просьбе участников сделал с ними.
Кстати, я недавно в нашем фреймворке игрался с восстановлением даты времени из родной RTC-памяти контроллера после мягких ребутов (сон, эксепшены, программные перезагрузки) и до синхронизации с NTP - вроде работает все хорошо.
C++:
13:06:57.670 > TIME: RTC time = 401379 sec (1624646237)
13:06:57.670 > TIME: After reboot time (1625047616)-> 2021-06-30T13:06
За практически неделю тестирования время особо никуда не убежало. Соответственно действительно можно обойтись без дополнительного RTC модуля :)
 

ASM

★★★★★✩✩
26 Окт 2018
1,918
422
@kDn, при сбое питания время будет настроено не скоро) Либо часто обновлять время, либо переписывать функцию времени и проверки.
 

kDn

★★★★★✩✩
18 Ноя 2019
1,103
437
@ASM, я ваш код не глядел, но у нас опрашивается 3 нтп-сервера, вероятность что все 3 сдохнут не то чтобы большая... Если же речь о том, что свет выключили, интернет не доступен - то как бы и сам контроллер без УПС работать не будет. Если же затем свет включили, интернет появился - то и синхронизация пройдет с момента подключения к WiFi.
* Но это естественно речь о фреймворке, т.к. как у вас сделано я не особо в курсе.