1 .\" Copyright (c) 2002 Andries Brouwer <aeb@cwi.nl>
3 .\" %%%LICENSE_START(VERBATIM)
4 .\" Permission is granted to make and distribute verbatim copies of this
5 .\" manual provided the copyright notice and this permission notice are
6 .\" preserved on all copies.
8 .\" Permission is granted to copy and distribute modified versions of this
9 .\" manual under the conditions for verbatim copying, provided that the
10 .\" entire resulting derived work is distributed under the terms of a
11 .\" permission notice identical to this one.
13 .\" Since the Linux kernel and libraries are constantly changing, this
14 .\" manual page may be incorrect or out-of-date. The author(s) assume no
15 .\" responsibility for errors or omissions, or for damages resulting from
16 .\" the use of the information contained herein. The author(s) may not
17 .\" have taken the same level of care in the production of this manual,
18 .\" which is licensed free of charge, as they might when working
21 .\" Formatted or processed versions of this manual, if unaccompanied by
22 .\" the source, must acknowledge the copyright and authors of this work.
25 .\" 2007-10-23 mtk Added intro paragraph about section, plus a paragraph
26 .\" about exit status values.
28 .TH INTRO 1 2007-11-15 "Linux" "Linux User's Manual"
30 intro \- introduction to user commands
32 Section 1 of the manual describes user commands and tools,
33 for example, file manipulation tools, shells, compilers,
34 web browsers, file and image viewers and editors, and so on.
36 All commands yield a status value on termination.
37 This value can be tested (e.g., in most shells the variable
39 contains the status of the last executed command)
40 to see whether the command completed successfully.
41 A zero exit status is conventionally used to indicate success,
42 and a nonzero status means that the command was unsuccessful.
43 (Details of the exit status can be found in
45 A nonzero exit status can be in the range 1 to 255, and some commands
46 use different nonzero status values to indicate the reason why the
49 Linux is a flavor of UNIX, and as a first approximation
50 all user commands under UNIX work precisely the same under
51 Linux (and FreeBSD and lots of other UNIX-like systems).
53 Under Linux, there are GUIs (graphical user interfaces), where you
54 can point and click and drag, and hopefully get work done without
55 first reading lots of documentation.
56 The traditional UNIX environment
57 is a CLI (command line interface), where you type commands to
58 tell the computer what to do.
59 That is faster and more powerful,
60 but requires finding out what the commands are.
61 Below a bare minimum, to get started.
63 In order to start working, you probably first have to login,
64 that is, give your username and password.
71 (command interpreter) for you.
72 In case of a graphical login, you get a screen with menus or icons
73 and a mouse click will start a shell in a window.
77 One types commands to the
79 the command interpreter.
80 It is not built-in, but is just a program
81 and you can change your shell.
82 Everybody has her own favorite one.
83 The standard one is called
92 A session might go like
96 .RB "knuth login: " aeb
97 .RB "Password: " ********
99 Tue Aug 6 23:50:44 CEST 2002
113 drwxrwxr\-x 2 aeb 1024 Aug 6 23:51 bin
114 \-rw\-rw\-r\-\- 1 aeb 37 Aug 6 23:52 tel
118 .RB "$ " "cp tel tel2"
121 drwxr\-xr\-x 2 aeb 1024 Aug 6 23:51 bin
122 \-rw\-r\-\-r\-\- 1 aeb 37 Aug 6 23:52 tel
123 \-rw\-r\-\-r\-\- 1 aeb 37 Aug 6 23:53 tel2
124 .RB "$ " "mv tel tel1"
127 drwxr\-xr\-x 2 aeb 1024 Aug 6 23:51 bin
128 \-rw\-r\-\-r\-\- 1 aeb 37 Aug 6 23:52 tel1
129 \-rw\-r\-\-r\-\- 1 aeb 37 Aug 6 23:53 tel2
130 .RB "$ " "diff tel1 tel2"
132 .RB "$ " "grep maja tel2"
137 and here typing Control-D ended the session.
140 here was the command prompt\(emit is the shell's way of indicating
141 that it is ready for the next command.
142 The prompt can be customized
143 in lots of ways, and one might include stuff like username,
144 machine name, current directory, time, and so on.
145 An assignment PS1="What next, master? "
146 would change the prompt as indicated.
148 We see that there are commands
150 (that gives date and time), and
152 (that gives a calendar).
156 lists the contents of the current directory\(emit tells you what
160 option it gives a long listing,
161 that includes the owner and size and date of the file, and the
162 permissions people have for reading and/or changing the file.
163 For example, the file "tel" here is 37 bytes long, owned by aeb
164 and the owner can read and write it, others can only read it.
165 Owner and permissions can be changed by the commands
172 will show the contents of a file.
173 (The name is from "concatenate and print": all files given as
174 parameters are concatenated and sent to "standard output", here
175 the terminal screen.)
179 (from "copy") will copy a file.
180 On the other hand, the command
182 (from "move") only renames it.
186 lists the differences between two files.
187 Here there was no output because there were no differences.
191 (from "remove") deletes the file, and be careful! it is gone.
192 No wastepaper basket or anything.
197 (from "g/re/p") finds occurrences of a string in one or more files.
198 Here it finds Maja's telephone number.
199 .SS Pathnames and the current directory
200 Files live in a large tree, the file hierarchy.
203 describing the path from the root of the tree (which is called
206 For example, such a full pathname might be
208 Always using full pathnames would be inconvenient, and the name
209 of a file in the current directory may be abbreviated by giving
210 only the last component.
216 when the current directory is
221 prints the current directory.
225 changes the current directory.
226 Try "cd /" and "pwd" and "cd" and "pwd".
230 makes a new directory.
234 removes a directory if it is empty, and complains otherwise.
238 (with a rather baroque syntax) will find files with given name
240 For example, "find . \-name tel" would find
243 starting in the present directory (which is called
245 And "find / \-name tel" would do the same, but starting at the root
247 Large searches on a multi-GB disk will be time-consuming,
248 and it may be better to use
250 .SS Disks and filesystems
253 will attach the filesystem found on some disk (or floppy, or CDROM or so)
254 to the big filesystem hierarchy.
260 will tell you how much of your disk is still free.
262 On a UNIX system many user and system processes run simultaneously.
263 The one you are talking to runs in the
269 will show you which processes are active and what numbers these
273 allows you to get rid of them.
274 Without option this is a friendly
275 request: please go away.
276 And "kill \-9" followed by the number
277 of the process is an immediate kill.
278 Foreground processes can often be killed by typing Control-C.
279 .SS Getting information
280 There are thousands of commands, each with many options.
281 Traditionally commands are documented on
283 (like this one), so that the command "man kill" will document
284 the use of the command "kill" (and "man man" document the command "man").
287 sends the text through some
291 Hit the space bar to get the next page, hit q to quit.
293 In documentation it is customary to refer to man pages
294 by giving the name and section number, as in
296 Man pages are terse, and allow you to find quickly some forgotten
298 For newcomers an introductory text with more examples
299 and explanations is useful.
301 A lot of GNU/FSF software is provided with info files.
303 for an introduction on the use of the program "info".
305 Special topics are often treated in HOWTOs.
307 .I /usr/share/doc/howto/en
308 and use a browser if you find HTML files there.
310 .\" Actual examples? Separate section for each of cat, cp, ...?
311 .\" gzip, bzip2, tar, rpm