by Uzma Husain
IN THIS CHAPTER
The communication tools discussed in this chapter include the following:
This chapter discusses all of these communications tools in detail and gives you the basics of how to use them in Linux. With practice, you will soon begin to use these tools effectively.
The write command is a communication tool that enables a user to interact directly with other users. If you want to ask your friend a simple question or ask him out to lunch, and you know that he is logged in, write is the tool to use. Unlike e-mail, which is discussed later, write pastes your message directly on the recipient's terminal who does not have to take any steps to receive it. To use the write command, your terminal and that of the other user should have write permission. Having these permissions enables you to write messages on each other's terminals. To look at the terminal settings, you need to know which terminal you are on. To find your terminal number, use the tty command as shown here:
mpsi:~$ tty /dev/tty2 mpsi:~$ ls -al /dev/tty2 crw--w--w- 1 calvin users 4, 2 Jan 15 05:49 /dev/tty2
The preceding code sample shows that I am on /dev/tty2. Your output may be different, depending on which terminal you happen to be on. The output of the ls command shows that others have write permission available on your terminal. You can confirm this by using the mesg command as shown here:
mpsi:~$ mpsi:~$ mesg Is y
The outcome of the mesg command shows that the terminal enables messages to be written to it. You can toggle the terminal settings on and off with the following command:
mpsi:~$ mesg n mpsi:~$ mesg Is n
The preceding segment turned the mesg off. Now you can't be disturbed by any other user. (You may miss out on lunch dates, though.)
The write command enables you to write an actual message on the other terminal online. You have to issue the write command with the login ID of the user with whom you want to communicate. The write command informs the user at the other end that there is a message from another user. write pastes that message onto the other user's terminal if their terminal's write permissions are set. Even if they are in the middle of an edit session, write overwrites whatever is on the screen. The edit session contents are not corrupted; you can restore the original screen on most editors with Ctrl-L. write is mostly used for one-way communication, but you can have an actual conversation as well.
Because you want your friend to be able to write to your tty as well, always begin by checking the status of the mesg command:
mpsi:~$ mpsi:~$ mesg Is y
Let's see whether your friend, Calvin, is logged in. You can do this by using the who command and piping it to the grep program to search for Calvin because you don't want the entire list of users to scroll down your terminal.
mpsi:~$ who | grep calvin calvin tty2 Jan 15 15:26
Oops! All the ttys are in /dev, so add /dev to tty2.
Now let's see whether he wants to be disturbed:
mpsi:~$ ls -al /dev/tty2 crw--w--w- 1 calvin users 4, 2 Jan 15 15:28 /dev/tty2 mpsi:~$
This excerpt shows you that Calvin is indeed logged in. Now let's see whether he is interested in communicating with a write session:
mpsi:~$ write calvin
Calvin sees the following on his screen:
mpsi:~$ Message from laurel@mpsi on tty1 at 15:36 ...
Now you have to wait for Calvin's response to the request. He responds by typing the following on his terminal if he is interested in communicating with you:
mpsi:~$ write laurel How are you?
Lunch tomorrow?
The following string appears on your terminal:
Message from calvin@mpsi on tty2 at 15:36 ... How are you?
Lunch tomorrow?
You can answer Calvin by initiating another write session from your end and typing your message. You have to press Enter at the end of each line for it to be displayed at the other terminal. To simplify communications, you can type over at the logical end of your sentence. Calvin should do likewise.
If you are waiting for the other party to respond to your write request, it is polite to let him reply while you wait. Only after he has accepted your invitation should the conversation begin. Also, let the called party have the first chance to reply by typing hello or any other salutation. Avoid typing until the other party stops or signals you to begin with an end-of-message word, such as over. Remember, only one person can speak at a time on this channel.
The write tool was nice for communicating one at a time. However, UNIX enables you to type simultaneously with the talk tool.
talk is an interactive communication tool that enables you to have an actual conversation in real-time mode with another user. You can actually see the conversation being typed as the other user is typing it. For talk to work, the other user has to be logged in, just as in write.
talk can be very annoying and disturbing if someone wants to be pesky. If you don't want to be disturbed, just turn talk off by entering mesg n at the prompt.
You can talk to somebody by typing talk followed by the user's login ID. To see if the user is logged in, you can use the who command just like you did for write. Let's try to talk to Calvin:
$ talk calvin
The computer responds with
[Waiting for your party to respond]
The user on the other end sees the following message even if he is in the middle of an edit session. The system beeps and displays the following message on the terminal:
Message from Talk_Daemon@mpsi at 13:08 ... talk: connection requested by laurel@hobbes.com. talk: respond with: talk laurel@hobbes.com
To respond to this phone call, type the command shown in the respond with message shown here. If your friend does not respond, the talk daemon persistently bothers him with the preceding message every 30 seconds.
At your terminal, you see the following messages:
[Ringing your party again] [Ringing your party again] [Ringing your party again] [Ringing your party again]
Occasionally, you will see the following message:
[Your party is refusing messages]
What happened? Your friend at the other end does not want to talk or be disturbed. After several of your interruptions, he has decided to turn his mesg off. That is why you got the message that your party is refusing messages.
Now let's look at a nicer scenario, when someone wants to talk to you. He has to respond with the following command:
talk laurel
Then your terminal displays the following screen:
[Connection Established]
---------------------------------------
The screen is divided horizontally with a dotted line, and you can type your message on the top half of the screen. This appears verbatim on the other terminal at the bottom half of the screen. You can type your messages, and the other user can type his, simultaneously.
The connection can be closed by entering Ctrl-C. The following line appears on the screen:
[Connection closing.Exiting]
You should now be back at your shell's command prompt.
The same etiquette applies to talk as in write. Always use lowercase letters, because CAPS LOCK conversations are considered loud and rude. Always finish your sentence by typing over. If you initiated the talk session, wait for the other party to respond with the hello first. To prevent both of you from typing at the same time, always read your message, wait for the over, type your own message, and then terminate it with over.
Electronic mail has taken the world by storm. E-mail, short for electronic mail, is a method of sending a message from a user on one computer to one or several recipients on another computer. E-mail provides fast and efficient transportation of data and documents. This mode of communication also eliminates the need to play telephone tag or to wait for a convenient or appropriate time to call someone. For someone with Internet access, e-mail provides the means to communicate with friends around the world.
E-mail is stored in a file called the system mail in the mailbox. System mail has the same name as that of the user. For example, a user named Calvin will have a mailbox under Linux in /var/spool/mail/calvin.
E-mail originates in the form of a file on your computer created by a Mail User Agent (MUA). E-mail is then submitted to a mail router such as sendmail, after which it is handed over to a Mail Transporter Agent (MTA). E-mail is then appended to a mailbox. The MTA delivers it to the final delivery agent by traversing one or more hosts.
The MUA is used to read and send mail. The MUA is the user interface for the mail system. Mail can be composed by using simple MUAs such as mail or mailx, or sophisticated mail user agents such as elm or pine.
A mail message includes two parts: a mail header and the text body.
The mail header is generated by the mail program automatically. A typical header in a mail message looks like this:
Date: Fri, 6 Jan 1995 13:27:00 -0600 From: "Calvin N. Hobbes" <calvin@hobbes.com> To: laurel@hady.com Subject: Format for a mail header Hi, just checking the different parts in a mail message
Date specifies the date and time the message is sent.
From specifies both the sender's name in quotes and the address, which includes the login ID and the address of their machine, hobbes.com.
To is the recipient's mail address.
Subject is a one-line description of the mail message.
The mail header is followed by the body of the mail message. Here you type the message as text. The mail message is terminated by typing a period (.) as the first character on the last line. The mail handler responds with EOT, for End Of Text. This is the standard procedure for Berkeley Mail; other mail handlers have their own way of ending message text entry.
There are several types of mail user agents, some of which are listed here. A variety of different programs can be used for reading the mail. The two most common programs are mail and Mail (also called mailx). Because of the similarity of their names, Mail is also called capmail or Berkeley Mail. Berkeley Mail is far superior to mail because it is much easier to use.
This section covers the following types of mail user agents:
Using elm elm, which stands for electronic mail, provides a full-screen interface mail program with a good help feature. elm is a pleasure to use when compared with Berkeley Mail because of its simplicity of use and functionality.
Start the elm system by typing elm at the command prompt:
$ elm
The screen is cleared, and the code shown in Listing 14.1 is displayed.
$ elm Mailbox is `/var/spool/mail/calvin' with 5 messages [ELM 2.4 PL25] N 1 Jan 12 Laurel N. Hardy (15) using el N 2 Jan 12 Laurel N. Hardy (15) 2nd elm message N 3 Jan 12 Laurel N. Hardy (16) Using elm N 4 Jan 11 Laurel N. Hardy (11) Re: Format for a mail header N 5 Jan 11 Laurel N. Hardy (11) message # 1 You can use any of the following commands by pressing the first character;
d)elete or u)ndelete mail, m)ail a message, r)eply or f)orward mail, q)uit
To read a message, press <return>. j = move down, k = move up, ? = help
Command:
The top line on the screen is the mailbox and the number of messages it has in it. You may also see elm's version number. This is followed by a list of all the messages in the mailbox, the date the messages were sent, the sender's name, and the subject of the message.
The current message is indicated by an arrow or inverse video.
One nice feature of elm is that it displays the sender's name instead of the login ID, as Berkeley Mail does.
The bottom part of the screen lists the options available. At this point, you can reply to the message, delete or undelete a message, or forward the mail by entering the appropriate command. You can go up and down the message list by using k and j, just as in the vi editor.
Some of the actions available in elm are listed in Table 14.1.
Table 14.1. elm actions.
Command | elm 2.4 Action |
Enter, Spacebar | Displays current message. |
| | Pipes current message or tagged messages to a system command. |
! | Shell escape. |
? | This screen of information. |
= | Sets current message to first message. |
* | Sets current message to last message. |
<NUMBER>, Enter | Sets current message to <NUMBER>. |
/ | Searches From/Subjects for pattern. |
// | Searches entire message texts for pattern. |
> | Saves current message or tagged messages to a folder. |
< | Scans current message for calendar entries. |
C | Copies current message or tagged messages. |
c | Changes to another folder. |
d | Deletes current message. |
Ctrl-D | Deletes messages with a specified pattern. |
e | Edits current folder. |
f | Forwards current message. |
g | Groups (all recipients') reply to current message. |
h | Headers displayed with message. |
J | Increments current message by one. |
j, <DOWN> | Advances to next undeleted message. |
K | Decrements current message by one. |
k, <UP> | Advances to previous undeleted message. |
l | Limits messages by specified criteria. |
Ctrl-L | Redraws screen. |
m | Mails a message. |
n | Next message, displaying current, then increment. |
p | Prints current message or tagged messages. |
q | Quits, maybe prompting for deleting, storing, and keeping messages. |
Let's try to send mail using elm.
To send mail, press m on the main screen. The header screen appears. elm prompts you to enter the name(s) of the recipient(s) of the mail. Enter calvin and root as recipients. Calvin is the primary recipient, and a copy of this message is sent to root as well.
elm then prompts for a subject. After entering the subject heading, elm puts you in the vi editor to enter the body of the mail message. After you are finished typing, use the vi command :wq to save and quit the vi editor. You can now send the message by pressing s.
You can also forward mail to others on the system with the f command or reply to a message with the r command.
To quit elm, type q at the main screen.
If elm is available on your system, try to use it. elm is very convenient and simple and can greatly improve your electronic mail interaction. Using Pine Pine, a trademark of the University of Washington, stands for Program for Internet News and E-mail. Pine offers the capability to send local and remote messages using a simple user interface, as well as the capability to send documents and graphics.
You invoke Pine by entering pine on the command line. The screen shown in Listing 14.2 should appear.
$ pine PINE 3.95 MAIN MENU Folder: INBOX 1 Message ? HELP - Get help using Pine C COMPOSE MESSAGE - Compose and send a message I FOLDER INDEX - View messages in current folder L FOLDER LIST - Select a folder to view A ADDRESS BOOK - Update address book S SETUP - Configure or update Pine Q QUIT - Exit the Pine program Copyright 1989-1996. PINE is a trademark of the University of Washington. [Folder "INBOX" opened with 1 message] ? Help P PrevCmd R RelNotes
O OTHER CMDS L [ListFldrs] N NextCmd K KBLock
Pine is very easy to use, because it provides a full-screen interface with the up and down cursor controls. Simply select the item you want by using the arrow keys and press Enter at the selected line.
Let's send a message using Pine. Take the cursor to the Compose Message line and press Enter. The screen shown in Listing 14.3 appears.
PINE 3.95 COMPOSE MESSAGE Folder: INBOX 1 Message To : "Laurel N. Hardy" <laurel@hobbes.com> Cc : Attchmnt: Subject : using pine ---- Message Text ---- Hi, I can do everything on one screen . Send message? [y] : ^G Get Help ^X Send ^R Rich Hdr ^Y PrvPg/Top ^K Cut Line ^O Postpone
^C Cancel ^D Del Char ^J Attach ^V NxtPg/End ^U UnDel Line ^T To AddrBk
Pine takes you line-by-line through the mail header and the mail message. Press Ctrl-X to end the message, as well as send it to the recipient. Just walk through all the options to get a feel for this mail system.
The last two lines on the screen tell you what commands are available for the current situation. Usually there are more commands than can be shown on two lines, so use the O key to see what other commands are available. The O is optional; you don't have to be able to see a command before you use it.
Pine creates a default configuration file, .pinerc, in your home directory. You can edit this file to select various options. Pine also creates a mail subdirectory for your saved-message folders. Type ? from the Main Menu for more help. Using mailx (Berkeley Mail) This section is about mailx, another common mail program for Linux. This section covers the basics of mailx. mailx has many options and features, most of which are listed in its man pages. Discussing all these features would require a book in itself.
Let's see how to receive and send mail using mailx. Receiving Mail Suppose someone has sent you a mail message. How would you know about it? The Mail system deals with this by displaying a message when you log in. A sample login session is shown in Listing 14.4.
Welcome to Linux 2.0.0. mpsi login: laurel Last login: Fri Jan 6 13:28:06 on tty1 Linux 2.0.0.
You have new mail.
To read the mail message, invoke the Mail handler by typing mail at the prompt. You will see the output shown in Listing 14.5.
mpsi:~$ mail Mail version 5.5 6/1/90. Type ? for help. "/var/spool/mail/calvin": 1 message 1 new >N 1 laurel@hobbes.com Fri Jan 6 13:38 12/374 "just checking" & 1 Message 1: From laurel@hobbes.com Fri Jan 6 13:38:06 1995 Date: Fri, 6 Jan 1995 13:38:06 -0600 From: "Laurel N. Hardy" <laurel@hobbes.com> To: calvin@hobbes.com Subject: just checking the body of the message bye & exit
You have mail in /var/spool/mail/calvin
In this example, the user Calvin has received a mail message from another user, Laurel. This message is the first message in the message queue and is declared as new, which means it has not been read yet. The message queue has an >N, indicating that it is a new message, followed by a message number (1), the sender's login ID (laurel@hobbes.com), the day of the week, the date and time the message was sent, and the subject of the message.
The ampersand (&) is the mail system prompt. You can now read the message by typing the message number at this prompt.
& 1 Message 1: From laurel@hobbes.com Fri Jan 6 13:38:06 1995 Date: Fri, 6 Jan 1995 13:38:06 -0600 From: "Laurel N. Hardy" <laurel@hobbes.com> To: calvin@hobbes.com Subject: just checking the body of the message bye &
Mail Options All the available options in the Mail system can be listed by typing a ? after the &. The listed options are shown in Listing 14.6.
& ? Mail Commands t <message list> type messages n goto and type next message e <message list> edit messages f <message list> give head lines of messages d <message list> delete messages s <message list> file append messages to file u <message list> undelete messages R <message list> reply to message senders r <message list> reply to message senders and all recipients pre <message list> make messages go back to /usr/spool/mail m <user list> mail to specific users q quit, saving unresolved messages in mbox x quit, do not remove system mailbox h print out active message headers ! shell escape cd [directory] chdir to directory or home if none given A <message list> consists of integers, ranges of same, or user names separated by spaces. If omitted, Mail uses the last message typed. A <user list> consists of user names or aliases separated by spaces. Aliases are defined in .mailrc in your home directory. &
Replying to a Message Suppose you have three mail messages from different users and you want to reply to the one sent by Jeremy. Just invoke mail as before, as shown in Listing 14.7.
mpsi:~$ mail Mail version 5.5 6/1/90. Type ? for help. "/var/spool/mail/laurel": 3 messages 3 unread >U 1 calvin@hobbes.com Fri Jan 6 13:27 12/429 "Format for a mail hea" U 2 jeremy@hobbes.com Sat Jan 7 15:25 72/23291 " Please reply soon" U 3 calvin@hobbes.com Wed Jan 11 12:29 12/373 "message # 3"
The U in front of the second message specifies that the message is still unread. You can read the message by typing the message number.
& 2 Message 2: From jeremy@hobbes.com Sat Jan 7 15:25:00 1995 Date: Sat, 7 Jan 1995 15:25:00 -0600 From: "friend22" <jeremy@hobbes.com> To: laurel@hobbes.com Subject: Please reply soon What's up?
You can reply to the message by typing r.
& r To: jeremy@hobbes.com Subject: Re: Please reply soon Replying to your mail message # 2 I am too busy to reply to you now. Go away. . EOT
The Mail daemon automatically sets up the header in the reply mode, so all you have to do is type the text. Sending and Forwarding Mail Sending and forwarding mail can be done with the s and f commands, respectively. The procedures for creating the header and text of the message are similar to that of replying to a message.
The ~/signature file is appended to every mail message you send. You should place text in here that you want to send with every message. Some examples are your phone number or an alternative e-mail address (your recipient might not be able to reply to certain hosts). Mail etiquette requires that you keep you signature files short--four lines or less. Most recipients do not like to see pages of information about you in every mail message.
Using news is perhaps the best way of getting into what is probably the world's best online forum: the Usenet news service. There are literally thousands of giant bulletin boards for you to select topics from and post messages to. The number of subjects available can be quite overwhelming at times, since there are more than 13,000 newsgroup topics to choose from. (A newsgroup is one of the bulletin boards.) Newsgroups offer the best example of free speech and a forum for discussing just about any topic imaginable.
Topics range from the serious to the absurd. In the serious category you can talk about computer communications (comp.dcom.telecom), astronomy (sci.astro), and so forth. In the absurd corner you have such choices as alt.tasteless, alt.barney.dinosaur.die.die.die, and alt.fan.oj-simpson.drive.faster.
Usenet was started at Duke University in 1979 by two students, Tom Truscott and Jim Ellis, as an experiment to connect two computers between Duke and the University of North Carolina. From these two news sites in 1980, the number of news sites has grown to hundreds of thousands of sites in the 1990s, with millions of subscribers worldwide.
There are several news readers for Linux. I will cover two: nn and tin.
The nn news reader stands for Net News. When you use nn, you decide which of the many news groups you are interested in. You unsubscribe those that do not interest you any more. nn lets you read all articles in each of the groups you subscribe to, using a menu-based article selection prior to reading the articles in the news group.
When you enter a newsgroup in nn, you are presented with a screen that lists the most recent unread articles. Each item on this list contains at least the sender and subject. You are now in selection mode. You can select using the A through Z and 0 through 9 keys. When you select an article, it is displayed in a highlight color. If you press the spacebar, you go into read mode.
In read mode, nn presents you with each article. Press the spacebar to get to the next page of each article. If you are at the end of an article, the spacebar takes you to the next article.
When you have read all the selected articles in the current group, pressing the spacebar takes you to the next group.
Here are some of the other commands in nn:
The nn man pages provide about 600 lines of very detailed information about all the options and commands available to you. You do not have to use all of them--just use as many as necessary to customize your own environment.
tin is a screen-oriented Net News reader. It can read news locally (/usr/spool/news) or remotely (rtin or tin -r option) via an NNTP (Network News Transport Protocol) server. tin is based on the tass newsreader, which was developed by Rich Skrenta in March 1991. tass was itself heavily influenced by NOTES, which was developed at the University of Illinois by Ray Essick and Rob Kolstad in 1982. The most relevant author to date is Iain Lea (iain.lea@erlm.siemens.de). Check the long list of contributors in the man pages.
On startup, tin shows a list of the newsgroups found in $HOME/.newsrc. An arrow (->) or highlighted bar points to the first newsgroup. Move to a group by using the terminal arrow keys or j and k. Use Page Up and Page Down or Ctrl-U and Ctrl-D to page up and down. Select a newsgroup to read from by pressing Enter.
The Tab key advances to the next newsgroup that has unread articles and enters it.
To start and run tin, export NNTPSERVER to the address of your remote news server. Use the command
$ export NNTPSERVER=news.your.provider.com
Then run tin with the -r option to connect to this remote server.
A sample tin session is shown in Listing 14.8. It shows two newsgroups that I have subscribed to: alt.humor and tx.jobs.
When you select a message to read from and press either the right arrow or Enter key, you are shown the message itself, as shown in Listing 14.9.
Group Selection (news.neosoft.com 2) h=help 1 571 alt.humor u 2 398 tx.jobs <n>=set current to n, TAB=next unread, /=search pattern, c)atchup, g)oto, j=line down, k=line up, h)elp, m)ove, q)uit, r=toggle all/unread, s)ubscribe, S)ub pattern, u)nsubscribe, U)nsub pattern, y)ank in/out
Group tx.jobs (`q' to quit)...
tx.jobs (368T 401A 0K 0H R) h=help 171 + US-TX-Dallas MicroFocus Cobol Contract Mark Allen 172 + CA-CLARIS HR, WINDOWS DEVELOPMENT POSITIONS A CLARIS HR 173 + CA-CLARIS HR, DIRECTOR OF WORLDWIDE PRODUCT D CLARIS HR 174 + CA-CLARIS HR, INTERNATIONAL WINDOWS ENGINEER CLARIS HR 175 + CA, CLARIS CORP - TELECOMMUNICATIONS ANALYST CLARIS HR 176 + CA- CLARIS HR, SYBASE PROGRAMMER/ANALYST AT C CLARIS HR 177 + CA-CLARIS HR, DOCUMENTATION CONTROL SPECIALIST CLARIS HR 178 + CA-CLARIS, SUPERVISOR, DIRECT ACCOUNT SERVICE CLARIS HR 179 + CA-DEVELOPERS & TEST ENGINEERS - JAPANESE PRO CLARIS HR 180 + CA-CLARIS HR, DATABASE INTERNALS ENGINEER POS CLARIS HR 181 + CA, CLARIS CORPORATION - PRICING ANALYST CLARIS HR 182 + WA-CLARIS HR, MAC & WINDOWS DEV'RS/ INTERFACE CLARIS HR 183 + USA-TX-DALLAS - Informix 4GL/ESQL imi 184 + USA-TX-DALLAS - SONET Telephany Engineers imi 185 + USA-TX-DALLAS - PowerBuilder imi 186 + USA-TX-DALLAS - Oracle DBAs imi 187 + USA-TX-DALLAS - CICS, Cobol, JCL, VSAM (ALC + imi <n>=set current to n, TAB=next unread, /=search pattern, ^K)ill/select, a)uthor search, c)atchup, j=line down, k=line up, K=mark read, l)ist thread,
|=pipe, m)ail, o=print, q)uit, r=toggle all/unread, s)ave, t)ag, w=post
In Listing 14.9, you see a list of subject headers and their index numbers. The
+ sign indicates that you have not read this message. For example, the SONET job
for Dallas, Texas, has an index of 184 and is unread. To read this message, use the
arrow keys to move to it, and then press Enter. Command-Line Options tin
has several command-line options, some of which are listed in Table 14.2.
Table 14.2. tin's command-line options.
Option | Description |
-c | Creates or updates index files for every group in $HOME/.newsrc or every file specified by the -f option and marks all articles as read. |
-f file | Uses the specified file of subscribed newsgroups instead of |
|
$HOME/.newsrc. |
-h | A help listing of all command-line options. |
-m dir | The mailbox directory to use. The default is $HOME/Mail. |
-n | Loads only groups from the active file that are also subscribed to in the user's .newsrc. This enables a noticeable speedup when connecting via a slow line. |
-p program | Prints program with options. |
-q quick | Starts without checking for new newsgroups. |
-r read | News specified in the environment variable NNTPSERVER or contained in the file /etc/nntpserver. |
-R read | News saved by -S option (not yet implemented remotely from the default NNTP server). |
-s dir | Saves articles to a directory. The default is $HOME/News. |
-v | Verbose mode for the -c, -M, -S, -u, and -Z options. |
To add a new group, type ggroupname. For example, gmisc.invest adds the newsgroup misc.invest.
tin offers an emacs-style editing facility for entering messages. The command strings include a history of commands to enable reuse of previous commands. The man pages for tin list all the commands available to you for editing, deleting, and removing messages.
tin uses the following important environment variables:
NNTPSERVER | The default NNTP server to remotely read news from. This variable needs to be set only if the -r command-line option is specified and the file /etc/nntpserver does not exist. |
|
|
File transfer protocol (FTP) is a method of transferring files from one computer to another. FTP provides the capability of transferring files to and from a remote network site as well as means for sharing public files. In this section you go through a sample FTP session and follow the steps for finding and getting software from a remote site.
ftp is the user interface to the ARPANET standard FTP. The ftp service is the interface to the file transfer protocol. It lets a user connect to another site and send and receive files.
In this section you will try to get a file from the address tsx-11.mit.edu by logging in as anonymous. This anonymous use of FTP is very convenient and provides access to innumerable servers, providing a wealth of information. Publicly accessible FTP servers are called anonymous FTP servers.
Anonymous FTP enables users to access remote sites without having an authorized user ID and password. Generally the login ID is anonymous and the password is guest. Most current systems require your e-mail address as the password instead of guest.
The client host with which ftp is to communicate may be specified on the command line. If this is done, ftp immediately attempts to establish a connection to an FTP server on that host. Otherwise, ftp enters its command interpreter and awaits instructions from the user. When ftp is awaiting commands from the user, the prompt ftp> is provided to the user. Enter ftp at the prompt, along with the site address:
$ ftp hostname
A hostname can be either a hostname or an Internet address. For example, you can use the following Internet address:
mpsi$ ftp tsx-11.mit.edu
If your system connects to the MIT server, the text shown in Listing 14.10 appears.
220 tsx-11 FTP server (Version wu-2.4(3) Mon Jun 5 16:40:22 EDT 1995) ready. Name (tsx-11.mit.edu:uzma): anonymous 331 Guest login ok, send your complete e-mail address as password. Password: 230-Welcome, archive user! This is an experimental FTP server. If you have any 230-unusual problems, please report them via e-mail to ftp-bugs@tsx-11.mit.edu. 230-If you do have problems, please try using a dash (-) as the first character 230-of your password -- this will turn off the continuation messages that may 230-be confusing your ftp client. 230- 230-The Linux archives are in /pub/linux/ 230- 230-In most places, `get <directory>.tar' will retrieve a tar file containing 230-that directory. `get <file>.gz' gets a gzipped version of the files, and 230-`get <file>.Z' gets a compressed version of the file. `get <dir>.tar.gz' 230-is possible, but not recommended. `get <dir>.zip' will get a zip archive 230-with *NO* compression of the directory <dir>. 230- 230-If you find something on TSX-11 which doesn't work, or which you 230-believe is obsolete, please send mail to ftp-linux@TSX-11.MIT.EDU. 230-INCLUDE THE FULL PATHNAME OF THE FILE AND WHY YOU THINK IT IS OBSOLETE. 230- 230- - Ted and Michael 230- 230 Guest login ok, access restrictions apply. Remote system type is UNIX. Using binary mode to transfer files. ftp>
The first line confirms that the connection is established. Line 220 indicates
that the FTP server is ready. The system then prompts for a name, which is anonymous
in this case, and a password. The password is not echoed, so any typing mistakes
you make are not apparent. You are then connected to the remote FTP server, which
awaits your commands. ftp Commands The ftp service enables the user to execute
several commands. Some of the local commands are listed in Table 14.3.
Table 14.3. Some ftp commands.
Command | Description |
[account [passwd]] | Provides a supplemental password required by a remote system for access to resources once a login has been successfully completed. If no argument is included, the user is prompted for an account password in a non-echoing input mode. |
ascii | Sets the file transfer type to network ASCII. This is the default type. |
bell | Sounds a bell after each file transfer. |
binary | Sets the file transfer type to binary mode. |
bye | Terminates the FTP session with the remote server and then exits. |
cd remote-directory | Changes the working directory on the remote machine to the remote directory. |
cdup | Goes to the parent of the current remote machine's working directory. |
chmod mode file-name | Changes the permission modes of the file. |
close | Terminates the FTP session with the remote server. |
delete remote-file | Deletes the remote file on the remote machine. |
dir [remote-directory] | Prints a listing of the remote directory to the terminal. |
disconnect | Same as close. |
get remote-file | Retrieves the remote file and stores it on the local ma- |
[local-file] | chine. If the local filename is not specified, it is given the same name it |
|
has on the remote machine. |
hash | While a file is being transferred, the hash sign (#) is printed for each data block transferred. |
help [command] | Prints an informative message about the meaning of the command. If no argument is given, ftp prints a list of the known commands. |
lcd [directory] | Changes the working directory on the local machine. If no directory is specified, the user's home directory is used. |
ls [remote-directory] | Lists the contents of the remote directory. |
mdelete [remote-files] | Deletes the remote files on the remote machine. |
mdir remote-files | Like dir, except multiple remote files may be specified. |
mget remote-files | Expands the remote files on the remote machine and does a getfiles based on regular expressions. For example, mget f*.tar will get all the files starting with the letter f. |
open host [port] | Establishes a connection to the specified host FTP server on the optional port number. |
put local-file | Stores a local file on the remote machine. |
pwd | Prints the name of the current working directory on the remote machine. |
quit | Same as bye. |
remotehelp [command-name] | Requests help from the remote FTP server. If a command name is specified, it is supplied to the server as well. |
reset | Resets the communications connection. |
rmdir directory-name | Deletes a directory on the remote machine. |
size file-name | Returns the size of the file on the remote machine. |
status | Shows the current status of ftp. |
verbose | Displays all responses to the user. |
? [command] | Same as help. |
-v | The verbose option. Gives a report on the transfer statistics and forces ftp
to show all responses from the remote server. |
-n | Restrains ftp from attempting auto-login upon initial connection. In auto-login, ftp checks for |
|
the user's account on the remote machine. |
-I | Turns off interactive prompting during multiple file transfers. |
-d |
Enables debugging. |
ftp> ftp> ls 200 PORT command successful. 150 Opening ASCII mode data connection for /bin/ls. total 6 drwxrwxr-x 2 root ftp-linu 512 Feb 8 1995 bin drwxrwxr-x 2 root wheel 512 Nov 5 1994 dev drwxrwxr-x 3 root wheel 512 Nov 9 17:22 etc lrwxr-xr-x 1 tytso wheel 1 Nov 5 02:17 ftp -> . drwxrwx-wx 4 tytso ftp-linu 512 Dec 8 07:44 incoming drwxrwxr-x 9 tytso ftp 512 Dec 1 22:35 pub 226 Transfer complete. ftp>
As you can see, you did not have to type -al. You get the long listing from the ls command.
To abort a file transfer, use the terminal interrupt key (usually Ctrl-C). Sending transfers are immediately halted. Receiving transfers are halted by sending an ftp ABOR command to the remote server and discarding any further data received.
The ftp specification specifies many parameters that may affect a file transfer. The type may be ascii, image (binary), or ebcdic.
The telnet command is used to communicate with another host using the TELNET protocol. If telnet is invoked without the host argument, it enters command mode, indicated by its prompt, telnet>. Normally you would use
$ telnet hostname [port]
where hostname is the host you want to connect to and port indicates a port number (an application's address). If a number is not specified, the default telnet port is used.
telnet can log you in either one of two modes: character-by-character or line-by-line. In character-by-character mode, most text typed is immediately sent to the remote host for processing. In line-by-line mode, all text is echoed locally, and only completed lines are sent to the remote host.
While connected to a remote host, you can enter the telnet command mode by typing the telnet escape character, Ctrl-]. When in command mode, the normal terminal editing conventions are available.
The following commands are available under the command mode:
close | Closes a telnet session and returns to command mode. |
open host | Opens a connection to the named host. If no port |
[[-l] user][-port] | number is specified, telnet attempts to use the default |
|
port. The [-l] option may be used to specify the user name. |
quit |
Closes any open telnet session and exits telnet. An end-of-file
(in command mode) will also close a session and exit. |
|
Let's use telnet to do an Archie session. An Archie server is helpful for searching for files by giving a keyword in a title. See Listing 14.11.
$ telnet archie.internic.net . . . SunOS UNIX 4.1 (ds) (ttypa) login: archie ******************************************************************** Welcome to the InterNIC Directory and Database Server. ******************************************************************************** # Bunyip Information Systems, 1993, 1994 # Terminal type set to `vt100 24 80' # `erase' character is `^?'. # `search' (type string) has the value `sub'. archie>
The archie> prompt is asking you for input. Let's look at some of the help information available for Archie. Type help at the archie> prompt. See Listing 14.12 for a sample output.
archie >help These are the commands you can use in help: . go up one level in the hierarchy ? display a list of valid subtopics at the current level <newline> done, ^D, ^C quit from help entirely <string> help on a topic or subtopic Eg. "help show" will give you the help screen for the "show" command "help set search" Will give you the help information for the "search" variable. The command "manpage" will give you a complete copy of the archie manual page. ~ ~ (END)
Now let's try to find a file on HylaFAX. Use the command find, as shown in Listing 14.13. The sub string indicates that you are searching for the word in the entire filename and are not looking for an exact match.
archie> find hylafax # Search type: sub. # Your queue position: 1 # Estimated time for completion: 00:33 working... \
The results of the match are shown in Listing 14.14. You can scroll up and down with the k and j keys. The spacebar scrolls one page. The Enter key scrolls down one line at a time. You can stop the listing with the q key.
Host freebsd.cdrom.com (192.153.46.2) Last updated 11:06 30 Jan 1994 Location: /.1/FreeBSD/FreeBSD-current/ports DIRECTORY drwxr-xr-x 1024 bytes 01:17 4 Dec 1993 flexfax Location: /.1/FreeBSD/FreeBSD-current/ports/hylafax/man FILE -rw-rw-r-- 15254 bytes 15:45 31 Aug 1993 flexfax.1 Location: /.1/FreeBSD/FreeBSD-current/ports/hylafax/dist FILE -rw-rw-r-- 17 bytes 15:40 31 Aug 1993 flexfax.alpha FILE -rw-rw-r-- 2671 bytes 15:40 31 Aug 1993 flexfax.spec Location: /.1/FreeBSD/FreeBSD-current/ports/hylafax/port/386bsd FILE -rw-rw-r-- 2828 bytes 15:45 31 Aug 1993 Makefile.flexfax Location: /.1/FreeBSD/FreeBSD-current/ports/hylafax/port/4.4bsd FILE -rw-rw-r-- 2839 bytes 15:45 31 Aug 1993 Makefile.flexfax Location: /.1/FreeBSD/FreeBSD-current/ports/hylafax/port/bsdi FILE -rw-rw-r-- 2837 bytes 15:46 31 Aug 1993 Makefile.flexfax db/tmp/AAAa26919
After you are finished with Archie, you can log off the server. This closes the telnet connection. You can get your HylaFAX files via FTP from these sites.
The communication tools discussed in this chapter were write, talk, mesg, and mail. You also learned about nn and tin for reading news from the Internet. For getting files from remote sites, you learned how to use FTP. With the telnet session, you also learned a bit about Archie, an archival search utility.
As you can see, Linux offers a wide variety of communication tools. This chapter has merely introduced you to these tools. You have to work with each tool to learn its intricacies. Happy communicating.