TCP-серверы: сбросить соединение вместо сброса или ответа? - PullRequest
4 голосов
/ 15 ноября 2011

Возможно ли в Node.JS «сбросить» соединение таким образом, чтобы

  • Клиент никогда не получает ответ (200, 404 или иначе)
  • Клиент никогда не уведомляется о том, что соединение разорвано (никогда не получает сброс соединения или завершение потока)
  • Ресурсы сервера высвобождаются (сервер не должен каким-либо образом поддерживать соединение)

Я специально спрашиваю о HTTP-серверах Node.JS (которые на самом деле являются просто сложными TCP-серверами) в Solaris, но если есть случаи на других ОС (Windows, Linux) или языках программирования (C / C ++, Java), которые разрешите это, мне интересно.

Зачем мне это нужно?

Для раздражения или замедления (возможно, однопоточных) роботов, таких как phpMyAdmin Probe .

Я знаю, что на самом деле это не то, что имеет значение, но эти типы вопросов могут помочь мне лучше понять границы моих программ.

Мне известно, что клиентский хост, скорее всего, повторно передаст пакеты соединения, поскольку я никогда не отправляю сброс.

Ответы [ 2 ]

1 голос
/ 25 апреля 2012

закрытие соединения НЕ должно отправлять RST.Существует 3 способа снятия.

1 голос
/ 15 ноября 2011

Это невозможно в обычном стеке TCP (по сравнению с вашим собственным стеком TCP). Причины:

  1. Закрытие сокета отправляет RST
  2. Даже если вы избегаете отправки RST, клиент продолжает думать, что соединение открыто, пока сервер закрыл соединение. Если клиент отправляет любой пакет по этому соединению, сервер отправит RST.

Возможно, вы захотите изучить брандмауэр этих роботов и заблокировать / ограничить скорость их IP-адресов с помощью чего-то вроде iptables (linux) или аналога в Solaris.

...