Have you ever wondered about the mechanisms that delivered this page to you? Chances are you are sitting at a computer right now, viewing this page in a browser. So, when you clicked on the link for this page, or typed in its URL (uniform resource locator), what happened behind the scenes to bring this page onto your screen?If
you've ever been curious about the process, or have ever wanted to know
some of the specific mechanisms that allow you to surf the Internet,
then read on. In this article, you will learn how Web servers bring
pages into your home, school or office.
The Basic Process
Let's say that you are sitting at your computer, surfing the Web, and
you get a call from a friend who says, "I just read a great article!
Type in this URL and check it out. It's at
http://www.howstuffworks.com/web-server.htm." So you type that URL into
your browser and press return. And magically, no matter where in the
world that URL lives, the page pops up on your screen.
At the most basic level possible, the following diagram shows the steps that brought that page to your screen:
Your browser formed a connection to a Web server, requested a page and received
Behind the Scenes
If you want to get into a bit more detail on the process of getting a
Web page onto your computer screen, here are the basic steps that
occurred behind the scenes:
The browser broke the URL into three parts:
- The protocol ("http")
- The server name ("www.howstuffworks.com")
- The file name ("web-server.htm")
The browser communicated with a name server to translate the server name "www.howstuffworks.com" into an IP Address,
which it uses to connect to the server machine. The browser then formed
a connection to the server at that IP address on port 80. (We'll
discuss ports later in this article.)
Following the HTTP protocol,
the browser sent a GET request to the server, asking for the file
"http://www.howstuffworks.com/web-server.htm." (Note that cookies may be sent from browser to server with the GET request -- see How Internet Cookies Work for details.)
The server then sent the HTML text for the Web page to the browser. (Cookies may also be sent from server to browser in the header for the page.) The browser read the HTML tags and formatted the page onto your screen.
If
you've never explored this process before, that's a lot of new
vocabulary. To understand this whole process in detail, you need to
learn about IP addresses, ports, protocols.
The Internet
So what is "the Internet"? The Internet is a gigantic collection of millions of computers, all linked together on a computer network.
The network allows all of the computers to communicate with one
another. A home computer may be linked to the Internet using a phone-line modem, DSL or cable modem that talks to an Internet service provider (ISP). A computer in a business or university will usually have a network interface card (NIC) that directly connects it to a local area network (LAN) inside the business. The business can then connect its LAN to an ISP using a high-speed phone line like a T1 line. A T1 line
can handle approximately 1.5 million bits per second, while a normal
phone line using a modem can typically handle 30,000 to 50,000 bits per
second.
ISPs then connect to larger ISPs, and the largest ISPs maintain fiber-optic
"backbones" for an entire nation or region. Backbones around the world
are connected through fiber-optic lines, undersea cables or satellite links (see An Atlas of Cyberspaces
for some interesting backbone maps). In this way, every computer on the
Internet is connected to every other computer on the Internet.
Clients and Servers
In general, all of the machines on the Internet can be categorized as
two types: servers and clients. Those machines that provide services
(like Web servers or FTP servers) to other machines are servers. And the machines that are used to connect to those services are clients.
When you connect to Yahoo! at www.yahoo.com to read a page, Yahoo! is
providing a machine (probably a cluster of very large machines), for use
on the Internet, to service your request. Yahoo! is providing a server.
Your machine, on the other hand, is probably providing no services to
anyone else on the Internet. Therefore, it is a user machine, also known
as a client. It is possible and common for a machine to be both a
server and a client, but for our purposes here you can think of most
machines as one or the other.
A server machine may provide one or
more services on the Internet. For example, a server machine might have
software running on it that allows it to act as a Web server, an e-mail server and an FTP
server. Clients that come to a server machine do so with a specific
intent, so clients direct their requests to a specific software server
running on the overall server machine. For example, if you are running a
Web browser on your machine, it will most likely want to talk to the
Web server on the server machine. Your Telnet application will want to talk to the Telnet server, your e-mail application will talk to the e-mail server, and so on...
P Addresses
To keep all of these machines straight, each machine on the Internet is assigned a unique address called an IP address. IP stands for Internet protocol, and these addresses are 32-bit numbers, normally expressed as four "octets" in a "dotted decimal number." A typical IP address looks like this:
216.27.61.137
The four numbers in an IP address are called octets because they can have values between 0 and 255, which is 28 possibilities per octet.
Every
machine on the Internet has a unique IP address. A server has a static
IP address that does not change very often. A home machine that is
dialing up through a modem often has an IP address that is assigned by
the ISP when the machine dials in. That IP address is unique for that
session -- it may be different the next time the machine dials in. This
way, an ISP only needs one IP address for each modem it supports, rather
than for each customer.
If you are working on a Windows machine,
you can view a lot of the Internet information for your machine,
including your current IP address and hostname, with the command WINIPCFG.EXE (IPCONFIG.EXE for Windows 2000/XP). On a UNIX machine, type nslookup
at the command prompt, along with a machine name, like
www.howstuffworks.com -- e.g. "nslookup www.howstuffworks.com" -- to
display the IP address of the machine, and you can use the command hostname to learn the name of your machine. (For more information on IP addresses, see IANA.)
As
far as the Internet's machines are concerned, an IP address is all you
need to talk to a server. For example, in your browser, you can type the
URL http://209.116.69.66 and arrive at the machine
that contains the Web server for HowStuffWorks. On some servers, the IP
address alone is not sufficient, but on most large servers it is
Domain Names
Because most people have trouble remembering the strings of numbers
that make up IP addresses, and because IP addresses sometimes need to
change, all servers on the Internet also have human-readable names,
called domain names. For example, www.howstuffworks.com
is a permanent, human-readable name. It is easier for most of us to
remember www.howstuffworks.com than it is to remember 209.116.69.66.
The name www.howstuffworks.com actually has three parts:- The host name ("www")
- The domain name ("howstuffworks")
- The top-level domain name ("com")
Domain names within the ".com" domain are managed by the registrar called VeriSign.
VeriSign also manages ".net" domain names. Other registrars (like
RegistryPro, NeuLevel and Public Interest Registry) manage the other
domains (like .pro, .biz and .org). VeriSign creates the top-level
domain names and guarantees that all names within a top-level domain are
unique. VeriSign also maintains contact information for each site and
runs the "whois" database. The host name is created by the company
hosting the domain. "www" is a very common host name, but many places
now either omit it or replace it with a different host name that
indicates a specific area of the site. For example, in encarta.msn.com, the domain name for Microsoft's Encarta encyclopedia, "encarta" is designated as the host name instead of "www."
Protocols
Once a client has connected to a service on a particular port, it accesses the service using a specific protocol. The protocol
is the pre-defined way that someone who wants to use a service talks
with that service. The "someone" could be a person, but more often it is
a computer program like a Web browser. Protocols are often text, and
simply describe how the client and server will have their conversation.
Perhaps the simplest protocol is the daytime protocol.
If you connect to port 13 on a machine that supports a daytime server,
the server will send you its impression of the current date and time and
then close the connection. The protocol is, "If you connect to me, I
will send you the date and time and then disconnect." Most UNIX machines
support this server. If you would like to try it out, you can connect
to one with the Telnet application. In UNIX, the session would look like
this:
%telnet web67.ntx.net 13Trying
216.27.61.137...Connected to web67.ntx.net.Escape character is '^]'.Sun
Oct 25 08:34:06 1998Connection closed by foreign host.
On a Windows machine, you can access this server by typing "telnet web67.ntx.net 13" at the MSDOS prompt.
In
this example, web67.ntx.net is the server's UNIX machine, and 13 is the
port number for the daytime service. The Telnet application connects to
port 13 (telnet naturally connects to port 23, but you can direct it to
connect to any port), then the server sends the date and time and
disconnects. Most versions of Telnet allow you to specify a port number,
so you can try this using whatever version of Telnet you have available
on your machine.
Most protocols are more involved than daytime
and are specified in Request for Comment (RFC) documents that are
publicly available (see http://sunsite.auc.dk/RFC/ for a nice archive of all RFCs). Every Web server on the Internet conforms to the HTTP protocol, summarized nicely in The Original HTTP as defined in 1991.
The most basic form of the protocol understood by an HTTP server
involves just one command: GET. If you connect to a server that
understands the HTTP protocol and tell it to "GET filename," the server
will respond by sending you the contents of the named file and then
disconnecting. Here's a typical session:
%telnet
www.howstuffworks.com 80Trying 216.27.61.137...Connected to
howstuffworks.com.Escape character is '^]'.GET
http://www.howstuffworks.com/ ...Connection closed by foreign host.
In
the original HTTP protocol, all you would have sent was the actual
filename, such as "/" or "/web-server.htm." The protocol was later
modified to handle the sending of the complete URL.
Extras: Security
You can see from this description that a Web server can be a pretty
simple piece of software. It takes the file name sent in with the GET
command, retrieves that file and sends it down the wire to the browser.
Even if you take into account all of the code to handle the ports and
port connections, you could easily create a C program
that implements a simple Web server in less than 500 lines of code.
Obviously, a full-blown enterprise-level Web server is more involved,
but the basics are very simple.
Most servers add some level of security
to the serving process. For example, if you have ever gone to a Web
page and had the browser pop up a dialog box asking for your name and
password, you have encountered a password-protected page. The server
lets the owner of the page maintain a list of names and passwords for
those people who are allowed to access the page; the server lets only
those people who know the proper password see the page. More advanced
servers add further security to allow an encrypted connection between server and browser, so that sensitive information like credit card numbers can be sent on the Internet.
Extras: Dynamic Pages
But what about the Web pages that are dynamic? For example:
- Any guest book allows you to enter a message in an HTML form, and the next time the guest book is viewed, the page will contain the new entry.
- The whois form at Network Solutions allows you to enter a domain name on a form, and the page returned is different depending on the domain name entered.
- Any search engine lets you enter keywords on an HTML form, and then it dynamically creates a page based on the keywords you enter.
No comments:
Post a Comment