Easily administer network devices, monitor traffic, and manage device configurations in one place.
The internet is a complex collection of network devices and servers that are interconnected through gateways. If a network error occurs as a result of data loss or delay, finding an IP packet path or discovering a faulty gateway can be difficult. A traceroute can help troubleshoot internet-related problems. In this article, you'll find out what a traceroute is and how it works. You'll also see some helpful examples.
Traceroute is a utility that allows you to see the route of an IP packet. Simply put, a traceroute sends packets to a destination and then measures how long it takes them to return. Using this information, the traceroute builds a map of the network between the source and destination.
A traceroute can help you discover the path that packets take from your computer to a specific destination—for example, your favorite website. It can show you where in the network the problem occurs. You can execute a traceroute from the command line.
Now that you have a basic understanding of what a traceroute is, it's time to take a look at how it operates.
Traceroute uses internet control message protocol (ICMP) packets to determine where in the network a packet fails. The most common use of ICMP is to notify about problems in packets.
When you run traceroute, it sends a series of packets to the destination. The command increments the TTL (time-to-live, or maximum number of hops) value of the probe packet by one with each successive packet. The TTL defines the maximum number of hops per packet.
When a packet travels through the network, each router decrements one from the TTL value until it reaches zero. The router then sends back an ICMP TIME_EXCEEDED response message if the TTL value reaches zero. The command sends packets regularly throughout the path to a target host. The traceroute command records the time it takes for each packet to return to the host and determine how far away each router is from the source.
Imagine that you're trying to request some information from a faraway server
What if you had some sort of issue with your ISP's network? In that case, it could interfere with this process. For example, there might be a problem at one of their servers or routers along the route. Or maybe the packets were routed through an overloaded shared line. Either way, you have a problem because your data is delayed and doesn't reach its destination within the expected time.
Using a traceroute, you can identify each server along the route that receives your IP packet. You can also determine the round-trip delay between the probe host and each relay. This allows you to easily identify weak nodes that are affecting your network performance and the response time of each hop along the way
Now, you can figure out how to optimize your network setup to decrease response times in your application, service, or website by following the actual route between a server and your computer.
Now that you have a better understanding of traceroute, it's time to talk about how you can use it. If you wanted to track the journey of a packet from your computer to a host, such as www.google.com, you could enter the command as below:
traceroute -m 30 google.com 60
Please note you need to provide the host name or IP address of your destination server as a mandatory parameter to this command. Here -m 30 is used to specify 30 hops to be shown, and 60 sets the byte size of each packet.
The traceroute command offers several options. Using these, you can troubleshoot connectivity issues or simply learn how the internet works. Here are the most useful options.
-p <port>: It allows you to specify a certain port to probe on each hop.
-n : This option prevents the traceroute from resolving the hostnames of each hop.
-m <max_ttl> : This option sets how many hops (max_ttl) appear on the final results page.
-i <ip address or hostname>: This option sets the source IP address for the traceroute.
-w : This option sets a timeout value for each hop in seconds. The default is five seconds.
-z <pause milliseconds>: This option allows you to add a delay in milliseconds between probes.
Some of these options are better for troubleshooting purposes than others. For example, using -w can be useful for finding routers that take a long time to respond. However, it works only on routers that support this functionality.
Here's what the output would look like.
$ traceroute -m 30 google.com 60
traceroute to google.com (126.96.36.199), 30 hops max, 60 byte packets
1 192.168.1.1 (192.168.1.1) 14.795 ms 8.726 ms 3.030 ms
2 abts-ap-static-188.8.131.52.airtelbroadband.in (184.108.40.206) 5.493 ms 5.368 ms 5.398 ms
3 220.127.116.11 (18.104.22.168) 5.048 ms
22.214.171.124 (126.96.36.199) 5.035 ms 5.693 ms
4 * 188.8.131.52 (184.108.40.206) 21.320 ms
220.127.116.11 (18.104.22.168) 33.119 ms
5 22.214.171.124 (126.96.36.199) 18.078 ms 188.8.131.52 (184.108.40.206) 16.304 ms
220.127.116.11 (18.104.22.168) 32.955 ms
6 * * *
7 22.214.171.124 (126.96.36.199) 28.009 ms
188.8.131.52 (184.108.40.206) 19.272 ms
220.127.116.11 (18.104.22.168) 19.097 ms
8 22.214.171.124 (126.96.36.199) 17.270 ms 16.503 ms
188.8.131.52 (184.108.40.206) 16.485 ms
9 220.127.116.11 (18.104.22.168) 18.863 ms 18.835 ms
maa03s45-in-f14.1e100.net (22.214.171.124) 16.906 ms
The output lists every router that the packet goes through on its journey to www.google.com. The listed hops are ordered in terms of how close they are to your computer, the first hop being the closest. This is a useful way to identify the general location of an issue within your ISP's network.
The output of the traceroute command will list every router in the path between your computer and the target host. It'll also specify how long each leg of the journey took. You can view how long each packet took to travel as well as any errors that were encountered.
It's possible that a node isn't sending any TIME_EXCEEDED packets back to the source. This could be for security reasons. These nodes can only relay the packet but will not respond with any information about their network identity. A traceroute uses the asterisk symbol ( * ) to indicate such sensitive information.
There are also some routers that disallow traceroute requests. Usually, this is because they're used for hosting web pages or other security-sensitive services.
You can use the traceroute command to help identify the problem. A traceroute can help you determine if there's a problem with your internet connection, the website you're trying to reach, or an intermediary.
The output of the traceroute command can help you to troubleshoot and fix networking problems. You can also use the traceroute command to diagnose problems with your computer's network adapter.
Another useful strategy is to try running a traceroute from multiple computers connected to the same ISP (internet service provider). If you get a different result when using two or more devices, then it's likely that your ISP has issues with congestion or routing in their network. In that case, you may need to contact your ISP for support.
While the traceroute command is extremely useful, it does have its limits. Traceroute also has issues with showing latency. This is because it measures only the time that a packet takes to travel each leg of the journey, not the time that it actually spends in transit. The latter is far more reliable when trying to troubleshoot issues.
The traceroute command is a great tool for diagnosing problems and figuring out where they're coming from. Therefore, whenever you encounter a problem in your network connection, a traceroute should be one of the first things you run. It also provides several command options to troubleshoot issues.
CLI tools can be used to efficiently monitor network traffic on Linux. Go through different scenarios in which they can be used.➤
Learn what is BGP hijacks and insecurities. Detect and avoid BGP hijacks and maintain the security of your network infrastructure.➤
Write for Site24x7 is a special writing program that supports writers who create content for Site24x7 “Learn” portal. Get paid for your writing.Apply Now