TCP송신자가 보내야 할 ack의 값보다 큰 값을 보내면?
글쓴이: mandugukbap / 작성시간: 화, 2012/10/23 - 8:50오후
안녕하세요.
TCP의 한 쪽 호스트가 다른 쪽 호스트에게 Ack 세그먼트를 보낼 때, 보내얄 할 값보다 더 큰 값을 보낸다면 Ack을 받아야 하는 쪽은 어떻게 반응 하는지요?
예를 들어 TCP 핸드쉐이크가 끝난 후 TCP 커넥션을 시작한 쪽이 첫 세그먼트의 ack을 1010을 보내야 하는데, 4010을 보낸다면 받는 쪽에서는 어떻게 반응하는지가 궁금합니다.
참고로 리눅스 커널 중 어느 부분에 이런 메카니즘이 쓰여져 있는지 알려 주시면 갑사하겠습니다.
Forums:
gilgil.net
1. 송신자의 마지막 seq : N
2. 수신자의 마지막 ack : N + alpha
패킷 중간단에서 조작을 해서 말씀하신 테스트를 해 본 경험이 있는데,
2번 패킷을 송신자가 수신하게 되는 경우 말도 안되는 ack no라 하여 TCP connection이 그냥 끊어져 버립니다(RST 패킷이 날라 감).
linux 소스 코드상으로는 어느 부분인지 잘 모르겠네요.
www.gilgil.net
답변 감사합니다. 혹시 패킷을 중간에 가로채서
답변 감사합니다. 혹시 패킷을 중간에 가로채서 ack을 변경하셨다는 말인지요? 그렇다면 IP헤더의 Checksum이 달라서 Middlebox에서 RST시켜 버린건 아닌가요? 그 이유가 아니라 하더라도 혹시 종단 호스트의 결정이 아니라 방화벽등의 middle box의 결정으로 RST이 이루어졌을 가능성은 없나요?
무시합니다. RST 안날립니다.
무시합니다. RST 안날립니다.
http://lxr.free-electrons.com
http://lxr.free-electrons.com/source/net/ipv4/tcp_input.c#L3583
3598 /* If the ack is older than previous acks
3599 * then we can probably ignore it.
3600 */
3601 if (before(ack, prior_snd_una))
3602 goto old_ack;
3603
3604 /* If the ack includes data we haven't sent yet, discard
3605 * this segment (RFC793 Section 3.9).
3606 */
3607 if (after(ack, tp->snd_nxt))
3608 goto invalid_ack;
이전에 ack 된게 오면 버리고 무시.
아직 보내지도 않은 ack이 오면 return -1 하는데, 호출 쪽에서 확인하는 코드가 없음. 고로 이것도 무시. 단, DEBUG 모드면 메세지가 뜸
댓글 달기