Skip to main content

Network connectivity - the bane of all computer users...

Network connectivity - the bane of all computer users...

If I am faced with a machine with a broken network connection, I always start with a few simple tests.  First see whether the machine has an IP address, netmask and default route.  If the basics do not work, nothing else will, but it is amazing how many people do not think about that!

If the basics are fine, try to do a ping of another machine - that will test most things, including the Domain Name Server.  Finally, I use Telnet to verify that the destination service is working.

Doing these tests manually, will provide you with helpful error messages.   The Linux error messages always tell you *exactly* what the problem is.  If you don't understand them, then google these messages for more information.  Another unfortunate soul likely had the same problem already.  If you use a GUI utility, then you are insulated from the error messages and you are reduced to aimlessly poking around in the dark.

If those do not work, try to use the Dynamic Host Configuration Protocol (DHCP) to fix things.

ifconfig

Display the device name, IP address and netmask:
# ifconfig

 em1       Link encap:Ethernet  HWaddr 00:21:CC:5E:98:D9
          inet addr:172.22.2.74  Bcast:172.22.2.255  Mask:255.255.255.0

In the olden days, the ethernet ports were always named eth0, eth1 and so on, but nowadays it seems that it can be anything at all, for example em1 or whatever the device file system chose at first startup.

You can also use ifconfig to set the IP address of an embedded system:
# ifconfig em1 192.168.0.1 netmask 255.255.255.0 up

route

Display the routing table and make sure that there is a default gateway defined:
# route

Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
default         172.22.2.1      0.0.0.0         UG    0      0        0 em1
172.22.2.0      *               255.255.255.0   U     1      0        0 em1

dhclient

You can use dhclient to talk to a DHCP server to reset the machine address and route (make sure it is stopped before running it again):
# killall dhclient
# dhclient eth0

If there is no DHCP server, if for example you are running an embedded system with static addresses, then you got to configure the above manually and in this case, you should disable automatic wizards such as NetworkManager, since it will cause you periodic grief by ever so helpfully changing your static setup for you!

ping

If all works so far, try to ping something.  Yahoo always answers to pings:
# ping www.yahoo.com

PING ds-eu-fp3.wa1.b.yahoo.com (87.248.122.122) 56(84) bytes of data.

Some network administrators configure their routers to filter out ping requests.  This is rather unhelpful, because ping is a valuable test tool, but Telnet will accomplish much the same thing.

dig

Ping also shows whether the DNS is working.  If not, check the nameserver definition in /etc/resolve.conf.  You can always use the Google DNS at 8.8.8.8 if you don't have a better one.

You can also do a DNS test with nslookup or dig:
# dig www.yahoo.com

; <<>> DiG 9.8.4-P1-RedHat-9.8.4-3.P1.fc16 <<>> www.yahoo.com
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 10032
;; flags: qr rd ra; QUERY: 1, ANSWER: 5, AUTHORITY: 0, ADDITIONAL: 0

;; QUESTION SECTION:
;www.yahoo.com.            IN    A

;; ANSWER SECTION:
www.yahoo.com.        0    IN    CNAME    fd-fp3.wg1.b.yahoo.com.
fd-fp3.wg1.b.yahoo.com.    0    IN    CNAME    ds-fp3.wg1.b.yahoo.com.
ds-fp3.wg1.b.yahoo.com.    0    IN    CNAME    ds-eu-fp3-lfb.wa1.b.yahoo.com.
ds-eu-fp3-lfb.wa1.b.yahoo.com. 0 IN    CNAME    ds-eu-fp3.wa1.b.yahoo.com.
ds-eu-fp3.wa1.b.yahoo.com. 42    IN    A    87.248.112.181

;; Query time: 12 msec
;; SERVER: 10.10.63.5#53(10.10.63.5)
;; WHEN: Mon Apr 15 12:30:45 2013
;; MSG SIZE  rcvd: 151

telnet

Finally, try to connect to the destination server using Telnet and see what it says:
# telnet www.yahoo.com 80

Trying 87.248.112.181...
Connected to www.yahoo.com.
Escape character is '^]'.


You should get the web server banner and you could even GET the home page manually:

get index.html
<HEAD><TITLE>Redirect</TITLE></HEAD>
<BODY BGCOLOR="white" FGCOLOR="black">
<FONT FACE="Helvetica,Arial"><B>
 "<em>http://failsafe.fp.yahoo.com/404.html</em>".<p></B></FONT>

<!-- default "Redirect" response (302) -->
</BODY>
Connection closed by foreign host.


Happy debugging!

Comments

Popular posts from this blog

Parasitic Quadrifilar Helical Antenna

This article was reprinted in OSCAR News, March 2018:  http://www.amsat-uk.org If you want to receive Satellite Weather Pictures , then you need a decent antenna, otherwise you will receive more noise than picture. For polar orbit satellites, one needs an antenna with a mushroom shaped radiation pattern .  It needs to have strong gain towards the horizon where the satellites are distant, less gain upwards where they are close and as little as possible downwards, which would be wasted and a source of noise.  Most satellites are spin stabilized and therefore the antenna also needs circular polarization, otherwise the received signal will flutter as the antennas rotate through nulls. The helical antenna, first proposed by Kraus in 1948, is the natural solution to circular polarized satellite communications.  It is a simple twisted wire - there seems to be nothing to it.  Various papers have been published on helix antennas, so the operation is pretty well understood. Therefore,

Patch Antenna Design with NEC2

The older free Numerical Electromagnetic Code version 2 (NEC2) from Lawrence Livermore Lab assumes an air dielectric.  This makes it hard (but not impossible) for a radio amateur to experiment with Printed Circuit Board Patch antennas and micro strip lines. Air Spaced Patch Antenna Radiation Pattern You could use the free ASAP simulation program , which handles thin dielectrics, you could shell out a few hundred Dollars for a copy of NEC4 , You could buy GEMACS if you live in the USA, or you could add distributed capacitors to a NEC2 model with LD cards (hook up one capacitor in the middle of each element.), but that is far too much money/trouble for most. More information on driving an array antenna can be found here: https://www.aeronetworks.ca/2019/03/driving-quad-patch-array-antenna.htm l Air Dielectric Patch   The obvious lazy solution is to accept the limitation and make an air dielectric patch antenna. An advantage of using air dielectric, is that the antenn

Weather Satellite Turnstile Antennas for the 2 meter Band

NEC2, 2 m band, 146 MHz, Yagi Turnstile Simulation and Build This article describes a Turnstile Antenna for the 2 meter band, 146 MHz amateur satcom, 137 MHz NOAA and Russian Meteor weather satellites.  Weather satellite reception is described here .  A quadrifilar helical antenna is described here .   Engineering, is the art of making what you need,  from what you can get. Radiation Pattern of the Three Element Yagi-Uda Antenna Once one combine and cross two Yagis, the pattern becomes distinctly twisted. The right hand polarization actually becomes visible in the radiation pattern plot, which I found really cool. Radiation Pattern of Six Element Turnstile Antenna Only a true RF Geek can appreciate the twisted invisible inner beauty of a herring bone antenna... Six Element Turnstile Antenna Essentially, it is three crosses on a stick.  The driven elements are broken in the middle at the drive points.  The other elements can go straight throug