When a MAC address itself is unique, why do we still need an IP address to uniquely identify a system on a network?
It is not possible to route a MAC address since it works on a layer above Ethernet. To understand why IP addressing is used in a computer network or over the internet you need to understand how IP routing works.
Basic IP Routing
When your computer (PC1) wants to send a packet to some IP address (IPv4) like x.x.x.x, then the first check is if the destination address is in the same IP network as the PC1 itself. If x.x.x.x is in the same network, then the destination IP can be reached directly, otherwise the packet needs to be sent to the route configured on PC1 and if a route for the destination network / host is not configured explicitly, the packet is routed to the default gateway configured on PC1. Well that was about how IP routing works at a very high-level. Routers also use dynamic routing protocols and algorithms to find the best possible path.
MAC addresses
Once the packet has reached the local network of the destination computer, the communication happens over the Ethernet which is the data link layer. This is where MAC addresses are used to communicate. The sender (which in this case could be a router or the source computer PC1 if it was in the same network) needs to get the MAC address of the destination computer. There is a special protocol ARP (address resolution protocol) that is used for that. Once the sender has retrieved the MAC address of the next hop, he sends the data. Before sending the data packet over the Ethernet, it is divided into shorter pieces called frames.
MAC addresses are needed for communication within the Local Area Network. IP address comes into the picture when the packet has to be routed to a different network.
Why MAC address are used locally only?
With MAC addresses, there is no hierarchy, and thus packet forwarding would not be possible. So, MAC addresses are not used for packet transfer.
And also, a host (e.g., a computer) cannot determine from the MAC address of another host whether that host is on the same network as the sending host, or on a network bridged to that network. This is the weakness of a MAC address and the reason why it is not used for determining the location of a host. Instead, determining a host's location, whether it is on the same network or another network, can only be accomplished by means of the IP address.
To route by MAC addresses, routers would have to account for every machine on the network individually which is a impossible for a network the size of the Internet.
Why we need IP when MACs are so unique?
To explain this in layman’s terms, let us compare IP routing to our postal address and routers to various post offices worldwide. Now let’s say your friend in Virginia, USA mails you a post card to your residence address which is like 101 Ganesh Society, Nariman Point, Mumbai-400001, Maharashtra, India. The post card will be first delivered to India then Maharashtra then Mumbai till it finally reaches your apartment.
Now let’s assume your another friend in India were to post you a postcard from New Delhi and he only knows your Aadhar Id (an unique Id for Indian citizen). Will the post office be able to deliver the post card without even referring your postal address online? The answer is No. This is simply because every post office worldwide relies on each other to deliver the posts.
Now, once again let's use the analogy of post office and unique ID and assume we had to use only the MAC address or a Unique ID or Aadhar Id to deliver information to another computer somewhere across the world. In this case we would require a single gigantic post office somewhere in first place. All the posts would be collected by this giant post office and then distributed to each person across the world. Which would also mean that if this post office was to be setup in New York, the post card from your friend in New Delhi would have to travel to New York before reaching you. This post office might have to handle millions of mails and parcels daily. They would have to maintain postal records for literally each person in the world so that their logistics team may deliver posts to respective people directly (Since there is no other post office to do the job). This may require infinite amount of resources and delivery teams travelling from just one central post office to each house in the world which is again next to impossible.
Similarly in the case of computer networks or an Internet, it is not possible to hook every single computer in the world to one network router or switch. We need to break this into smaller network segments, also known as subnets.
Comments