INFO: Dieses Forum nutzt Cookies...
Cookies sind für den Betrieb des Forums unverzichtbar. Mit der Nutzung des Forums erklärst Du dich damit einverstanden, dass wir Cookies verwenden.

Es wird in jedem Fall ein Cookie gesetzt um diesen Hinweis nicht mehr zu erhalten. Desweiteren setzen wir Google Adsense und Google Analytics ein.

Antwort schreiben 
 
Themabewertung:
  • 0 Bewertungen - 0 im Durchschnitt
  • 1
  • 2
  • 3
  • 4
  • 5
Problem mit der Ethernet Library (client.connect)
05.10.2015, 15:40 (Dieser Beitrag wurde zuletzt bearbeitet: 05.10.2015 21:28 von ardu_arne.)
Beitrag #1
Problem mit der Ethernet Library (client.connect)
Hallo,

Ich habe seit langem mal wieder den Versuch unternommen Messwerte vom Arduino in eine MySQL Datenbank auf einem PC zu schreiben. Das funktioniert inzwischen auch super aber in manchen Situationen gibt es ein Problem.

Hier mal der Code, stark gekürzt auf das Wesentliche.
Code:
void setup()
  {
  Ethernet.begin(mac, ip, dnsServer, gateway, subnet);
  .
  .
  }

void loop()
  {

  unsigned long clientStart = millis();

   if (client.connect(zielrechner, 80)) // Verbindung zum Server aufbauen
    {
    Serial.println(F("Verbunden, sende Daten"));
    .
    .  
    //Datenübertragung
    .
    .
    client.stop();
    }

  else

    {
    Serial.println(F("** VERBINDUNG KANN NICHT HERGESTELLT WERDEN **"));
    }

  Serial.println( millis() - clientStart);

  }

Wenn der Zielrechner (Server) ok ist, erfolgt die Datenübertragung in knapp 140ms.
Wenn der Zielrechner ausgeschaltet ist oder das Netzwerkkabel abgezogen ist dauert es 2 Sekunden bis der else-Teil ausgeführt wird und die Fehlermeldung kommt.
Wenn der Zielrechner läuft, aber der Webserver auf dem Zielrechner nicht läuft, dann dauert es über 30 Sekunden bis der else-Teil mit der Fehlermeldung ausgeführt wird. Angry In dieser Zeit friert der Arduino scheinbar ein und macht dann nach über 30 Sekunden weiter als ob nichts gewesen wäre.

Hat jemand eine Idee wie man die Wartezeit (wahrscheinlich irgend ein timeout in der Ethernet Library) beeinflussen kann oder den Fehler bereits vor dem Aufruf von client.connect(zielrechner, 80) abfangen kann.

Ich verwende übrigens die Ethernet Library welche mit der Arduino IDE 1.6.5 ausgeliefert wurde.

Gruß
Arne

ExclamationMit zunehmender Anzahl qualifizierter Informationen bei einer Problemstellung, erhöht sich zwangsläufig die Gefahr auf eine zielführende Antwort.Exclamation
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren
05.10.2015, 21:11
Beitrag #2
RE: Problem mit der Ethernet Library (client.connect)
Hi Arne,
ich habe es gerade bei mir getestet und ich habe den gleichen Aufbau der Übertragung. Also bei mir kommt die Fehlermeldung ohne erkennbare Verzögerung wenn ich dem RPi einen reboot verpasse. Vielleicht ist das auch eine andere Qualität wie wenn nur der mySQL Server nicht geht.
lgbk

1+1 = 10 Angel ...und ich bin hier nicht der Suchmaschinen-Ersatz Dodgy...nur mal so als genereller Tipp..
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren
05.10.2015, 21:43
Beitrag #3
RE: Problem mit der Ethernet Library (client.connect)
Hallo Bitklopfer,

danke für den Test und die Rückmeldung.

Ich habe im Code-Teil des ersten Beitrags noch die Zeitmessung ergänzt.

Auf dem Server (Windows-PC) läuft bei mir XAMPP. Im Control Panel dazu kann ich die einzelnen Module starten und stoppen.

Nochmal kurz die gemessenen Zeiten:
Wenn Apache und MySQL läuft erfolgt die Übertragung in 136ms
Wenn Apache läuft und MySQL steht, kommt nach 1,2s die Fehlermeldung.
Wenn Apache steht kommt nach 32s die Fehlermeldung.
Wenn der Server aus ist oder vom Netzwerk getrennt ist, kommt nach 1,8s die Fehlermeldung.

Vielleicht läuft auf deinem RPi noch irgendein Dienst der Port 80 bedient?
Das wäre bei mir dann mit dem Zustand Apache läuft und MySQL steht vergleichbar, der nach 1,2s Fehler meldet.
Oder aber bei mir läuft noch irgendwas wenn der Apache steht was falsche Antworten gibt auf Port 80 schreibt.
Ich werde mal "tcpview" installieren und damit etwas forschen.

Gruß
Arne

ExclamationMit zunehmender Anzahl qualifizierter Informationen bei einer Problemstellung, erhöht sich zwangsläufig die Gefahr auf eine zielführende Antwort.Exclamation
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren
06.10.2015, 17:06
Beitrag #4
RE: Problem mit der Ethernet Library (client.connect)
Ich habe hier eine Lösung gefunden. Smile
Beitrag #4 unter "The simpler fix" funktioniert.
Mit "W5100.setRetransmissionCount(1);" dauert es bei allen Problemen weniger als eine Sekunde bis eine Fehlermeldung kommt.

Gruß
Arne

ExclamationMit zunehmender Anzahl qualifizierter Informationen bei einer Problemstellung, erhöht sich zwangsläufig die Gefahr auf eine zielführende Antwort.Exclamation
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren
Antwort schreiben 


Möglicherweise verwandte Themen...
Thema: Verfasser Antworten: Ansichten: Letzter Beitrag
  Library unter Linux Mint installieren atmel900 1 86 22.11.2016 14:12
Letzter Beitrag: rkuehle
  Arduino UNO und Ethernet Shield 2 POE und Fritzbox 3272 tr3 2 155 19.11.2016 10:46
Letzter Beitrag: tr3
  Dallas Temp Library und LiquidCrystal_i2c relay 20 467 27.10.2016 12:20
Letzter Beitrag: hotsystems
  ESP8266 Server connect sowerum 1 167 21.10.2016 19:10
Letzter Beitrag: sowerum
  Problem mit SD Card Library BennIY 4 189 06.10.2016 18:38
Letzter Beitrag: Bitklopfer
  Ethernet Modul Enc28j60 Pin13 LED Schalten BennIY 16 502 27.09.2016 20:30
Letzter Beitrag: BennIY
  Problem mit SD.remove Eichner 6 211 22.08.2016 19:42
Letzter Beitrag: Eichner
Question Webserver, Client, Loop Marc2014 6 365 29.07.2016 21:04
Letzter Beitrag: Marc2014
  4x16 Tastermatrix Problem Michel 16 843 14.07.2016 10:02
Letzter Beitrag: StephanBuerger
  Problem mit Delay und Millis funnyzocker 1 458 26.06.2016 09:54
Letzter Beitrag: hotsystems

Gehe zu:


Benutzer, die gerade dieses Thema anschauen: 1 Gast/Gäste