我正在使用具有以太网屏蔽的Arduino Uno。许多客户端打印后Arduino(Uno)以太网客户端连接失败
发送很多HTTP请求后,client.println(...),连接时客户端开始失败。失败的时间似乎是随机的,循环中的序列读数可以在〜1000和〜7000之间任意变化。
的错误不是做与以太网发送缓冲区溢出(以下this advice)
这里是一个错误的代码:
#include <Ethernet.h>
#include <SPI.h>
// Network constants
byte mac[] = {0x00, 0x23, 0xdf, 0x82, 0xd4, 0x01};
byte ip[] = {/*REDACTED*/};
byte server[] = {/*REDACTED*/};
int port = /*REDACTED*/;
Client client(server, port);
// State
int sequence;
void setup(){
Ethernet.begin(mac, ip);
Serial.begin(9600);
sequence = 0;
delay(1000);
}
void loop(){
httpPut("/topic/:test/publish?sessionId=SESenanhygrp");
Serial.println(sequence++);
}
void httpPut(char* url){
if (!client.connect()) {
Serial.println("EXCEPTION: during HTTP PUT. Could not connect");
return;
}
client.print("PUT");
client.print(" ");
client.print(url);
client.println(" HTTP/1.0");
client.println();
while(!client.available()){
delay(1);
}
while(client.available()) {
char c = client.read();
Serial.print(c);
}
while(client.connected()){
Serial.println("Waiting for server to disconnect");
}
client.stop();
}
在以下段将出现错误
if (!client.connect()) {
Serial.println("EXCEPTION: during HTTP PUT. Could not connect");
return;
}
在客户端连接失败的时候,我会做两件事:(1)检查服务器日志中是否有任何证据服务器接收失败的连接请求; (2)在服务器上使用'netstat'来确定之前的连接是否已经关闭或者正在等待。 – NPE
除上述之外,3)我会检查堆栈是否溢出。 4)数千个周期后是否发生内存泄漏。 – Jeff
服务器日志没有显示任何问题。使用Arduinos时内存始终是一个问题,但上面的代码应该是'内存安全' – ChrisSSocha