NodeMCU + Mosquitto MQTT + ArduinoIDE

Olá pessoal,

Sou novo nestas coisas e queria a ajude de um de vocês :smiley:
Tenho um nodeMCU, que tou a configurar com o arduino (porque sinto-me +/- à vontade com o arduino). Já configurei tudo, usei as bibliotecas pubsubclient.h e esp8266.h.
Só o programei para a incrementar uma variavel e a publicar para o mqtt… e consigo ver no HA… uso o mqtt explorer e consigo ver os topic, tudo correcto até aqui, mas agora vem o meu problema…
Se eu tiver o nodemcu ligado ao PC1 (via USB, onde uso o arduino IDE e mqtt explorer) funciona tudo bem, se eu o ligar, via usb a outro pc, ou carregador de telem, não funciona.
WIFI - OK - consigo pinga-lo
MQTT - Penso que ta OK, pq fiz um “jogo” de luzes e ele fica no ciclo do contador
Mosquitto ou mqtt explorer - nao recebo nenhuma msg
Volto a ligar ao PC1, vejo logo os topic, com a info a chegar…

Alguem tem alguma ideia? Como posso fazer mais algum tipo de troubleshooting? nao tenho lcd…
Obrigado!!

Não percebi como testaste o mqtt… Se não tens ligação ao mosquitto…

Não seria muito mais fácil usar como firmware o Tasmota?

Só consigo comunicar com o mosquitto qdo e apenas está ligado ao PC… como sei que se liga? pq recebo os valores que quero pelo topic.

Eu estou tão séptico como tu, não faz sentido, mas o que é certo é que se ligar a outra fonte de alimentação qlq, no HA, já nao recebo qlq dado. Não seria necessário mais nenhuma biblioteca, deveria ser o suficiente, certo?

image


#include <ESP8266WiFi.h>
#include <PubSubClient.h>

#define MSG_BUFFER_SIZE  (50)
char msg[MSG_BUFFER_SIZE];

const char* ssid = " ***** ";
const char* password = " ******* ";
const char* mqtt_server = "192.168.1.197";

unsigned long lastMsg = 0;
int temp = 1;
int value = 0;
WiFiClient espClient;
PubSubClient client(espClient);

void setup() {
  pinMode(BUILTIN_LED, OUTPUT);     // Initialize the BUILTIN_LED pin as an output
  Serial.begin(115200);
  Serial.println("mqtt_esp8266_v4.2");
  setup_wifi();
  client.setServer(mqtt_server, 1883);
  client.setCallback(callback);
}
void setup_wifi() {
  delay(10);
  // We start by connecting to a WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);
  WiFi.mode(WIFI_STA);
  WiFi.begin(ssid, password);

  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  randomSeed(micros());
  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}

void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived [");
  Serial.print(topic);
  Serial.print("] ");
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
  Serial.println();
  Serial.println("you are on void callback ");
}

void reconnect() {
  // Loop until we're reconnected
  while (!client.connected()) {
    Serial.print("Attempting MQTT connection...");
    String clientId = "ESP8266Client-Jardim";

    // Attempt to connect
    if (client.connect(clientId.c_str())) {
      Serial.println("connected");

      // Once connected, publish an announcement...
      Serial.print("RECONNECT: hello world");
      client.publish("outTopic", "RECONNECT: hello world");
      // ... and resubscribe
      client.subscribe("inTopic");
    }
    else {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      // Wait 5 seconds before retrying
      delay(5000);
    }
  }
}

void loop() {
  if (!client.connected()) {
    reconnect();
  }
  client.loop();
  digitalWrite(BUILTIN_LED, LOW);
  Serial.print("Contador: ");
  Serial.println(String(temp).c_str());
  client.publish("contador/topic", String(temp).c_str(), true);
  temp = temp + 1;
  delay(3000);
  digitalWrite(BUILTIN_LED, HIGH);
   delay(1500);
}

Possivelmente, se ano conseguir resolver, terei que ver essa hipotese


Copyright © 2017-2021. Todos os direitos reservados
CPHA.pt - info@cpha.pt


FAQ | Termos de Serviço/Regras | Política de Privacidade