Hej!
För er som undrar över hur kommunikation fungerar i ett nätverk mellan två enheter (t.ex två datorer) genom en switch och router kan ni läsa mitt svar här nedanför som jag gav till en utländsk student vid Halmstad högskola som jag hade i kursen IP-telefoni och trådlösa nätverk när jag var kursansvarig. Texten är på engelska. Om jag får in några kommentarer som vill ha en svensk översättning så fixar jag det.
Studenten frågade efter hur en PC känner till sin destinations IP-adress och hur datapaketen tar sig dit, utan att man specificerar subnätmasken i ICMP (ping) meddelandet. Allt har att göra med protokollet ARP - Address Resolution Protocol.
Till min hjälp har jag använt programmet Packet Tracer 5.2 för att felsöka kommunikationen. Jag har även bifogat en simpel topologi över nätverket.
--------------------------
(Klicka på bilden för att förstora)
--------------------------
Question: How does a PC know about the destination IP-address and how to get to it without sending the subnetmask in the ICMP (ping) message?Answer:Hi,
I tried a scenario in Packet Tracer just now and here it how it works.
- I choose to ping from 192.168.1.10 to 192.168.1.11
- ARP constructs a request for target IP-address 192.168.1.11, and sets the broadcast MAC-address to FF:FF:FF:FF:FF:FF
- ARP encapsulates PDU into Ethernet frame
- Frame goes to switch on the wire
- Switch receives frame on port fa0/2
- Switch processes frame up to OSi layer 2 "Data link"
- It is a broadcast (FF:FF:FF:FF:FF:FF), send out on all switch ports except the receiving port, so this is sending packets to router (192.168.1.1) and PC (192.168.1.11)
- Packets are sent out fa0/1 and fa0/3
- Router receives ARP request on port fa0/0
- The ARP request's target IP address does not match the receiving port's IP address, (192.168.1.11 is not matching routers IP of 192.168.1.1)
- The ARP process on the router checks the routing table whether the requested IP address is reachable, and the IP-address is reachable on source port fa0/0
Router# show ip route
C 192.168.1.0/24 is directly connected, FastEthernet0/0
C 192.168.2.0/24 is directly connected, FastEthernet0/1
- ARP table on router is updated with souce IP-address (192.168.1.10) and MAC-address
- Router discards ARP-request
- Now the destination PC receives the ARP request on its ethernet port from the switch as a broadcast (FF:FF:FF:FF:FF:FF)
- The ARP request's target IP address matches the receiving port's IP address. (192.168.1.11 is matching 192.168.1.11)
- ARP-process on destination PC updates the ARP-table.
- ARP-process on destination PC replies to source PC with source port MAC-address, and encapsulates PDU into ethernet frame.
- Switch port fa0/3 receives request and looks in its ARP-table.
- The frame source MAC-address was found in its ARP-table.
- This is a uniucast frame (from PC 192.168.1.11 to PC 192.168.1.10) so switch looks in ARP-table for destination MAC-address
- Switch is sending unicast reply out fa0/2 port
- PC 192.168.1.10 receives ARP-reply on ethernet port and does now know about the PC 192.168.1.11 MAC-address on OSI layer 2
- It saves the information (mapping) MAC-address to IP-address.
- PC 0 can now send an ICMP (ping) message to PC 1 using only IP-addresses on OSI layer 3 "Network".
Now, if the ping is going to IP-address 192.168.2.10, then the ICMP-message will reach the router (which MAC-address is also in PC A's ARP-table). The router will check the routing table for destination IP-address network, if it's reachable. It is reachable through port router's fa0/1 to network
192.168.2.0/24Then the ARP-process will start all over again on the other side, so the router will ask the switch, which in turn will broadcast the ARP out all switchports except receiving port (fa0/1). The request is going out fa0/2 to PC 2 with IP 192.168.2.10 and the IP is correct. An ARP-reply is then sent back to the router. ICMP (ping) can now continue.
I really recommend you to test Packet Tracer to look at TCP/IP and ARP messages going. You can also debug DHCP and some other protocols.
-----------------------------
Innan jag svarade studenten på hans fråga, trodde jag att jag kunde ARP, men efter en djupdykning i protokollet fick jag mer kunskap. Nu vet jag mycket bättre själv hur kommunikationen i ett datanätverk går till. Visst kunde jag detta utantill när jag studerande CCNA vid högskolan och gymnasiet men det är alltid bra att fräscha upp minnet lite.
Lycka till alla