1. ARP(Address Resolution Protocol)이란 !?
# ip address를 이용해 mac address를 알아내는 프로토콜이다.
+ 즉 IP 주소만 알고 있을 때 그 IP에 해당하는 MAC 주소를 결정하는 프로토콜!!
IP -> MAC
# 논리적 주소를 물리적 주소로 변환
# 주소 결정 프로토콜
과정은 이렇다.
그림 이해 : 송신 호스트 MAC 주소는 자신의 LAN 카드에 내장되어 있기에 값을 알 수 있지만 수신 호스트는 MAC 주소는 모르기 때문에 수신 호스트는 ARP 기능을 통해 수신 호스트 MAC 주소를 얻어야 한다.
A host 가 B host의 MAC 주소를 얻으려면 ARP Request라는 특수 패킷을 브로드캐스팅 or 플로딩을 해야 한다. B가 아닌 다른 호스트들은 모두 패킷을 받게 되는데 관계가 없기 때문에 패킷을 무시하고 B는 동일함을 인지하기 때문에 ARP reply 패킷을 사용해 B host의 MAC 주소를 A host에게 회신한다.
계속해서 ARP Request를 하게 되면 브로드캐스팅을 하게 된다. 브로드캐스팅을 지속적으로 하게 된다면 네트워크 트래픽이 증가해 CPU의 부담을 줄 수 있기에 최근에 얻은 Ip 주소와 MAC 주소 Mapping 값을 보관하는 캐시 정보를 이용한다!.
송신 호스트는 ARP Request 패킷을 브로드 캐스팅하면서 패킷을 수신한 모든 호스트는 IP 주소와 MAC 주소 Mapping 값을 자동을 얻을 수 있다. 이러한 방식을 이용해 ARP 트래픽에 의한 부담을 줄일 수 있다.
2. RARP(Reverse Address Resolution Protocol)
# mac address를 IP로 매핑 시키는 역할
MAC -> IP
# 특이한 경우에 사용 ( 일반적이지 않다 )
+ 특이한 경우란 무엇인가?
디스크가 없는 컴퓨터! 즉 디스크 없는 컴퓨터는 중앙 서버를 두고 각 클라이언트가 디스크 없이 서버의 데이터를 받아 사용하도록 하는 것! 하드웨어 비용을 줄일 수 있다는 큰 이점이 있다!
컴퓨터가 처음 전원이 들어오면서 통신을 하기 위해 RARP 서버로부터 IP를 얻기 위해 사용이 됨
과정은 이렇다
RARP는 MAC 주소를 이용해 IP 주소를 제공한다.
하드 디스크가 없는 호스트에서는 송신 호스트 IP 주소를 보관할 방법이 없으므로 LAN 카드에 내장된 MAC 주소를 매개변수로 사용하여 RARP 기능을 수행하여 자신의 IP 주소를 얻어야 한다.
MAC 주소와 IP 주소의 매핑 값을 보관하고 있는 호스트로부터 IP 주소를 얻어야만 한다.
RARP의 기능을 전담 서버가 하나 이상 존재하므로 모든 호스트가 RARP 변환 요청을 받아도 해당 정보를 보관하고 있는 RARP 서버만 응답할 수 있다.
자신의 IP 주소를 얻은 다음, 미리 정해진 호스트로부터 자신의 부트 이미지를 다운로드를 한다. 이러한 시스템은 ROM 등의 비활성 메모리에 다른 호스트와 통신하여 필요한 부트 이미지를 수신할 수 있는 TFTP 등의 기본 프로토콜이 존재한다.
◆ Proxy ARP
Subnet을 인식하지 못하는 호스트와 subnet을 인식하는 다른 호스트가 공존할 수 있도록 하기 위해 broadcast 전송 네트워크에 사용된다.
proxy ARP는 Router가 한쪽 편에 있는 host request에 대해 다른 편의 host를 대신하여 응답.
ARP를 요청한 host의 destination의 host와 같은 segment에 없으면 일단 router가 자신의 MAC address를 대신 전송함
어떻게 보면 속이는 기술입니다. 실제 목적지는 아니지만 그런 척 해서 받은 ARP request를 발생지로 응답하는 기술을 Proxy ARP라 합니다. Proxy ARP는 같은 서브넷에 존재하는 호스트를 원격지 호스트 또는 Default Gateway로 가는데 라우팅 설정 없이 보낼 수 있습니다. Proxy ARP : RFC1027
◆ gratuitous ARP
어떤 host가 자기 자신의 ip address에 대해 ARP request를 송신, 여기에 대한 답이 오면 자기 자신 과 같은 ip address를 누군가 쓰고 있는 것이므로 ip address의 중복 사용을 막는다.