|Last updated: 6/16/2002; 10:22:21 AM|
Marketing 101. Consulting 101. PHP Consulting. Random geeky stuff. I Blog Therefore I Am.Basic Network Troubleshooting or What Do I Do Before I Call My SysAdmin ?
I was troubleshooting some network connectivity problems recently with a box in a remote data center that wasn’t responding and I thought this technique would come in handy to someone. There isn’t any magic here and I’m not pretending that there is. Still, if you are new to doing network stuff this is useful.
NOTE: SysAdmin is short hand for “Systems Administrator”. Generally this is the guy who keeps everything running and in order. He’s also the guy who will save you time and again. As a general rule, be nice to your SysAdmin.
NOTE 2 : I ran these by my friend Kjartan who’s a much better *nix admin than I am and he added some great points. I agree with all of them and, rather than rewriting them, I thought I’d give full credit but leaving them intact as a final section.
There are two core network troubleshooting tools for Internet style networking (i.e. TCP/IP networking). They are Ping and TraceRt (pronounced “Trace Route”). Here’s what they do:
- ping – Contact a machine between 1 and N times (N might be infinite) sending it one “chunk” of information to see if it responds.
- tracert – Trace the “route” over (generally) 30 hops between your machine and the remote machine.
Here’s a pretty good assumption when you have a machine in a data center and THEY gave you the machine’s IP address:
Machines in data centers generally have consecutive IP addresses. Let’s say for example that your machine has the IP address: 18.104.22.168. It’s a pretty good bet that 22.214.171.124 will be another machine in that SAME data center. What I do when troubleshooting failures is alter the IP address I am looking at by 1 or 2 digits on the last set of numbers. This tells me whether or not the failure is the entire data center or just a machine or group of machines.
How to Troubleshoot a Remote Machine
This is one of those things that there are as many different opinions on as there are SysAdmins. I tend to use this approach.
- Ping the remote machine by dns name such as “ping example.com”. If this fails, proceed to step 2.
- Ping the remote machine by IP address such as “ping 126.96.36.199”. Don’t know your machine’s IP address? Pinging it will reveal it to you. WRITE IT DOWN NOW. Don’t lose it. If DNS fails you can often reach your machine by IP address.
- If this succeeds then your machine is still on the Internet but you have a DNS failure. Contact your SysAdmin immediately.
- If this fails then proceed to step 3.
Run a tracert to the remote machine by IP address. This will give a result like this.
Tracing route to 188.8.131.52 over a maximum of 30 hops:
1 15 ms <10 ms 16 ms 184.108.40.206 2 16 ms <10 ms 15 ms bar01-p0-1-0.sagshe1.ma.attbb.net [220.127.116.11]
3 <10 ms 16 ms 16 ms 18.104.22.168 4 <10 ms 16 ms 15 ms bar03-p8-0.wobnhe1.ma.attbb.net [22.214.171.124] 5 <10 ms 16 ms 16 ms 126.96.36.199 6 <10 ms 15 ms 16 ms gbr1-p70.cb1ma.ip.att.net [188.8.131.52] 7 16 ms 15 ms 16 ms tbr1-p013401.cb1ma.ip.att.net [184.108.40.206] 8 * * * Request timed out. 9 16 ms 15 ms 16 ms ggr1-p320.n54ny.ip.att.net [220.127.116.11] 10 16 ms 15 ms 16 ms att-gw.ny.verio.net [18.104.22.168] 11 79 ms 93 ms 78 ms p16-6-0-0.r00.mlpsca01.us.bb.verio.net [22.214.171.124] 12 78 ms 78 ms 94 ms p16-7-0-0.r01.mlpsca01.us.bb.verio.net [126.96.36.199] 13 78 ms 94 ms 93 ms p16-7-0-0.r00.lsanca01.us.bb.verio.net [188.8.131.52] 14 79 ms 93 ms 94 ms ge-2-0-0.a02.lsanca02.us.ra.verio.net [184.108.40.206] 15 78 ms * 78 ms d1-1-2-2.a02.lsanca02.us.ce.verio.net [220.127.116.11] 16 94 ms 94 ms 94 ms 18.104.22.168 17 94 ms 94 ms 109 ms www.example.com [22.214.171.124]
When you have a failure, what you are looking for is something like this:
21 * some domain name [126.96.36.199] reports: Destination host unreachable.
This tells you that on hop 21 to the destination it found an error. It’s a pretty good certainty that if you can’t get to your machine via ping to it’s name, ping to its IP address or tracert to its IP address you need to call your SysAdmin.
Feedback from KjartanKjartan sent these comments. I reformatted them from the email but they're all pretty much the same (and they are excellent). Thanks!
- tracert is called traceroute in linux systems. The tracert is a relic from the days when DOS/Windows only supported 8.3 file names.
- It really helps to know the route from your location to the server. Not being able to reach a server can be your ISPs problem. I have a copy of traceroutes too all my servers saved on file so I can guess where the failure is. I can usually tell if the failure is my isp, the hosting company or somewhere in between. Ofcoz routes change so its not an exact science, but with some experience its not that hard.
- Make sure there are no firewalls blocking pings/traceroutes. ISPs/hosting companies have a nasty habit of modifying the rules at will. So when the web server is down make sure you can’t contact the server via ssh (or telnet if you still run that).
|Copyright 2002 © The FuzzyStuff|