ESP8266WiFi.hで1KB超のHTTP_GETが出来ない場合 ネットワークのMTU値/MSSの確認
ESP-WROOM-02をArduino IDE 1.6.5でプログラムする環境において、サンプルスケッチのESP8266WiFi/WiFiClient.ino サンプルを流用してJSON文字列をHTTPでGETするプログラムを書いているのですが、レスポンスヘッダを含めて1360bytes程度までしか取得できず困っています。
一定以上の大きさのリソースは取得できないという制限があるのならば、Web側でCGIなりで加工する実装に切り替えようと思いますが、この1360bytesの制限を変更する方法をご存知の方がいらっしゃいましたら、教えていただければありがたく存じます。
スケッチは以下のようになります。
#include <ESP8266WiFi.h>
const char* ssid = "your-ssid";
const char* password = "your-password";
const char* host = "example.com";
void setup() {
Serial.begin(115200);
delay(10);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
}
}
void loop() {
delay(5000);
Serial.print("connecting to ");
Serial.println(host);
WiFiClient client;
const int httpPort = 80;
if (!client.connect(host, httpPort)) {
Serial.println("connection failed");
return;
}
String url = "/hugedata.json";
Serial.print("Requesting URL: ");
Serial.println(url);
client.print(String("GET ") + url + " HTTP/1.1\r\n" +
"Host: " + host + "\r\n" +
"Connection: close\r\n\r\n");
delay(10);
while(client.available()){
String line = client.readStringUntil('\r');
Serial.print(line);
}
}
(2015-11-07 02:40追記)アクセス先のVPSサーバでtcpdumpをとったりして試したところ、eth0のMTUを1500から1400(=MSS:1360)にしたところ、大きなファイルでもESP-WROOM-02でも8KBのファイルがGETできたので、ESP8266WiFi.hではなくて、回線の問題になると思います。ネットワーク環境を調整して引き続き調査しています。
(2015-11-07 03:24追記)tcpdumpの3way hand shakeの様子を見ていると、我が家の回線がCATVでMTU=1400のところを、ESP-WROOM-02からのSYNでMSS=1380を要求していました。
- アクセス先のサーバがMTU=1500(MSS=1460)のときは、SYN+ACKでMSS=1460が提示され、結果としてMSS=1380(MTU=1420)が採用、サーバからCATV回線にパケットが通らないという状態。
- アクセス先のサーバがMTU=1400(MSS=1360)のときは、SYN+ACKでMSS=1360が提示され、結果としてMSS=1360(MTU=1400)が採用、サーバからCATV回線にパケットが通る。
という切り分けができました。よって、問題は、自宅内のネットワーク環境で、ESP-WROOM-02がMTU=1420(MSS=1380)を採用する原因を調査することになりました。