How Linux Works: What Every Super-User Should Know by Brian

October 30, 2017 | Author: Anonymous | Category: N/A
Share Embed


Short Description

List of Sidebars HOWTO, The Book of VMware (No Starch Press), and The Linux Problem Solver (No Starch Press) Overview.&n...

Description

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Back Cover How Linux Works: What Every Super-User Should Know Whether you’re a systems administrator or a home user, you need to understand how Linux internals work before you can really ISBN:1593270356 by Brian Ward master Linux—how it boots, how networking works, how to customize the kernel, and even what hardware to buy. No Starch Press © 2004 (347 pages) How Linux WorksThis contains kind ofthe information normally down from wizards—knowledge that comes from years and of guide the describes inner workings of ahanded Linux system beginning with the file system and boot process experience doingcovering things the hard way. Butsuch instead of seeking the right incantation to make system work, youshell can scripts, read How advanced topics as networking, firewalls, development tools,your device management, and Linux Works to see how to administer Linux and why each particular technique works. This book covers such need-to-know topics sharing printers with Samba. as:

Table of Contents How Linux boots, with coverage of boot loaders and init How Linux Works—What Every Super-User Should Know Chapter 1 networking, - The Basics How interfaces, firewalls, and servers work Chapter 2 - Devices, Disks, Filesystems, and the Kernel How development tools and shared libraries work Chapter 3 - How Linux Boots How kernel manages deviceand drivers, and processes, and how to build a custom kernel Chapter 4 the - Essential System devices, Files, Servers, Utilities Chapter 5 the - Configuring Your Network How Linux printing system works, with sections on cups, filters, and Ghostscript Chapter 6 - Network Services How shell scripts work Chapter 7 - Introduction to Shell Scripts Chapter 8 - Development Tools theory and real-world examples, How Linux Works will show you how to run your system With its combination of background instead your system run From you. Source Code Chapterof9having - Compiling Software Chapter 10 - Maintaining the Kernel

About the Author Chapter 11 - Configuring and Manipulating Peripheral Devices

Chapter 12 has - Printing Brian Ward been working with Linux since 1993, when he scraped together enough pennies for a secondhand 386. He has a Ph.D. in computer science from the University of Chicago and currently lives in San Francisco. He is the author of the Linux Kernel Chapter 13 - Backups HOWTO, The Book of VMware (No Starch Press), and The Linux Problem Solver (No Starch Press). Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know How Linux Works—What Every Super-User Should by Brian Ward Starch Press Know No This guide describes the inner workings of a Linux system beginning with the file system and boot process and

ISBN:1593270356

© 2004 (347 pages)

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and by Brian Ward sharing printers with Samba.

Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 - How PRESS Linux Boots NO STARCH Chapter 4 - Essential System Files, Servers, and Utilities San Francisco Chapter 5

- Configuring Your Network

Copyright © 2004Services by Brian Chapter 6 - Network

Ward.

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

All rights-reserved. No part of this work may be reproduced or transmitted in any form or by any means, Compiling Software From Source Code electronic or mechanical, including photocopying, recording, or by any information storage or retrieval Chapter 10 - Maintaining the Kernel system, without the prior written permission of the copyright owner and the publisher. Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 9

Chapter 12 - Printing Chapter 13 - Backups Printed on recycled

paper in the United States of America

Chapter 14 - Sharing Files with Samba

1 2 3 4155-6Network 7 8 9 10 07 06 05 Chapter File- Transfer

04

Chapter 16 - User Environments

No Starch PressHardware and the for NoLinux Starch Chapter 17 - Buying

Press logo are registered trademarks of No Starch Press, Inc. Linux is a registered trademark of Linus Torvalds. Other product and company names mentioned herein may be Chapter 18 - Further Directions the trademarks of their respective owners. Rather than use a trademark symbol with every occurrence of a Appendix A - Command Classification trademarked name, we are using the names only in an editorial fashion and to the benefit of the trademark Bibliography owner, with no intention of infringement of the trademark. Index List of Figures

Publisher: William Pollock

List of Tables

List of Sidebars

Managing Editor: Karol Jurado Cover and Interior Design: Octopod Studios Technical Reviewer: Scott Schwartz Copyeditor: Andy Carroll Compositor: Wedobooks Proofreader: Stephanie Provines Indexer: Brian Ward For information on book distributors or translations, please contact No Starch Press, Inc. directly: No Starch Press, Inc. 555 De Haro Street, Suite 250, San Francisco, CA 94107 phone: 415-863-9900; fax: 415-863-9950; http://www.nostarch.com

The information in this book is distributed on an "As Is" basis, without warranty. While every precaution has been taken in the preparation of this work, neither the author nor No Starch Press, Inc. shall have any liability to any person or entity with respect to any loss or damage caused or alleged to be caused directly or indirectly by the information contained in it. Library of Congress Cataloguing-in-Publication Data

Ward, Brian. How Linux works : what every super-user should know / Brian Ward. p. cm. Includes index.

ISBN 1-59327-035-6 1. Linux. 2. Operating (Computers). I. Title. Should Know How Linuxsystems Works: What Every Super-User by Brian Ward

ISBN:1593270356

QA76.76.O63 W3654 2004 No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

005.4'32--dc22 covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

2004002692 Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 1: The Basics by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

This chapter is a guide to the Unix commands and utilities that you must know to get anything out of this book. This is preliminary material, and you may already know a substantial amount. Even if you think Table of Contents you're up to speed, though, take a few seconds to flip through the sections just to make sure. How Linux Works—What Every Super-User Should Know Chapter 1

The Basics You may- be asking yourself, "I thought this was a book about Linux, not Unix?" Don't worry; this chapter is - Devices, Disks, Filesystems, and the Kernel just getting you ready for working with the Linux system. Linux is a Unix flavor at heart. You will see the Chapter 3 - How Linux Boots word "Unix" in this chapter more than "Linux" because you can take the information straight over to Chapter 4 - Essential System Files, Servers, and Utilities Solaris, BSD, and other Unix-flavored systems. Special care has been taken to avoid too many LinuxChapter 5 - Configuring Your Network specific user interface extensions, not only so you will have a better background with other operating Chapter 6 - Network Services systems, but also because these extensions tend to be extremely unstable. You will be able to adapt to Chapter 7 - Introduction to Shell Scripts new Linux releases much more quickly if you know the core that does not change. Chapter 2

Chapter 8

- Development Tools

Chapter 9 - the Compiling Software Although material here From may Source seem Code sparse,

you need to convince yourself that Unix is not hard. Yes, to the contrary, but in the end, Unix is nothing but a bunch of files and a few Chapter 11 - Configuring and Manipulating Peripheral Devices commands for manipulating those files. If you are familiar with other operating systems, you shouldn't Chapter - Printing However, if you find the information in this preliminary chapter somewhat lacking, there have a12problem. Chapter 13 - Backups are books with much more detail for beginners, such as UNIX for the Impatient [Abrahams] and Learning Chapter 14 - Operating Sharing FilesSystem with Samba the UNIX [Peek]. Chapter 10 - Maintaining the Kernel most reports from the field are

Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.1 About /bin/sh by Brian Ward

ISBN:1593270356

Press © 2004 (347 pages) The shell is No oneStarch of the most important parts of a Unix system. A shell is a program that runs commands. This guide describes theduties inner workings a Linux system beginning withtype. the file system andserve boot process and For example, one of the shell's is to runofthe commands that users Shells also as small covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and programming environments. Unix programmers often break common tasks into little components and rely sharing printers with Samba. on the shell to manage tasks and to piece things together. Table of Contents

Many important parts of the system are actually shell scripts — text files that contain nothing but shell shell scripts may seem similar to .BAT files, but the shell is Chapter 1 - The Basics far more powerful. Chapter 7 is a small guide to shell scripts, and you can peruse it anytime after finishing Chapter 2 - Devices, Disks, Filesystems, and the Kernel this chapter. How Linux Works—What Everyworked Super-User Know commands. If you have withShould MS-DOS,

Chapter 3

- How Linux Boots

Chapter As you4

- Essentialthrough System Files, Servers, and Utilities progress this book, you will learn how to manipulate commands with the shell. One of the Chapter 5 Configuring Your Network best things about the shell is that if you make a mistake, you can look at what you typed, see what went Chapter - Network Services wrong,6 and then try again quickly. Do not be afraid to try new things. The only way to learn the shell is to Chapter use it.7 - Introduction to Shell Scripts Chapter 8

- Development Tools

There9are- Compiling many different all Chapter SoftwareUnix Fromshells, Sourcebut Code /bin/sh. Every Unix Chapter 10 - Maintaining thesystem Kernel

derive many of their features from the Bourne shell, or needs the Bourne shell to function correctly, as you will see throughout this

book. 11 - Configuring and Manipulating Peripheral Devices Chapter Chapter 12 - Printing

Linux 13 uses an enhanced Chapter - Backups

version of this shell, called bash, or the "Bourne-again" shell. bash is the default and /bin/sh is normally some sort of link to bash on a Linux system. You should use the bash shell when running the examples in this book. Chapter 15 - Network File Transfer shell for Linux Chapter 14 most - Sharing Filesdistributions, with Samba Chapter 16 - User Environments

You may not have bash if you're using this chapter as a guide for a Unix account at an organization where you are not the systems administrator. You can change your shell with chsh or ask your systems Chapter 18 - Further Directions administrator for help. Appendix A - Command Classification Chapter 17 - Buying Hardware for Linux

Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.2 Using the Shell by Brian Ward

ISBN:1593270356

No StarchLinux, Press ©you 2004 set (347 up pages) When you installed a root (superuser) password, and hopefully you also made at least This guide the inner of a Linux system beginning theregular file system and boot process and one more regular userdescribes for yourself. Forworkings this chapter, you should log in with as the user.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

The first thing you need to do after logging in is to bring up a shell window. After starting a shell, its window contains a prompt at the top that usually ends with a dollar sign ($). On Red Hat Linux, the prompt looks Table of Contents like[name@host path]$. If you know Windows, you will find that the shell window looks vaguely similar How Linux Works—What Every Super-User Should Know to the command prompt. Chapter 1

- The Basics

Chapter 2 - You Devices, and the Kernel Note mayDisks, hearFilesystems, the shell window referred

Chapter 5

to as the terminal window. The terminal window is the interface that accepts keystrokes from the windowing system and draws the - characters Essential System Files, Servers, andcan Utilities on the screen. You think of the terminal as a middleman between the shell and - the Configuring Your Network user.

Chapter 6

- Network Services

Chapter 3 Chapter 4

- part How Linux of theBoots user

Chapter 7 - the Introduction to command Shell Scripts and Now type following Chapter 8

press ENTER:

- Development Tools

Chapter 9

- Compiling Software From Source Code cat /etc/passwd

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing The command prints

a couple of lines that start with usernames, and then you get your shell prompt back. text very well, manipulate the font settings to your liking. You're going to be spending Chapter - Sharing Files withwith Samba a good14part of your time this book in the shell, so you should be comfortable with it. Chapter - Backups If you 13 can't read the

Chapter 15 - Network File Transfer

Thecat is a great Chapter 16 command - User Environments

one to start with because it's one of the easiest Unix commands. Its syntax is

Chapter 17 - Buying Hardware for Linux as follows: Chapter 18 - Further Directions Appendix A - Command Classification

catfile1 file2 ...

Bibliography Index List of Figures When you List of Tables additional

run this command, cat prints (and concatenates) the contents of file1,file2, and any files you desire (denoted by ...) and exits.

List of Sidebars

If you do not specify any input files, cat reads from the standard input, which in this case is the keyboard. To see this at work, type cat and press ENTER. Unlike the earlier example, you do not get your shell prompt back because cat is still running. Now type some stuff (it doesn't matter what). After you press ENTER at the end of each line, cat repeats the line you typed. W hen you're sick of this, press CONTROLD on a line by itself to terminate the cat command and return to the shell prompt. Note Do not confuse CONTROL-D and CONTROL-C. CONTROL-D on a line by itself stops the current standard input entry (and often terminates a program). CONTROL-C terminates a program regardless of its input or output. You have now experienced standard input (stdin) and output (stdout), two important components of the Unix shell environment. Standard input is a program's default input source. When you ran cat without any arguments, it didn't give up because there were no arguments; instead, cat switched to standard input instead of going after some files. Here, standard input was the stuff that came from your keyboard. Standard output, on the other hand, is where a program's output goes by default. In this case, that location is the terminal window running the shell. The best feature of standard input and output is that you can easily send them to places other than their defaults, as described in Section 1.14.

Linux Works: What Every Super-User Should Know 1.3 BasicHow Commands by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347commands. pages) It's time to learn some other Unix Most of the following programs take multiple arguments, and Thismany guide options describesand the inner workings Linux system listing beginning with be thepointless. file system This and boot and some have so formats that of anaunabridged would is aprocess simplified covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and list; you don't need to know all of the details just yet. sharing printers with Samba.

1.3.1ls

Table of Contents How Linux Works—What Every Super-User Should Know Chapter - The Basics Thels1 command lists

the contents of a directory. The default is the current directory. Use ls -l for a type information (for more on file types and the permissions Chapter How Linuxsee Boots in the 3left- column, Section 1.17). Here is a sample long listing: Chapter 2 (long) - Devices, Disks, Filesystems, the Kernel detailed listing and ls -F toand display file Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network total 3616 - Network Services -rw-r--r-1 juser users 3804 Chapter 7 - Introduction to Shell Scripts -rw-r--r-- 1 juser users 4165 Chapter 8 - Development Tools -rw-r--r-- 1 juser users 131219 Chapter 9 - Compiling Software From Source Code -rw-r--r-- 1 juser users 6255 Chapter 10 - Maintaining the Kernel drwxr-xr-x 2 juser users 4096 Chapter 11 - Configuring and Manipulating Peripheral Devices -rwxr-xr-x 1 juser users 7108 Chapter 12 - Printing -rw-r--r-- 1 juser users 11309 Chapter 13 - Backups -rw-r--r-- 1 juser users 56 Chapter 14 - Sharing Files with Samba drwxr-xr-x 6 juser users 4096 Chapter 15 - Network File Transfer drwxr-xr-x 3 juser users 4096 Chapter 6

Chapter 16 - User Environments

Apr May Oct May Jul Feb Oct Oct Feb May

30 2000 abusive.c 26 1999 battery.zip 26 2000 beav_1.40-13.tar.gz 30 1999 country.c 17 20:00 cs335 2 2001 dhry 20 1999 dhry.c 6 1999 doit 20 13:51 dw 2 2000 hough-stuff

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

1.3.2cp

Appendix A - Command Classification Bibliography

In the Index

first form shown below, cp copies the contents of file1 to file2. In the second form, it copies all dir directory:

List of Figures files to the List of Tables

List of Sidebars

cpfile1 file2 cpfile1 ... fileN dir

1.3.3mv In the first form below, mv renames file1 to file2. In the second form, it moves all files to the dir directory: mvfile1 file2 mvfile1 ... fileN dir

1.3.4touch Thetouch command creates a file. If the file already exists, touch does not change it, but it does update the timestamp you see with the long listing that you get with the ls -l command. touchfile

1.3.5rm To delete (remove) a file, use rm. After you remove a file, it's gone. Do not expect to be able to "undelete" anything. rmfile

1.3.6echo

How Linux Works: What Every Super-User Should Know

by Brian Ward Theecho command prints its arguments to the standard output:

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

echo Hello there. covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Theofecho command Table Contents

is very useful for finding expansions of shell wildcards and variables that you will

encounter later in this chapter. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.4 Using Directory Commands by Brian Ward

ISBN:1593270356

No Starch hierarchy Press © 2004that (347 pages) Unix has a directory starts at /, sometimes called the root. The directory separator is the describes theThere inner workings of a Linux system beginning with in thethe file root system and boot such process slash (/),notThis theguide backslash (\). are several standard subdirectories directory, asand advanced topics such as networking, firewalls, development tools, device management, shell scripts, and /usr (you'll covering learn all about them in Section 2.1 ). sharing printers with Samba.

A directory specification is called a path, and one that starts at the root (such as /usr/lib) is a full or a filename with a full path in front (such as /usr/lib/libc.a) is a full How Linux Works—What Every Super-User Should Know pathname.

Table of Contents absolute path. Similarly, Chapter 1

- The Basics

Chapter 2 - component Devices, Disks, Filesystems, Kernel The path identified by and two the dots (..)

specifies the parent of your shell's current directory, and directory. For example, if the current working directory of your shell is Chapter 4 - Essential System Files, refers Servers,toand Utilities /usr/lib, the path ../bin /usr/bin. A path beginning with .. or . is called a relative Chapter 5 Configuring Your Network pathname. Chapter 3 (.) - How Linux Boots one dot specifies the current

Chapter 6

- Network Services

The following sections the Chapter 7 - Introduction to describe Shell Scripts Chapter 8

essential directory commands.

- Development Tools

Chapter 9

- Compiling Software From Source Code 1.4.1cd

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Thecd command changes the shell's current working directory to dir:

Chapter 12 - Printing

Chapter 13 - Backups

cddir14 - Sharing Files with Samba Chapter Chapter 15 - Network File Transfer Chapter 16 - User Environments

If you 17 omit dir, Hardware the shell for returns Chapter - Buying Linux

to your home directory.

Chapter 18 - Further Directions Appendix A - Command Classification

1.4.2mkdir

Bibliography Index

Themkdir command creates a new directory, dir:

List of Figures List of Tables

mkdir dir List of Sidebars

1.4.3rmdir Thermdir command removes the directory dir: rmdirdir

If dir isn't empty, this command fails. However, if you're impatient, you probably don't want to laboriously delete all the files and subdirectories inside dir first. You can use rm -rf dir to delete a directory and its contents, but be careful. This is one of the few commands that can do serious damage, especially if you run it as the superuser. The -r option specifies recursive delete, and -f forces the delete operation. Don't use the -rf flags with wildcards such as a star (*). Above all, always double-check your command.

1.4.4Shell Wildcards The shell is capable of matching simple patterns with files in the current working directory. The simplest of these is the star character (*), which means match any number of arbitrary characters. For example, the following command prints a list of files in the current directory: echo *

After matching files to wildcards, the shell substitutes the filenames for the wildcard in the command line and then runs the revised command line. Here are some more wildcard examples: at* matches all files starting with at;*at matches files that end with at; and *at* matches any files that contains at. If no files match a wildcard, the shell does no substitution, and the command runs with literal characters such as * (for example, try a command such as echo *dfkdsafh).

If you're used to MS-DOS, you might instinctively type *.* as a wildcard to match all files. Break this habit now. In Linux and other versions of Unix, you must use * to match all files. In the Unix shell, *.* matches only files and directories that contain the Super-User dot (.) character their names. Unix filenames do not need How Linux Works: What Every ShouldinKnow extensions and often do not carry them. ISBN:1593270356 by Brian Ward No Starch Press © 2004 (347 pages)

Another shellThis wildcard character is the question mark (?), instructing the shell to match exactly one guide describes the inner workings of a Linux system beginning with the file system and boot process and arbitrary character. example, boat and development brat. covering For advanced topics b?at such asmatches networking, firewalls, tools, device management, shell scripts, and sharing printers with Samba.

If you do not want the shell to expand a wildcard in a command, enclose the wildcard in single quotes (''). For of example, Table Contentsthe command echo '*' prints a star. You will find this handy in a few of the commands described in the nextEvery section , such Should as grep and find. Quoting is a somewhat tricky matter, so don't get How Linux Works—What Super-User Know too involved it just yet — you'll learn more much later, in Section 7.2 . Chapter 1 - Thewith Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

This isn't-the end to a modern shell's pattern-matching capabilities, but * and ? are what you need to know. How Linux Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.5 Intermediate Commands by Brian Ward

ISBN:1593270356

Nosections Starch Press © 2004 (347 The following describe thepages) most essential intermediate Unix commands beyond the basics that This in guide inner are workings of more a Linuxcommands system beginning with the file system andcheck boot process you saw earlier thisdescribes chapter.theThere many where these come from; out and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and Appendix A sharing for a large list of commands on your system. printers with Samba.

1.5.1grep

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter - The Basics grep 1prints the lines

from a file or input stream that match an expression. For example, if you want to print text root, use this command:

Chapter 2 -inDevices, Disks, Filesystems, Kernel the the lines the /etc/passwd file and thatthe contain Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities grep root /etc/passwd

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7 - command Introduction is to extraordinarily Shell Scripts Thegrep

handy when operating on multiple files at once, because it prints the line when in this multiple-file mode. For example, if you want to check Chapter 9 -file Compiling Software From Source Code on every in /etc that contains root, you could use this command: Chapter 8 -in Development filename addition toTools the matching Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

grep root /etc/*

Chapter 12 - Printing

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

Two of the most important grep options are -i (for case-insensitive matches) and -v (which inverts the search; that is, it prints all lines that don't match). There is also a more powerful variant called egrep.

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter - Buying Hardware for known Linux grep 17 understands patterns

as regular expressions that are grounded in computer science theory utilities. Regular expressions are more powerful than wildcard-style patterns, Appendix A -have Command Classification and they a different syntax. The two most important things to remember about regular expressions Bibliography are these: Chapter 18 ubiquitous - Further Directions and are in Unix

Index

.* to match List of Figures

any number of characters (like the * in wildcards)

List of Tables

. to match List of Sidebars

one arbitrary character

The grep(1) manual page contains a detailed description of regular expressions, but it can be a little difficult to read. To learn more, you can try Mastering Regular Expressions [Friedl], or look at the regular expressions chapter of Programming Perl [Wall]. If you like math and are interested in where these things come from, look up Introduction to Automata Theory, Languages, and Computation [Hopcroft].

1.5.2more and less When a command's output is long, it can scroll off the top of the screen, and it's annoying to use a scrollbar to view such output because you have to move your hands around. You sometimes may also want to look at a large text file without starting a text editor. Two standard commands for text navigation are more and less. To page through a big file like /usr/dict/words, use a command such as more /usr/dict/words. When running more, you will see the contents of the file, one screenful at a time. You can press the space bar to go forward in the file and the b key to skip back one screenful. To quit more, type q. Theless command performs the same function as more, but it is far more powerful and widely used. Use less --help to get a good summary of its operations. As you will learn in Section 1.14, you can send the output of nearly any program directly to another program's input, enabling operations such as this (try it to see what it does): grep ie /usr/dict/words | less

1.5.3pwd This program's name stands for "print working directory," and the command outputs the current working directory. That's all that pwd does, but it's useful. Some Linux distributions set up accounts with the current working directory in the prompt, but you may wish to change that because the current working directory

takes up a lot of space on a line. Linux Works: What Every Super-User Should Know 1.5.4diffHow by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

To see the differences between two text files, use diff:

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and printers with Samba. difffile1sharing file2 Table of Contents

There several options that can control the format How Linuxare Works—What Every Super-User Should Know Chapter The Basics format1 is-often the most

of the output, such as -c, but the default output comprehensible (for human beings, that is).

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

1.5.5file - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

If you see a file and are unsure of its format, try using file to see if the system can guess, based on a - Network Services large set of rules: Chapter 7 - Introduction to Shell Scripts Chapter 6 Chapter 8

- Development Tools

filefile Chapter 9 - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

You may surprised Chapter 12 - be Printing

to see how much this innocent-looking command can do.

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

1.5.6find

Chapter 15 - Network File Transfer Chapter 16 - User Environments

It's frustrating when you know that a certain file is in a directory tree somewhere, and you just don't know where. Run find to find file in dir:

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Appendix A - Command Classification

finddir Bibliography

-name file -print

Index List of Figures

Like most programs in this section, find is capable of some fancy stuff. However, don't try options such as-exec before you know the form shown here by heart, and you know why you need the -name and print options. The find command accepts wildcard characters, such as *, but you must enclose them in single quotes ('*') to protect the wildcard characters from the shell's own wildcard features (recall from Section 1.4.4 that the shell expands wildcards before running commands).

List of Tables

List of Sidebars

1.5.7head and tail To quickly view a portion of a file or stream, use the head and tail commands. For example, head /etc/inittab shows the first ten lines of this system configuration file, and tail /etc/inittab shows the last ten lines. You can change the number of lines to print by using the -n option, where n is the number of lines you want to see. If you want to print lines starting at line n, use tail +n.

1.5.8sort Thesort command quickly puts the lines of a text file in alphanumeric order. If the file's lines start with numbers, and you want to sort in numeric order, use the -n option. The -r option reverses the order of the sort.

How Linux Works:Password What Every Super-User 1.6 Changing Your and Should ShellKnow by Brian Ward

ISBN:1593270356

No Starch Press pages) On large commercial sites,© 2004 it is (347 important to change your password when you first log in. At home, you This guideadescribes the but inneryou workings of aUse Linux system beginning with thetofile system your and boot process and may not even have password, should. the passwd command change password. It covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and asks for yoursharing old password and then prompts you for your new password twice. printers with Samba.

As any other manual will tell you, choose a password that does not include any real words in any language. Don't try to combine words, either. One of the easiest ways to get a good password is to pick a sentence, How Linux Works—What Every Super-User Should Know produce an acronym from it, and then modify the acronym with a number or some punctuation. All you Chapter 1 do - The Basics have to is remember the sentence. For example, Ayht8irt is a modification of the previous sentence.

Table of Contents

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

1.6.1chsh - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

You can shell Chapter 6 -change Networkyour Services

with the chsh command, but keep in mind that this book assumes that you're

running Chapter 7 bash. - Introduction to Shell Scripts Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.7 Dot Files by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 Change to your homePress directory andpages) take a look around with ls, and then run ls -a. At first, you will not This guide describes the inner workings of adot Linux system with the file system boot process and see the configuration files, which are also called files. Dot beginning files are nothing more thanand files and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and directories whose names begin with a dot (.). Common dot files are .bashrc and .login. There are sharing printers with Samba. some dot directories, too, such as .mozilla. Table of Contents

There is nothing special about dot files or directories. Some programs just don't list them by default, so that you don't see a complete mess when listing the contents of your home directory. For example, without Chapter - The Basics the-a1option, ls doesn't list dot files. In addition, shell wildcards don't match dot files unless you explicitly Chapter 2 - Devices, Filesystems, and the Kernel use a pattern suchDisks, as .*. How Linux Works—What Every Super-User Should Know

Chapter 3

- How Linux Boots

Chapter 4 - You Essential and with Utilities canSystem still runFiles, intoServers, problems wildcards Note

Chapter 7

because .* matches . and .. (the current and on what you're doing, you may wish to use a pattern such as - .[^.]* Network Services or .??* to get all dot files except the current and parent directories. This isn't a perfect - solution, Introduction Scripts buttoitShell usually works.

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 5 Chapter 6

- parent Configuring Your Network directories). Depending

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.8 Environment and Shell Variables by Brian Ward

ISBN:1593270356

Nostore Starchtemporary Press © 2004variables, (347 pages) called shell variables, that store the values of text strings. Shell The shell can guide describes the inner track workings of a Linux system and beginning thevariables file system control and bootthe process variables areThis very useful for keeping of state in scripts, somewith shell way and the covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and shell behaves (for example, the PS1 variable controls the prompt). To assign a value to a shell variable, sharing printers with Samba. use the equal sign (=): Table of Contents

STUFF=blah How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

The preceding example sets the value of the variable named STUFF to blah. To access this variable, use - How Linux Boots $STUFF (for example, try running echo $STUFF). Chapter 4 - Essential System Files, Servers, and Utilities Chapter 3 Chapter 5

- Configuring Your Network

Anenvironment variable is like a shell variable, but is not specific to the shell. All programs on Unix - Network Services systems have environment variable storage. The difference that you will notice is that the operating Chapter 7 - Introduction to Shell Scripts system passes all of your shell's environment variables to programs that the shell runs, whereas shell Chapter 8 - Development Tools variables are not accessible by the commands that you run. Some programs use environment variables for Chapter 9 - Compiling Software From Source Code configuration and options. For example, you can put your favorite less command-line options in the LESS Chapter 10 - Maintaining the Kernel environment variable, and less will use these when you run it. Many manual pages contain a section Chapter 11 - Configuring and Manipulating Peripheral Devices marked ENVIRONMENT that describes these variables. Chapter 6

Chapter 12 - Printing

Chapter 13 - Backups

You can assign a new environment variable just as you would a shell variable, except that after creating operation to transfer the variable to the shell's environment Chapter 15 storage. - Network The File Transfer variable following sequence of commands assigns a value to STUFF and changes it into an Chapter 16 - User Environments environment variable: Chapter 14 - Sharing the variable, you Files mustwith runSamba the export

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

STUFF=blah export STUFF

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works:Path What Every Super-User Should Know 1.9 The Command by Brian Ward

ISBN:1593270356

No Starch Press © 2004 variable (347 pages) containing the command path (or path for short). A command path PATH is a special environment This guide describes that the inner workings of ainLinux system beginning with the file system andexample, boot process and is a list of system directories the shell looks when trying to locate a command. For if you advanced topics such as networking, firewalls, development tools, device management, shell scripts, and try to run thecovering ls command, the shell searches the directories listed in PATH for the ls program. If sharing printers with Samba. programs with the same name appear in several directories in the path, the shell runs the first program that matches.

Table of Contents

How Linux Works—What Every you'll Super-User Should If you run echo $PATH, see that theKnow path

components are separated by colons (:). Here's a simple

Chapter 1

example:- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

/usr/local/bin:/usr/X11R6/bin:/usr/bin:/bin - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

To make the shell look in more places for programs, you can change the PATH environment variable. You - Introduction to Shell Scripts can add a directory dir to the beginning of the path so that the shell looks in dir before looking in any of Chapter 8 - Development Tools the other PATH directories with this command: Chapter 7 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

PATH=dir:$PATH Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

As an 14 alternative, youwith canSamba append Chapter - Sharing Files

a directory name to the end of the PATH variable, causing the shell to

look in15dir last: File Transfer Chapter - Network Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux PATH=$PATH:dir Chapter 18 - Further Directions Appendix A - Command Classification Bibliography

Note Exercise caution when modifying the path, because you can accidentally wipe out your entire if you mistype $PATH. Don't panic if this happens, because it isn't permanent (for a lasting List of Tableseffect, you need to mistype it when editing a certain configuration file, and even then it isn't List of Sidebars difficult to rectify). One of the easiest methods to get back to normal is to exit the terminal window that you're using and start another. Index

List of Figurespath

How Linux Works: What Every Super-User Should Know 1.10Special Characters by Brian Ward

ISBN:1593270356

Starchwho Press © 2004 pages)and you have some inexplicable desire to discuss it with them, you If you know No people are into(347 Linux, guide describes inner of a Linux system that beginning the file system boot process and should knowThis a few names for the some ofworkings the special characters you'llwith encounter. If youand are infinitely covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and amused by this sort of thing, look at the Jargon File (http://catb.org/~esr/jargon/html/) or its printed sharing printers with Samba. companion,The New Hacker's Dictionary [Raymond]. Table of Contents

Table 1-1 on the next page lists a select set of the special characters, what they are, what people call them, and their uses. You have already seen many of these characters in this chapter. Not all meanings of Chapter 1 - The Basics each character are identified because there are too many to list. Some utilities, such as the Perl Chapter 2 - Devices, Disks, Filesystems, and the Kernel programming language, use nearly every one of these special characters! Also, keep in mind that these Chapter 3 - How Linux Boots are the American names for the characters. How Linux Works—What Every Super-User Should Know

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Table 1-1: Special Characters

Chapter 7 - Introduction to Shell Scripts Character Name(s) Chapter 8

- Development Tools

* Chapter 9

starSoftware From Source Code - Compiling

Chapter 10 - Maintaining the Kernel

.

dot

Uses Regular expression, wildcard character Current directory, file/hostname delimiter

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing ! bang Chapter 13 - Backups

|

pipe

Negation, command history

Chapter 14 - Sharing Files with Samba

Command pipes

Chapter 15 - Network File Transfer / (forward) slash

Directory delimiter, search command

Chapter 16 - User Environments

\ Chapter 17 - Buyingbackslash Hardware for Linux

Literals, macros (never directories)

Chapter 18 - Further Directions

dollar

Variable denotation, end of line

tick, (single) quote

Literal strings

backtick, backquote

Command substitution

double quote

Semi-literal strings

^

caret

Negation, beginning of line

~

tilde, squiggle

Negation, directory shortcut

#

hash, sharp, pound

Comments, preprocessor, substitutions

[]

(square) brackets

Ranges

{}

(curly) braces

Statement blocks, ranges

_

underscore

Cheap substitute for a space

$

Appendix A - Command Classification

' Bibliography Index

`

List of Figures List" of Tables List of Sidebars

Note You will often see control characters marked with a caret; for example, ^C for CONTROL-C.

How Linux Works: What Every Super-User Should Know 1.11Command-Line Editing by Brian Ward

ISBN:1593270356

Starchwith Pressthe © 2004 (347 you pages) As you play No around shell, may notice that you can edit the command line with the left and This guide describes the inner workings of a Linux system beginning the file system and boot process right arrow keys, as well as page through previous commands with thewith up and down arrows. This is as and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and good as standard on almost any Linux system. sharing printers with Samba.

However, you should forget about the arrow keys and use control key sequences instead. If you learn and practice the ones listed in Table 1-2 , you will have a great advantage when entering text in the many Unix How Linux Works—What Every Super-User Should Know programs that use these standard keystrokes.

Table of Contents Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Table 1-2: Command-Line Keystrokes

Chapter 4 - Essential System Files, Servers, and Utilities Keystroke Action Chapter 5

- Configuring Your Network

CONTROL-B Move Chapter 6 - Network Services

cursor left

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

CONTROL-F

Move cursor right

Chapter 9 - Compiling Software From Source Code CONTROL-P View previous command

(or move cursor up)

Chapter 10 - Maintaining the Kernel

CONTROL-N

View next command (or move cursor down)

Chapter 12 - Printing CONTROL-A

Move the cursor to the beginning of the line

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 13 - Backups

CONTROL-E the cursor Chapter 14 - Sharing FilesMove with Samba

to the end of the line

Chapter 15 - Network File Transfer

CONTROL-W

Erase the preceding word

Chapter 16 - User Environments

CONTROL-U Erase entire Chapter 17 - Buying Hardware forthe Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

line

Linux Works: What Every Super-User Should Know 1.12TextHow Editors by Brian Ward

ISBN:1593270356

Starch it's Press © 2004 pages) Speaking of No editing, time for(347 you to learn an editor. To get serious with Unix, you must be able to edit This guide describes the inner a Linux system beginning withconfiguration the file system files and boot and text files without damaging them. Mostworkings parts ofof the system use plain-text (forprocess example, covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and those in /etc). It's not too difficult to edit files, but you will do it so often that you need a serious, powerful sharing printers with Samba. tool for the job. Table Contents Youofshould make

a serious attempt to learn one of the two de facto standard Unix text editors, vi and choice of editor. Don't listen to them. Instead, choose Chapter 1 - The Basics for yourself. If you choose an editor that matches your personality, you will find it easier to learn. How Linux Works—What Every Super-User Should Knowtheir emacs. Most Unix wizards are religious about Chapter 2

- Devices, Disks, Filesystems, and the Kernel

ChapterIf 3you - How Linux Boots want an editor

that can do almost anything and has extensive online help, and you don't mind try emacs.

Chapterdoing 4 - Essential System Files,to Servers, and Utilities some extra typing get these features, Chapter 5

- Configuring Your Network

means everything ChapterIf 6speed - Network Services Chapter 7

to you, give vi a shot; it "plays" a bit like a video game.

- Introduction to Shell Scripts

Learning vi Editor Tools [Lamb] Chapter 8 -the Development

can tell you everything you need to know about vi. For emacs, use the or a GUI menu, type CONTROL-H, and then type t. If you want book, look GNU Emacs Manual [Stallman]. Chapter 10 - aMaintaining theatKernel online9tutorial: StartSoftware emacsFrom fromSource the shell Chapter - Compiling Codeprompt

Chapter 11 - Configuring and Manipulating Peripheral Devices

You might be tempted to bumble around with a "friendlier" editor, such as pico or one of the myriad GUI editors when you first start out, but if you're the type of person who tends to make a habit out of the first Chapter 13 - Backups thing that you use, you don't want to go down this route. Chapter 14 - Sharing Files with Samba Chapter 12 - Printing

Chapter 15 - Network File Transfer

Incidentally, the editing text is where you will first start to see a difference between the terminal and the GUI. Editors such as vi run inside the terminal window, using the standard terminal I/O interface that you Chapter 17 - Buying Hardware for Linux are now starting to learn. However, GUI editors start their own window and present their own interface, Chapter 18 - Further Directions independent of terminals. Chapter 16 - User Environments

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.13Getting Online Help by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 pages) Linux systems come Press with a wealth of documentation. For basic commands, the manual pages (or man Thiswhat guide you describes workings of a Linux beginning the file system and processto and pages) tell you needthe to inner know. To access this system manual, use thewith man command. Forboot example, covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and see the manual page for the ls command, run man as follows: sharing printers with Samba.

manofls Table Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Most manual pages concentrate primarily on reference Chapter 2 - Devices, Disks, Filesystems, and the Kernel

information. They may contain some examples and cross-references, but that's about it. Don't expect a tutorial, and don't expect an engaging literary style. For Chapter 3 - How Linux Boots programs with many options, manual page often lists the options in some systematic way (for example, Chapter 4 - Essential System Files, the Servers, and Utilities alphabetical order). ItYour won't bother to tell you what the important ones are. If you are patient, you can Chapter 5 - Configuring Network usually find what you need to know. If you're excessively impatient, ask a friend, or pay someone to be Chapter 6 - Network Services your friend so that you can ask them. Chapter 7 - Introduction to Shell Scripts To search for a manual page by keyword, use the -k option:

Chapter 10 - Maintaining the Kernel

man -k Chapter 11 -keyword Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

This is14helpful if you quite know Chapter - Sharing Filesdon't with Samba

the name of the command that you want.

Chapter 15 - Network File Transfer

Note If you have any additional questions about any of the commands described in the previous sections, you can find the answers with the man command.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Manual pages fall into numbered sections. When someone refers to a manual page, the section number appears in parentheses next to the name — ping(8), for example. Table 1-3 explains the section numbers:

Appendix A - Command Classification Bibliography Index

Table 1-3: Online Manual Sections

List of Figures ListSection of Tables

Description

List of Sidebars

1

User commands

2

Low-level system calls

3

Higher-level Unix programming library documentation

4

Device interface and driver information

5

File descriptions (system configuration files)

6

Games

7

File formats, conventions, and encodings (ASCII, suffixes, and so on)

8

System commands and servers

Sections 1, 5, 7, and 8 are good supplements to this book. Section 4 may be of marginal use. Section 6 would be great if only it were a little larger. You can select a manual page by section. This is sometimes important because man displays the first manual page that it finds for a particular search term. For example, if you want to see the /etc/passwd file description (as opposed to the passwd command), you can insert the section number before the page name: man 5 passwd

Manual pages cover the essentials, but there are many more ways to get online help. If you're just looking for a certain option for a command, try typing a command name followed by --help or -h (the exact option varies from command to command). You may get a deluge (as in the case of ls --help), but you may find just what you're looking for. Some time ago, the GNU Project decided that it didn't like manual pages very much and switched to

another format called info (or texinfo). Often, this documentation goes further than a typical manual page, but it is sometimes more complex. To access an info page, use info with the command name: How Linux Works: What Every Super-User Should Know by Brian Ward infocommand

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such documentation as networking, firewalls, development tools, device scripts, and Some packages dump their available into /usr/share/doc with management, no regard forshell online sharing printers with Samba. manual systems such as man or info. Have a look in this directory on your system if you find yourself searching for documentation. And as ever, don't hesitate to look for help on the Internet if you have a Table of Contents connection. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

HowInput Linux Works: Every Super-User Should Know 1.14Shell andWhat Output by Brian Ward

ISBN:1593270356

Starch Press with © 2004basic (347 pages) Now that youNoare familiar Unix commands, files, and directories, you are ready learn the shell's Thiscan guide describes inner workings a Linux system beginning withstandard the file system and boot process and I/O tricks. You redirect thethestandard input of and output. Let's start with output.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

If you wish to send the output of command to a file instead of the terminal, use the > redirection character: Table of Contents

command > file Every Super-User Should Know How Linux Works—What Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

The shell- creates file if it does not already exist. If file does exist, the shell erases the original file first; How Linux Boots this is4called clobbering file. Someand shells have parameters that prevent clobbering. For example, you Chapter - Essential Systemthe Files, Servers, Utilities can type set -C to avoid clobbering in bash. Chapter 5 - Configuring Your Network Chapter 3

Chapter 6

- Network Services

If you don't want to overwrite a file, you can append the output to the file instead with the >> redirection - Introduction to Shell Scripts syntax:

Chapter 7 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

command >> file the Kernel Chapter 10 - Maintaining Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

This is13a -handy way Chapter Backups

to collect output in one place when repeatedly executing a variant of the same

command. Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

To send the output of a command to the input of another command, use the pipe (|). To see how this works, try these two commands: Chapter 17 - Buying Hardware for Linux Chapter 16 - User Environments Chapter 18 - Further Directions

head /proc/cpuinfo Appendix A - Command Classification head /proc/cpuinfo Bibliography

| tr a-z A-Z

Index List of Figures

You can send List of Tables

output through as many piped commands as you wish; just add another pipe (|) before each

additional command. List of Sidebars

1.14.1Standard Error Occasionally, you may redirect standard output but find that the program still prints something on the terminal. This is standard error (stderr), an additional output stream for diagnostics and debugging. Try this command, which produces an error: ls /fffffffff > f

After completion, f should be empty, but you still see the following error message on the terminal as standard error: ls: /fffffffff: No such file or directory

You can redirect the standard error if you like. If you want to send standard output to f and standard error to e, use the following command: ls /fffffffff > f 2> e

The number 2 specifies the stream ID that the shell modifies. Stream ID 1 is standard output (the default), and 2 is standard error. You can also send the standard error to the same place as stdout with the >& notation. For example, to send both standard output and standard error to the file named f, try this command: ls /fffffffff > f 2>&1

1.14.2Standard Input Redirection How Linux Works: What Every Super-User Should Know

It is also possible to channel a file to a program's standard input with the < operator. Here's an example: ISBN:1593270356 by Brian Ward No Starch Press © 2004 (347 pages)

head < /proc/cpuinfo This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

You will occasionally run into a program that requires this sort of redirection. However, because most Unix filenames as arguments, this redirection isn't very common. For example, the preceding commandEvery could have been written How Linux Works—What Super-User Should Knowas head /proc/cpuinfo.

Table of Contents commands accept Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What EveryMessages Super-User Should Know 1.15Understanding Error by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 When you encounter a problem onpages) a Unix-like system such as Linux, you must read the error message. This guide the inner workings of aUnix Linuxerrors systemusually beginning file system bootwrong. process and Unlike messages fromdescribes other operating systems, tellwith youthe exactly whatand went

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Most Unix programs generate and report the same basic error messages, but there can be subtle differences between the output of any two programs. Here is an example that you'll certainly encounter in Table of Contents some form or other (the error message is in boldface): How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

$ ls /dsafsda - Devices, Disks, Filesystems, and the Kernel ls: /dsafsda: No such file or directory Chapter 3 - How Linux Boots Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

There are three components to this message:

ChapterThe 7 -program Introduction to Shell name, ls.Scripts Some

programs omit this identifying information, which can be annoying Tools when- Development you are writing shell scripts, but it's not really a big deal.

Chapter 8 Chapter 9

- Compiling Software From Source Code

ChapterThe 10 -filename, Maintaining/dsafsda, the Kernel

which is a more specific piece of information. There's some problem with

Chapterthis 11 path. - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing ChapterThe 13 -specific Backups error,

No such file or directory, indicates the problem with the filename.

Chapter 14 - Sharing Files with Samba

Putting together, you get Chapter 15it- all Network File Transfer

something like "ls tried to open /dsafsda but couldn't because it does not of obvious, but these messages can get a little confusing when you run a shell script 17 that- Buying includes an erroneous Chapter Hardware for Linux command under a different name. exist."16 This may seem kind Chapter - User Environments Chapter 18 - Further Directions

Always address the first error first. For example, some programs report that they can't do something before reporting a host of other problems. For example, let's say you run a fictitious program called scumd, and you see this error message: Index Appendix A - Command Classification Bibliography

List of Figures

scumd: List of Tables/etc/scumd/config:

No such file or directory

List of Sidebars

Following this is a huge list of other error messages that looks like a complete catastrophe. Don't let those other errors distract you. You probably just need to create /etc/scumd/config.

Note Do not confuse error messages with warning messages. Warnings often look like errors, except that they contain the word "warning." A warning usually means something is wrong but that the program will try to continue running anyway. To fix a problem noted in a warning message, you may have to hunt down a process and kill it before doing anything else (you'll read about processes in Section 1.16).

1.15.1Common Errors Many of the errors that you will encounter in Unix programs result from things that can go wrong with files and processes. Here is the error message hit parade:

No Such File or Directory This is the number one error. You tried to access a file that does not exist. Because the Unix file I/O system does not discriminate between files and directories, this error message occurs everywhere. You get it when you try to read a file that does not exist, when you try to change to a directory that isn't there, when you try to write to a file in a directory that does not exist, and so on.

File Exists In this case, you probably tried to create a file that already exists. This is common when you try to create a directory with the same name as a file.

Not a Directory, is a Directory These messages pop up when you try to use a file as a directory, or a directory as a file. You may have to hunt around a little after you see the error message. Here is an example:

$ touch a $ touch a/b How Linux What Every Super-User Should Know touch:a/b: Not a Works: directory by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

Thiserror guide message describes the inner workings of a a Linux beginning file system andproblem, boot process Notice that the only applies to the partsystem of a/b. When with youthe encounter this youand advanced topics such as networking, firewalls, development tools, device management, shell scripts, and may need tocovering dig around a little to find the particular file that is being treated like a directory. sharing printers with Samba.

No Space Left on Device

Table of Contents

How Linux Works—What Every Super-User Should Know

You're out of disk space. See Section 2.4.7 for information on how to manage this.

Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel Permission Denied - How Linux Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities You get this error when you attempt to read or write to a file or directory that you're not allowed to (that is, Configuring Your Network you have- insufficient access privileges). This includes the case when you try to execute a file that does not Chapter 6 - Network Services have the execute bit set (even if you can read the file). You will read more about permissions in Section Chapter 7 - Introduction to Shell Scripts 1.17. Chapter 5

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code Operation Not Permitted

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring Manipulating Peripheral Devices This usually happensand when you try to kill a process

that you don't own.

Chapter 12 - Printing Chapter 13 - Backups

Segmentation Fault, Bus Error

Chapter 14 - Sharing Files with Samba

Chapter 15 - Networkfault File Transfer A segmentation essentially

means that the person who wrote the program that you just ran screwed tried to access some part of memory that it was not allowed to touch, and the Chapter 17 - system Buying Hardware operating killed it.for A Linux bus error is similar, except that it tried to access some memory in a particular Chapter 18 Further Directions way that it shouldn't. W hen you get one of these errors, you might be giving a program some input that it Appendix - Command Classification did not Aexpect. Chapter 16 - User Environments up somewhere. The program

Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 1.16Processes by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) Aprocess is No a running program. Each process on the system has a numeric process ID (PID). For a quick guide describes the inner workings of run a Linux beginningon with thecommand file system line. and boot listing of theThis processes that you're running, just the system ps command the Youprocess shouldand get covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and a list like this: sharing printers with Samba.

TTY STAT TablePID of Contents

TIME COMMAND

p0 S 0:00Super-User -bash Should Know How 520 Linux Works—What Every 5451 Chapter

? S - The Basics

5482 Chapter

? S Disks, 0:10 xclockand-geometry - Devices, Filesystems, the Kernel

3:59 /usr/X11R6/bin/ctwm -W -0-0 2159 pd SW 0:00 /usr/bin/vi lib/addresses Chapter 3 - How Linux Boots 319564 -p3 R System 0:00Files, ps Servers, and Utilities Chapter Essential Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

This is7 an- Introduction abridged listing; Chapter to Shellyours Scriptswill

be much longer if you're running a windowing system. The fields are

as follows: Chapter 8 - Development Tools Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

PID The process ID.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing ChapterTTY 13 - The Backups terminal

device where the process is running (don't worry about this for now).

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

TheEnvironments process status; ChapterSTAT 16 - User

that is, what the process is doing at the given time and where its memory sleeping and R means running. Check the ps(1) manual page for all

ForHardware example, means Chapterresides. 17 - Buying forSLinux Chapterthe 18 symbols. - Further Directions Appendix A - Command Classification Bibliography

TIME The amount of CPU time (in minutes and seconds) that the process has used so far. In other words, this is the total amount of time that the process has spent running instructions on the List of Figures processor. Index

List of Tables

List of Sidebars

COMMAND This one might seem obvious, but be aware that a process can change this field from its original value. If you're interested in all processes on the system (not just the ones you're running), use ps ax, and if you'd like a more detailed report on process characteristics, use ps u. As with other programs, you can combine options, as in ps aux. Another important option that works in conjunction with a is w, which tells ps to print the full command name if it's too long to fit on one line. To check on a specific process, add its PID to the argument list of the ps command. For example, one way to inspect the current shell process is with ps u $$ ($$ is a shell variable that evaluates to the current shell's PID). You'll find information on two handy administration commands called top and lsof in Section 4.8 . These can be useful when locating processes, even when doing something other than system maintenance.

1.16.1Killing Processes To terminate a process, send it a signal with the kill command. In most cases, all you need to do is this: killpid

There are many types of signals. The default signal is TERM, or terminate. You can send different signals by adding an extra option to kill. Let's say that you don't want to terminate the process, but rather, freeze it with the STOP signal. Use this command: kill -STOP pid

A process stopped in this manner is still in memory, ready to pick up where it left off. Use the CONT signal to set the process on its way again:

kill -CONT pid How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

As you may No recall from Section 1.2pages) Starch Press © 2004 (347 , CONTROL-C terminates a process running in the current terminal. This is the same as using kill endworkings the process withsystem the INT (interrupt) signal. This guide describes theto inner of a Linux beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. The most brutal way to terminate a process is with the KILL signal. Other signals give the process a chance to clean up after itself, but KILL does not — the operating system terminates the process and Table of Contents forcibly removes it from memory. Use this as a last resort. How Linux Works—What Every Super-User Should Know

Warning Don't Chapter 1 - The Basics

kill processes indiscriminately, especially if you don't know what they're doing. This can foot.

Chapter 2

be akin toFilesystems, shooting yourself in the - Devices, Disks, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

Essential System Files, Servers, and Utilities 1.16.2--Job Control Configuring Your Network

Chapter 5 Chapter 6

- Network Services Shells also support job control, a way to send STOP and CONT signals to programs by using funny - Introduction to Shell Scripts keystrokes and commands. For example, you can send a STOP signal with CONTROL-Z and start the Chapter 8 - Development Tools process again by typing fg or bg. Chapter 7 Chapter 9

- Compiling Software From Source Code

Chapter 10 the - Maintaining Kernel Despite habits ofthe many experienced

users, job control is not necessary and can be confusing to CONTROL-Z instead of CONTROL-C and have Chapter - Printing processes sitting about. many 12 suspended Chapter 11 - Configuring Manipulating beginners — it is notand uncommon forPeripheral the userDevices to press Chapter 13 - Backups Chapter - Sharing with Samba If you 14 want to runFiles multiple shell Chapter 15 - Network File Transfer put non-interactive processes

programs, you can either run each program in a separate terminal window, in the background (explained in the next section ), or learn to use the

Chapter 16 -program. User Environments screen Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

1.16.3Background Processes

Appendix A - Command Classification Bibliography

Normally, Index

when you run a Unix command from the shell, you do not get the shell prompt back until the program has finished executing. However, you can detach a process from the shell and put it in the List of Figures "background" with the ampersand (&); this gives you the prompt back. For example, if you have a large file List of Tables that you need to decompress with gunzip (you'll see this in Section 1.18), and you want to do some other List of Sidebars stuff while it's running, run the command as in this gunzip example: gunzipfile.gz &

The shell responds by printing the PID of the new background process, and the prompt returns immediately so that you can continue working. The process also continues to run after you log out, which comes in particularly handy if you have a program that does a lot of number crunching that you need to run for a while. Depending on your setup, the shell may notify you when the process completes. The dark side to background processes is that they may expect to work with the standard input (or worse). If the program wants to read something from the standard input when it is in the background, it can freeze (try fg to bring it back), or it may terminate. If the program writes to the standard output or standard error, the output can appear in the terminal window with no regard to anything else running there. The best way to make sure that a background process doesn't bother you is to redirect its output (and possibly input) as described in Section 1.14. If spurious output from background processes gets in your way, you should know how to redraw the content of your terminal window. bash and most full-screen interactive programs support CONTROL-L to redraw the entire screen. If a program is reading from the standard input, CONTROL-R usually redraws the current line. Unfortunately, pressing the wrong sequence in the wrong situation can leave you in an even worse situation than before. For example, CONTROL-R at the bash prompt puts you in an annoying mode called reverse isearch.

Linux Works: Every Super-User Should Know 1.17FileHow Modes andWhat Permissions by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 pages) that determine whether you can read, write, or run the file. Every Unix file has aPress set of permissions guide describes the inner workings of aan Linux system of beginning the file system and boot process and Runningls This -l displays the permissions. Here's example such awith display:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

-rw-r--r-- 1 juser

somegroup

7041 Mar 26 19:34 endnotes.html

Table of Contents How Linux Works—What Every Super-User Should Know

The first represents Chapter 1 -column The Basics

the mode of the file, and it is shown in bold. The mode represents the file's permissions and some extra information. There are four parts to the mode; Figure 1-1 on the next page Chapter 2 - Devices, Disks, Filesystems, and the Kernel illustrates the pieces. The first character of the mode is the file type. A dash (-) in this position, as in the Chapter 3 - How Linux Boots example, a regular file, meaning that there is nothing special about it. This is by far the most Chapter 4 - denotes Essential System Files, Servers, and Utilities common kind of file. Directories are also common, carrying d in the file type slot. The rest of the file types Chapter 5 - Configuring Your Network are listed Section 2.3 , but you don't need to know about them just yet. Chapter 6 - in Network Services Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

Figure 1-1: The of a Chapter 14 - Sharing Filespieces with Samba

file mode

Chapter 15 - Network File Transfer

The rest of a file's mode contains the permissions, which break down into three sets: the user,group, and other permissions, in that order. For example, the rw- characters in the example are the user permissions, Chapter 17 - Buying Hardware for Linux r-- are the group permissions, and r-- are the other permissions. Chapter 18 - Further Directions Chapter 16 - User Environments

Appendix A - Command Classification

Four basic things can appear in each permission set:

Bibliography Index

r Means that the file is readable

List of Figures

w Means List of Tables

that the file is writable

List of Sidebars

x Means that the file is executable (that is, you can run it as a program) - Means nothing The user permissions (the first set) pertain to the user who owns the file. In the preceding example, that's juser. The second set, group permissions, are for the file's group (somegroup in the example). Any user in that group can take advantage of these permissions. (Use the groups command to see what group you're in, and see Section 4.3.2 for more information.) Everyone else on the system has access according to the other permissions. These are sometimes called world permissions.

Note Each read, write, and execute permission slot is sometimes called a permission bit. Therefore, you may hear people refer to parts of the permissions as "the read bits." Some executable files have an s in the user permissions listing instead of an x. This indicates that the executable is setuid, meaning that when you execute the program, it runs as the file owner instead of you. Many programs use this setuid bit to run as root to get the special privileges they need to change system files. One example is the passwd program, which needs to change the /etc/passwd file.

1.17.1Modifying Permissions To change permissions, use the chmod command. First, pick the set of permissions that you want to change, and then pick the bit to change. For example, say that you want to add group (g) and world (o, for "other") read (r) permissions to file. You can do it with two commands: chmodg+rfile chmodo+rfile

Or you can do it all in one shot like this: chmodgo+rHow fileLinux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a of Linux system beginning with the file system and boot process and To remove these permissions, use go-r instead go+r. covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Note Obviously, you shouldn't make your files world writable because it gives anyone on your system the ability to change them. But would this give anyone connected to the Internet a chance to Table of Contents change your files? Probably not, unless your system has a network security hole. In that case, How Linux Works—What Every Super-User Should Knowyou. file permissions aren't going to help Chapter 1

- The Basics

Chapter 2 - sometimes Devices, Disks, Filesystems, and the Kernel You may see people changing permissions Chapter 3

with numbers, for example:

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities chmod 644 file

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter - Introduction to Shell Scripts This is7 called an absolute change,

because it sets all of the permission bits at once. To understand how how to represent the permission bits in octal form (each numeral represents Chapter 9 number - Compiling Software From Source an octal and corresponds to a Code permission set). If you're curious about this, look at the chmod(1) Chapter 10 Maintaining the Kernel manual page or the info page. Chapter 8 - Development Tools this works, you need to know

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing It is actually not that Chapter - Backups modes13that you use.

important to know how to construct absolute modes; it is easier to just memorize the Table 1-4 lists the most common absolute modes.

Chapter 14 - Sharing Files with Samba Chapter - Network File Transfer Table15 1-4: Absolute Permission

Modes

Chapter 16 - User Environments

Mode Meaning Chapter 17 - Buying Hardware for Linux

Used For

Chapter 18 - Further Directions

Appendix A - Command Classification

user: read/write; group, other: read

files

Bibliography 600

644

user: read/write; group, other: none

files

List755 of Figures

user: read/write/execute; group, other: read/execute

directories, programs

List of Tables

700

user: read/write/execute; group, other: none

directories, programs

711

user: read/write/execute; group, other: execute

directories

Index

List of Sidebars

Directories also have permissions, as you can see from the preceding list. You can list the contents of a directory if the directory is readable, but you can only access a file inside if the directory is executable. One common mistake people make when setting the permissions of directories is to accidentally remove the execute bit when using absolute modes. Finally, you can specify a set of default permissions with the umask shell command that are applied to any new file you create. Without going into too much detail, use umask 022 if you want everyone to be able to see all of the files and directories that you make, and use umask 077 if you don't. You need to put the umask command with the desired mode in one of your startup files to make your new default permissions apply to later sessions (see Chapter 16).

1.17.2Symbolic Links Asymbolic link is a file that points to another file or a directory, effectively creating an alias. It is similar to a shortcut in W indows. Symbolic links offer a quick way to provide access to an obscure directory path. In a long directory listing, these links look like this (notice the l as the file type in the file mode): lrwxrwxrwx 1 ruser

users

11 Feb 27 13:52 funk -> /home/skunk

If you try to access funk in this directory, the system gives you /home/skunk instead. Symbolic links are nothing more than names that point to other names. The names of the symbolic links and the paths to which they point don't actually have to mean anything. In the preceding example, /home/skunk doesn't need to exist. If /home/skunk does not in fact exist, any program that accesses funk just reports that funk doesn't exist (except for ls funk, a command that stupidly informs you that funk is funk). This can be baffling, because you can see something named

funk right there in front of you. This is not the only wayWorks: that symbolic links can be confusing. Another problem is that you cannot identify How Linux What Every Super-User Should Know the characteristics a link target just by looking at the name of the link. You must follow the linkISBN:1593270356 to find by Brianof Ward out if it goesNo toStarch a file Press or directory. Your system may also have links that point to other links, which are © 2004 (347 pages) called chained symbolic links. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

To create a sharing symbolic link from target to linkname, use this command: printers with Samba. Table ln of -sContents target

linkname

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 - Devices, Disks, Filesystems, and the Kernel Thelinkname argument is the name of the symbolic Chapter 3 -that How the Linux Boots directory link points

link, the target argument is the path of the file or to, and the -s flag specifies a symbolic link (see the warning on the next

Chapter page).4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

When6making a symbolic Chapter - Network Services

link, check the command twice before you run it, because there are a number of if you reverse the order of the arguments (ln -s linkname target) in for Tools some fun when linkname is a directory that already exists. In this case, ln creates Chapter 8 -you're Development Chapter - Compiling Software Source Code a link 9named target insideFrom linkname (the link points to itself unless linkname is a full path). Therefore, Chapter 10 - Maintaining the Kernel if something goes wrong when you create a symbolic link to a directory, check that directory for errant Chapter 11 -links Configuring and Manipulating symbolic and remove them. Peripheral Devices things7that can go wrong. For example, Chapter - Introduction to Shell Scripts

Chapter 12 - Printing

Symbolic can Chapter 13 - links Backups

also cause headaches when you're not aware of their presence. For example, you can of a file but is actually a symbolic link to the original.

easily 14 edit what you is a copy Chapter - Sharing Filesthink with Samba Chapter 15 - Network File Transfer

forget the Warning Chapter 16 - UserDon't Environments

-s option when creating a symbolic link. Without it, ln creates a hard link, real filename to a single file. The new filename has all of the status of theDirections old one; it points (links) directly to the file data instead of to another filename, as a Chapter 18 - Further symbolic link does. Hard links can be even more confusing than symbolic links. Avoid them. Appendix A - Command Classification giving an additional Chapter 17 - Buying Hardware for Linux

Bibliography

With Index

all of these warnings regarding symbolic links, you may wonder why anyone ever bothers with them. The simple List of Figures reason is that they offer a convenient way to share files and patch up small problems. List of Tables List of Sidebars

How Linux and Works:Compressing What Every Super-UserFiles Should Know 1.18Archiving by Brian Ward

ISBN:1593270356

Starchall Press © 2004 (347permissions, pages) Now that youNoknow about files, and the errors that you might get, you need to master tar andgzip. This guide describes the inner workings of a Linux system beginning with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Start with gzip (GNU Zip), the current standard Unix compression program. A file that ends with .gz is a GNU Zip archive. Use gunzipfile.gz to uncompress file.gz and remove the suffix; to compress it Table of Contents again, use gzipfile. How Linux Works—What Every Super-User Should Know Chapter - The gzip 1does notBasics perform

the additional function of archiving, like the ZIP programs for other operating and directories into one file, thus creating an archive. To Chapter How Linuxuse Boots create3an- archive, tar instead: Chapter 2 -— Devices, Filesystems, the Kernel systems that is,Disks, it does not packand multiple files Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

tar cvf- Network archive.tar file1 file2 ... Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

tar archives have a .tar suffix. In the preceding example, file1,file2, and so on are the names of - Compiling Software From Source Code the files and directories that you wish to place in the archive named archive.tar. The c flag denotes Chapter 10 - Maintaining the Kernel create mode. You will learn about the v and f flags later in this section. Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 9

Chapter 12 - Printing

You can also unpack a .tar file with tar:

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba

tar xvf file.tar Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Study this command. The xvf part specifies the mode and options; it is the same as -xvf. The meanings

Appendix A - Command Classification

are as follows: Bibliography Index

Thex flag puts tar into extract (unpack) mode. You can extract individual parts of the archive by placing the names of the parts at the end of the command line, but you must know their exact names. List of Tables To find out for sure, see the table of contents mode described shortly. List of Figures

List of Sidebars

Thev flag activates verbose diagnostic output, causing tar to print the names of the files and directories in the archive when it encounters them. Adding another v causes tar to print details such as file size and permissions. Thef flag denotes the file option. The next argument on the command line must be the file on which tar is to work (in the preceding example, it is file.tar). You must use this option and a filename at all times — there is one exception, but it involves tape drives (see Section 13.6). To use standard input or output, use - instead of the filename.

Note When using extract mode, remember that tar does not remove the archived .tar file after extracting its contents. Before unpacking, it's usually a good idea to check the contents of a .tar file with the t (table of contents) mode instead of x. This mode verifies the archive's basic integrity and prints the names of all files inside. The most important reason for testing an archive is that sometimes unpacking an archive can dump a huge mess of files into the current directory. This is difficult to clean up. When you check an archive with thet mode, verify that everything is in a rational directory structure — that is, all file pathnames in the archive should start with the same directory. If you're not sure, create a temporary directory, change to that, and then extract. You can always use mv * .. if it turned out to be a false alarm. One last significant option to tar is p, which preserves permissions. Use this in extract mode to override yourumask and get the exact permissions specified in the archive. The p option is the default when working as the superuser. If you're having trouble with permissions and ownership when unpacking an archive as the superuser, make sure that you are waiting until the command terminates and you get the shell prompt back. Although you may only want to extract a small part of the archive, tar must run through the whole thing. You must not interrupt the process, because it sets the permissions only after checking the entire archive. You should commit all of the tar options and modes in this section to memory; know them cold. If you're having trouble, make some flash cards. This may sound like a grade-school strategy, but it is very

important to avoid careless mistakes with this command. How Linux Works: What Every Super-User Should Know 1.18.1Compressed Archives (.tar.gz) by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

Many beginners find it confusing that archives normally come compressed, where the archive file ends in This guide describes the inner workings of a Linux system beginning with the file system and boot process and .tar.gz. To unpack a compressed archive, work from the right side to the left; get rid of the .gz first and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and then worry about the .tar. For example, these two commands decompress and unpack file.tar.gz: sharing printers with Samba. Table of Contents gunzip file.tar.gz How Linux Works—What Every Super-User Should Know tar xvf file.tar Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter - Howstarting Linux Boots When3you're out,

it's fine to do this one step at a time, first running gunzip to decompress and you soon memorize the entire archiving and Chapter 5 - Configuring Your Network this is not the fastest or most efficient way to invoke tar on a compression process. However, Chapter 6 - Network Services compressed archive. In particular, it wastes system resources — disk space and kernel I/O time. Chapter 4 -to Essential System Files, Servers, and Utilities thentar verify and unpack. When you do it enough,

Chapter 7

- Introduction to Shell Scripts

You can archival Chapter 8 -combine Development Tools

and compression functions with a pipeline; for example, this command pipeline

unpacks Chapter 9 file.tar.gz: - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and zcatfile.tar.gz | Manipulating tar xvf -Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter - Sharing with Samba zcat 14 is the sameFiles as gunzip -dc. Chapter 15 -output Network File Transfer standard (in this case,

The -d option decompresses and the -c option sends the result to to the tar command).

Chapter 16 - User Environments

Because is such a common Chapter 17 -this Buying Hardware for Linuxoperation,

the version of tar that comes with Linux has a shortcut. You automatically invoke gzip on the archive. For example, use tar ztvf file.tar.gz to verify a compressed archive. However, for the sake of learning, you should make an Appendix A - Command Classification Bibliography effort to master the longer form before taking the shortcut. can use as an option to Chapter 18 z - Further Directions

Index List of Note FiguresA.tgz

file is the same as a .tar.gz file. The name is meant to fit into FAT (MS-DOS based)

List of Tablesfilesystems. List of Sidebars

1.18.2Other Compression Utilities A newer compression program gaining some popularity in Unix is bzip2, where compressed files end with .bz2. Marginally slower than gzip, it often compacts text files a little more, and is therefore increasingly popular in the distribution of source code. The decompressing program is bunzip2, and the options of both components are close enough to those of gzip that you don't need to learn anything new. Most Linux distributions come with zip and unzip programs compatible with the ZIP archives on Windows systems. They work on the usual .zip files as well as self-extracting archives ending in .exe. If you encounter a file that ends in .Z, you have found a relic created by the compress program, once the Unix standard. gunzip can unpack these files, but gzip will not create them.

How Linux Works: What Every Super-User Should Know Chapter 2: Devices, Disks, Filesystems, and the Kernel by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

This chapterThis is aguide guided tour of the infrastructure in a functioning Linux system, including the system describes the inner workings of a Linux system beginning with the file system and boot process and directories, devices, and thetopics kernel. A as large part of firewalls, the material in this chapter deals with filesystems. covering advanced such networking, development tools, device management, shell scripts, and sharing the printers with Samba. When you master workings of Linux filesystems, you will find it much easier to deal with system crashes, manage software, and accommodate new hardware. Table of Contents

Note You must Every do most systemShould configuration How Linux Works—What Super-User Know

and maintenance work as the superuser; this and all chapters assume that you have this capability.

Chapter 1

- remaining The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

- How Linux Boots 2.1 Directory Hierarchy

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 - Configuring Your Network As mentioned in Chapter 1, your

Linux system has a root directory (/). The root contains several a file or two. Keep this area clean; don't let stray files end up here. But don't Chapter 7 - Introduction to Shell fall victim to a syndrome thatScripts affects many administrators — removing files in a zealous attempt to keep Chapter 8 - Development the system "clean." If Tools you don't know what something does (and can't figure it out), don't remove it. Chapter 6 - Network subdirectories andServices possibly

Chapter 9

- Compiling Software From Source Code

The names of the directories Chapter 10 - Maintaining the Kernel in

/ have special meanings that pervade the Linux system in many other in the root, but there are also many other bin directories throughout the system, including /usr/bin and /usr/local/bin. All of these bin Chapter 12 - Printing directories contain executables. Chapter 13 - Backups subdirectories. For example, there is a /binDevices directory Chapter 11 - Configuring and Manipulating Peripheral

Chapter 14 - Sharing Files with Samba

If you 15 want to know gory Chapter - Network Filethe Transfer

details of the many directories on the system, have a look at the Filesystem For the most part, the directory names reflect the root and /usr directory patterns in the for next sections. Chapter 17 -described Buying Hardware Linux Hierarchy Standard [Filesystem]. Chapter 16 - User Environments Chapter 18 - Further Directions Appendix A - Command Classification

2.1.1The Essential Root Subdirectories

Bibliography Index

The most important of the root directory's subdirectories are the following:

List of Figures List of Tables

bin Contains List of Sidebars

binary programs (also known as an executables), which are programs that are ready to run. Most of the basic Unix commands such as ls and cp are in /bin. However, some of the files in /bin are not in binary format because shell scripts perform the tasks of binaries in modern systems.

dev Contains device files. Read more about these special files in Section 2.3 . etc The core system configuration directory (pronounced EHT-cee). User password, boot, device, networking, and other setup files are here. Many items in /etc are specific to the particular hardware on the machine — for example, the /etc/X11 directory contains the graphics card configuration. home Holds personal directories for normal users on the system. Most Unix installations conform to this standard. lib An abbreviation for library. In Linux, this directory holds library files containing code that executables can use. There are two types of libraries: static and shared. The /lib directory should contain only shared libraries, but other lib directories such as /usr/lib contain both varieties, as well as other auxiliary files. proc Provides system statistics through a directory-and-file interface that you can browse with standard Unix tools, like those introduced in Chapter 1. Much of the /proc subdirectory structure on Linux is unique, but many other Unix variants have similar features. sbin The place to find system executables. Programs in sbin directories pertain to system management, so regular users usually do not have sbin components in their command paths. Many of the utilities don't work for normal users. tmp The place to put smaller temporary files that you don't care much about. Any user may read to and write from /tmp, but they may not have permission to access another user's files there. Some

programs use this directory as a workspace. If something is extremely important, don't put it in /tmp. Most distributions clear /tmp when the machine boots, and some even remove its old files periodically. Don't Works: fill /tmp either, because its space isKnow usually shared with something critical (like the How Linux What Every Super-User Should rest of /, example). ISBN:1593270356 by for Brian Ward No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and usr Pronounced as "user," but this subdirectory does not contain user files (there have been no user covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and files in /usr Unix with systems long before Linux existed). Instead, /usr is a large directory hierarchy sharingon printers Samba. that looks a little like the root. The bulk of the Linux system resides in /usr. Many of the directory names in /usr are the same as in the root and hold the same type of files; /usr/bin and /usr/lib Table of Contents are Works—What two examples. The primaryShould reason that the root does not contain the complete system is to keep How Linux Every Super-User Know requirements low. The /usr directory is so important that Section 2.1.3 is dedicated to it. Chapterspace 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

How Linux Boots var -The "variable" subdirectory, where programs record runtime information. System logging, user - Essential System Files, Servers, and Utilities tracking, caches, and other files that system programs create and tend all go into /var. There is a Chapter 5 - Configuring Your Network /var/tmp similar to /tmp, but the system doesn't wipe it clean on boot. Chapter 4 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

- Development Tools 2.1.2Other Root Subdirectories

Chapter 8 Chapter 9

- Compiling Software From Source Code

Chapter the Kernel There10 are- Maintaining a few other interesting

subdirectories in the root:

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

boot Contains kernel boot loader files. These files pertain only to the very first stage of the Linux process; not find information about how Linux starts up its services in this directory. Chapterstartup 14 - Sharing Files you with will Samba Chapter 13 - Backups

Chapter 15 - Network File Transfer Chaptercdrom 16 - User Environments Where most Linux

distributions attach a CD drive; the contents of the disc are under this directory. The root may contain similar directories for other removable devices.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Appendix A - Command Classification

opt May Bibliography

contain additional third-party software. Many systems don't use /opt.

Index List of Figures

2.1.3The /usr Directory

List of Tables

List of Sidebars

The/usr directory may look relatively clean at first glance, but a quick look at /usr/bin and /usr/lib reveals that there's a lot here. In addition to the subdirectories that you just read about, /usr contains the following: include Holds header files used by the C compiler (see Section 8.1.2). info Contains GNU info pages (see Section 1.13). local Where administrators can install their own software. Its structure should look like that of / and /usr. man Contains manual pages. Unformatted pages go in the man* directories here (according to the numbered category described in Section 1.13), and human-readable formatted pages go in cat*. share Contains files that should work on other kinds of Unix machines with no loss of functionality. That's the theory, anyway; a true share directory is becoming rare because there are no space issues on modern disks. It is often more of a pain to maintain a share directory than it's worth. In any case, man,info, and some other subdirectories are often found here. X11R6 Holds the core Linux windowing system software, called XFree86. However, the custom configuration files for your computer are usually in /etc/X11. dict An oddball subdirectory containing dictionaries; /usr/dict/words is one such dictionary file.

How Linux Works: What Every Super-User Should Know 2.2 The Kernel by Brian Ward

ISBN:1593270356

No Starch Press © 2004directory (347 pages) structure looks like. Before going on to devices and filesystems, You now know what the Linux Thissome guide describes the inner workings of a Linux system beginning with the file system and boot process and you must learn higher-level concepts about the kernel.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Thekernel of an operating system is the very core of a running system. It's a very special program that manages all processes, device drivers, and I/O. When the system boots, the kernel runs first, initializing Table of Contents hardware and internal data structures. After the kernel completes this stage, it loads and starts the init How Linux Works—What Every Super-User Should Know program. Chapter 1

- The Basics

Chapter 2 - Devices, Disks, Filesystems, and the Kernel The kernel also has many functions once the system

boots. Process and device management are the most although computers with one CPU run only one program at a time, the kernel Chapter 4 - several Essential programs System Files, and can keep inServers, memory atUtilities the same time. Process and device management run together in Chapter 5 Configuring Your Network a cycle like this: Chapter 3 - How important. TheLinux ideaBoots is that

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

1. The kernel has control of the processor. There are several processes in memory.

Chapter 8

- Development Tools 2. The kernel selects a process and finds out where that process was last running.

Chapter 9

- Compiling Software From Source Code

Chapter - Maintaining the Kernel 3. 10The kernel relinquishes

control of the processor to that process.

Chapter 11 - Configuring and Manipulating Peripheral Devices

4. 12That process Chapter - Printing

runs for a few microseconds.

Chapter 13 - Backups

5. 14When the Files timewith is up, a clock Chapter - Sharing Samba

interrupt stops the process and gives control back to the kernel.

Chapter 15 - Network File Transfer

6. The kernel takes care of any system work that it needs to do, such as reading to and from devices.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

7. Go to step 2.

Chapter 18 - Further Directions Appendix A - Command Classification This description of the kernel's

work is somewhat simplified, but as you can see, there is nothing magic kernel. It is not a process; it is just a piece of code that runs every now and then between Index processes. Bibliography about the

List of Figures List Tablessystems, OnofLinux

the kernel is normally in a file called /vmlinuz or /boot/vmlinuz. A boot loader into memory and sets it in motion when the system boots. Details on to how to configure the boot loader and how to create a Linux kernel are in Chapters 4 and 10 .

List of Sidebars loads this file

If you are interested in the detailed workings of a kernel, the classic textbook is Operating System Concepts [Silberschatz].

How Linux Works: What Every Super-User Should Know 2.3 Devices by Brian Ward

ISBN:1593270356

Starcheasy Pressto © 2004 (347 pages)devices on a Unix system because the kernel normally presents You will findNo it very manipulate Thisinterface guide describes the inner of a Linux as system with theafile system and boot the device I/O to system andworkings user processes files.beginning Not only can programmer use process regularand file advanced topics such as networking, firewalls, development tools, device management, shell scripts, and operations tocovering work with a device, but some devices are also accessible to standard programs like cat, so sharing printers with Samba. you don't have to be a programmer to use a device. Linux uses the same design of device files as other Unix flavors, but device filenames and functionality vary among flavors.

Table of Contents

How Linux Works—What Super-User Should Know Linix device files areEvery in the /dev directory, and Chapter - The Basics files in1 /dev. So how Chapter 2

running ls /dev reveals that there are more than a few do you work with devices?

- Devices, Disks, Filesystems, and the Kernel

Chapter - How Linux Boots this To get3 started, consider

command:

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

echo blah blah > /dev/null

Chapter 8

Development Tools Like any -command with redirected output, this sends some stuff on the standard output to a file. However, Chapter 9 Compiling Software From Source Code the file is /dev/null, a device, and the kernel decides what to do with any data written to this device. In Chapter 10 Maintaining the Kernel the case of /dev/null, the kernel simply ignores the data (making /dev/null a bitbucket). Of course, Chapter - Configuring and Peripheral Devices other 11 devices actually doManipulating things, such as /dev/dsp, which plays a sound if you send appropriate output Chapter Printing there 12 (for- example, cat blab.wav > /dev/dsp). Chapter 13 - Backups Chapter 14 - Sharing Filesuse with ls Samba To identify a device, -l

to get a long listing and look at the permissions. Here are four examples:

Chapter 15 - Network File Transfer Chapter 16 - User Environments

brw-rw---1 root disk crw-rw-rw1 root root Chapter 18 - Further Directions prw-r--r-1 root root Appendix A - Command Classification srw-rw-rw1 root root Chapter 17 - Buying Hardware for Linux

Bibliography

3, 1,

65 3 0 0

Jul 20 1998 hdb1 Jul 20 1998 null Mar 3 19:17 gpmdata Dec 18 07:43 log

Index List of Figures List of Tables Notice the

very first character of each line in the listing. If this character is b,c,p, or s, then the file is a device. These letters stand for block,character,pipe, and socket, respectively:

List of Sidebars

Block device Programs access data in a block device in fixed chunks. The hdb1 in the preceding example is a disk device. Because disks break down into blocks of data, it is only natural that a disk be a block device. A block device's total size is fixed, and a program has random access to any block in the device. Character deviceCharacter devices work with data streams. You can only read characters from or write characters to these devices, like /dev/null in the previous example. Character devices don't have a size; when you read from or write to a character device, the kernel usually performs a read or write operation on the device, leaving no record of the activity inside the kernel. Printers are character devices, and after the kernel sends data to a printer, the responsibility for that data passes to the printer; the kernel cannot back up and reexamine the data stream. Pipe deviceNamed pipes are like character devices, but there is another process at the other end of the I/O stream instead of a kernel driver. An example of such a process is gpm, a program that can duplicate mouse events and send them to the named pipe /dev/gpmdata for use by other programs. Socket deviceSockets are special-purpose I/O files offering a type of network interface. For example, the gpm program accepts control commands through the /dev/gpmctl socket. You don't need to worry about sockets if you're not a network programmer. The numbers before the dates in the first two lines of the previous listing are the major and minor device numbers that help the kernel identify the device. Similar devices usually have the same major number, such as hda3 and hdb1 (these are both hard disk partitions).

2.3.1dd and Devices The name dd stands for convert and copy. dd is extremely useful when working with block and character

devices. This program's sole function is to read from an input file or stream and write to an output file or stream, possibly doing some encoding conversion on the way. It was originally developed for reblocking. How Linux Works: What Every Super-User Should Know

dd copies data in blocks of a fixed size. Here is an example of using dd with a character device ISBN:1593270356 and some by Brian Ward common options: No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such bs=1024 as networking, firewalls, development tools, device management, shell scripts, and dd if=/dev/zero of=new_file count=1 sharing printers with Samba.

Table of Contents How Works—What Super-User Should Know As Linux you can see, the Every dd option format is different

than the option formats of most other Unix commands; - character to signal an option, you name an option and set its value to something with Chapter 2 - Devices, Disks, Filesystems, the Kernel the= sign. The preceding exampleand copies a single 1024 -byte block from /dev/zero (a continuous Chapter Boots stream3 of- How zeroLinux bytes) to the file new_file. These are the important dd options: Chapter - The Basics rather1than use the

Chapter 4

- Essential System Files, Servers, and Utilities

The input The Chapterif=file 5 - Configuring Your file. Network Chapter 6

default is the standard input.

- Network Services

The output file. The Chapterof=file 7 - Introduction to Shell Scripts Chapter 8

default is the standard output.

- Development Tools

The Software block size; ddSource readsCode and Chapterbs=size 9 - Compiling From

writes this many bytes of data at a time. To abbreviate large chunks of data, you may use b and k to signify 512 and 1024 bytes. Therefore, the example above Chapter 10 - Maintaining the Kernel could read bs=1k instead of bs=1024. Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

ibs=size, obs=size The input and output block sizes. If you can use the same block size for both input and output, use the bs option, but if this is impossible, then use ibs and obs for input and Chapter 14 - Sharing Files with Samba respectively. Chapteroutput, 15 - Network File Transfer Chapter 13 - Backups

Chapter 16 - User Environments

count=num The total number of blocks to copy. W hen working with a huge file, or with a device that supplies an endless stream of data (like /dev/zero), you want dd to stop at a fixed point. Otherwise Chapter 18 - Further Directions you could waste a lot of disk space, CPU time, or both. count can be used in conjunction with the Appendix A - Command Classification skip parameter to copy a small piece out of a large file or device. Chapter 17 - Buying Hardware for Linux

Bibliography Index

skip=num Skip past the first num blocks in the input file or stream; do not copy them to the output.

List of Figures List of Tables

2.3.2Device Name Summary

List of Sidebars

Sometimes it is difficult to find the name of a device (for example, when partitioning a disk). Here are two tactics for finding out: Guess the name from the output of the dmesg command (which prints out the last few kernel messages) or the kernel system log file (see Section 4.1); this output might contain a description of the devices on your system. Runcat /proc/devices to see the block and character devices for which your system currently has drivers. Each line consists of a number and name. The number is the major number of the device described in Section 2.3. If you can guess the device from the name, look in /dev for the character or block devices with the corresponding major number, and you've found the device files. Neither method is terribly reliable, especially because the kernel does not load certain device drivers until you try to use them. (Section 10.8 has information on the driver-loading mechanism.) The following sections list the most common Linux devices and their naming conventions.

Hard Disks: /dev/hd* These are the ATA (IDE) disks and partitions. All are block devices. Two example names are /dev/hda1 and /dev/hdb. The letter after hd identifies the disk, and the number represents the partition. A device without a number is a device for an entire disk. (Information on how to partition disks is in Section 2.3.4. To connect disks to your current systems, start at Section 2.4.3.)

SCSI Disks: /dev/sd* SCSI disks carry the names /dev/sda,/dev/sdb, and so on, and the disks work much like their ATA counterparts, although the SCSI disk names do not directly correspond to a SCSI host controller and target. Linux assigns the devices in the order that it encounters the disks. For example, if you have two SCSI controllers, scsi0 and scsi1, with disks at scsi0 targets 0, 3, and

scsi1 target 1, the device assignments are as shown in Table 2-1. Table 2-1: Sample How Linux Device Works: Assignments What Every Super-User Should Know by Brian Ward

ISBN:1593270356

ControllerNo Starch Press © 2004 (347 pages) Target

Device Assignment

This guide describes the inner workings of a Linux system beginning with the file system and boot process and /dev/sda 0 covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

scsi0 scsi0

scsi1 Table of Contents

3

/dev/sdb

1

/dev/sdc

How Linux Works—What Every Super-User Should Know

This naming Chapter 1 - Thescheme Basics

can cause problems when reconfiguring hardware. Let's say that scsi0 target 3 the machine can work again. When you do so, scsi1 target 31 moves to /dev/sdb from /dev/sdc, and you have to change the fstab file (described later in Chapter - How Linux Boots Chapter this chapter). 4 - Essential System Files, Servers, and Utilities explodes you Disks, must Filesystems, remove the disk that Chapter 2 - and Devices, and theso Kernel

Chapter 5

- Configuring Your Network

- Network Services /dev/pts/*, /dev/tty Terminals: /dev/tty*,

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Terminals are devicesTools for moving Chapter 8 - Development

characters between the system and an I/O device, usually for text output goes back a long way, to the days when terminals were

to a terminal screen. The terminal device Chapter 9 - Compiling Software From Source Codeinterface typewriter-based devices. Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Pseudo-terminal Chapter 12 - Printing devices

are emulated terminals that understand the I/O features of real terminals, but a real piece of hardware, the kernel presents the I/O interface to a piece of software, such as shell window. Chapter 14 a- Sharing Files with Samba rather13 than talk to Chapter - Backups

Chapter 15 - Network File Transfer

Two common terminal devices are /dev/tty1 (the first virtual console) and /dev/pts/0 (the first pseudo-terminal device). Chapter 17 - Buying Hardware for Linux Chapter 16 - User Environments Chapter 18 - Further Directions

The/dev/tty device is the controlling terminal of the current process. If a program is currently reading from and writing to a terminal, this device is a synonym for that terminal. A process does not need to be Bibliography attached to aterminal. Appendix A - Command Classification Index

List of Figures

Serial Ports: /dev/ttyS*

List of Tables

List of Sidebars

Serial ports are special terminal devices. You can't do much on the command line with serial port devices because there are too many settings to worry about, such as baud rate and flow control. The port known as COM1 on Windows is /dev/ttyS0, COM2 is /dev/ttyS1, and so on. For add-in modem cards, check the output of the dmesg command for the port assignment.

Floppy Disks: /dev/fd* Section 11.1.1 covers operations on these block devices. The 3.5-inch floppy on most modern systems is /dev/fd0.

Parallel Ports: /dev/lp0, /dev/lp1 These unidirectional port devices correspond to LPT1 and LPT2 in Windows. You can send files (such as a file to be printed) directly to a parallel port with the cat command, but you might need to give the printer an extra form feed or reset afterward. The bidirectional parallel ports are /dev/parport0 and /dev/parport1.

Audio Devices: /dev/dsp, /dev/audio, /dev/mixer, /dev/snd/*, etc. Linux has two different sets of audio devices. There are separate devices for the OSS (Open Sound System) and the newer ALSA (Advanced Linux Sound Architecture) system interface. Linux systems that use ALSA usually contain OSS compatibility devices, because most applications still use OSS. Some rudimentary operations are possible with the dsp and audio devices that belong to OSS. As mentioned earlier, the computer plays any WAV file that you send to /dev/dsp. However, it may not sound right due to frequency mismatches. The ALSA devices are in the /dev/snd directory, but you can't do much by redirecting standard I/O to them. Note Theplay and aplay programs can play samples from the command line. To adjust the volume and mixer settings, aumix and alsamixer are available on most systems.

2.3.3Creating Device Files How Linux Works: What Super-User Know the device name as well as its major and To create one individual device file,Every use mknod. YouShould must know ISBN:1593270356 by Brian Ward minor numbers. For example, if you remove /dev/hda2 by accident, you can create it again with this No Starch Press © 2004 (347 pages) command:

mknod

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers /dev/hda2 b 3 with 2 Samba.

Table of Contents

TheLinux b32Works—What specifies a Every blockSuper-User device with a major How Should Knownumber pipe devices, use c Chapter 1 - The Basics Chapter 2

3 and a minor number 2. For character or named

or p instead of b.

- Devices, Disks, Filesystems, and the Kernel

Themknod command is useful only for creating the occasional missing device or named pipe. As you - How Linux Boots upgrade your system and add device drivers, you may need to create entirely new groups of devices. Chapter 4 - Essential System Files, Servers, and Utilities Because there are so many devices, it's better to use the MAKEDEV program (found in /dev) to create Chapter 5 - Configuring Your Network groups of devices. Device groups can be named after the common part of several device names, such as Chapter 6 - Network Services hda, or they can have a completely separate name, such as std-hd. For example, to create all devices Chapter 7 - Introduction to Shell Scripts beginning with hda, run this command: Chapter 3

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

/dev/MAKEDEV hda Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

MAKEDEV command Note Chapter 14 - The Sharing Files with Samba

is harmless if the devices already exist on your system.

Chapter 15 - Network File Transfer

devfs

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

Before18you go to Directions the trouble Chapter - Further

of making any device files, you should see whether you're running devfs, an automatic device-file generation system. The easiest way to check for devfs is to run mount and look for Appendix A - Command Classification devfs in the output. Bibliography Index

If your system runs devfs, you should not have to create missing device files because the kernel maintains the directory of available device files. Linux kernels typically configure devfs at boot time, List of Tables starting a special auxiliary system program called devfsd that gives the administrator the ability to List of Sidebars customize the device system. List of Figures

Note devfs was an experimental feature in older Linux kernels, but is classified as obsolete in the latest Linux kernels.

2.3.4Partitioning Disk Devices Before you can use a new disk on your system, you need to know how to partition disks with their device files. If you've never worked with partitions before, don't worry. A disk partition is just a piece of the disk dedicated to one purpose, such as a specific directory tree. On PCs, partitions have numbers starting at 1. To get started, identify the disk device that you want to partition. Most PCs have two ATA interfaces, called primary and secondary interfaces, and each interface can have a master and slave disk, for a total of four disk devices. The standard ATA disk assignments are as follows: /dev/hda Master disk, primary interface /dev/hdb Slave disk, primary interface /dev/hdc Master disk, secondary interface /dev/hdd Slave disk, secondary interface There are several partitioning utilities, but the most simple and direct is fdisk. To get started, run fdisk dev (where dev is one of the devices listed above), then print the current partition list with p. Here is sample from fdisk output for a device with three partitions, two containing filesystems and one with swap (see Section 2.5 for more information on swap partitions).

Disk /dev/hda: 240 heads, 63 sectors, 2584 cylinders Units = cylinders of 15120 * 512 bytes How Linux Works: What Every Super-User Should Know

Device Boot End Blocks Id System ISBN:1593270356 by Brian Ward Start /dev/hda1No Starch Press © 20041 (347 pages) 136 1028128+ 83 Linux /dev/hda2This guide describes 137 204 of a Linux 514080 82 Linux swap the inner workings system beginning with the file system and boot process and topics such as networking, firewalls, development tools, device management, shell scripts, and /dev/hda3covering advanced205 2584 17992800 83 Linux sharing printers with Samba. Table Partition of Contents dimensions

are usually in units of cylinders. Each partition has a start and end cylinder, cylinder varies depending on the disk. The second line in Chapter the preceding 1 - The Basics output shows you the cylinder size, but you don't need to do any weird computations to Chapter create2partitions. - Devices, Disks, Filesystems, and the Kernel How determining Linux Works—What its size,Every but the Super-User amountShould of space Knowper

Chapter 3

- How Linux Boots

When4creating a new partition, you only to Chapter - Essential System Files, Servers, andneed Utilities

know the starting cylinder. Cylinders do not overlap in PC a disk, pick the first available cylinder in the fdisk partition list output. In the 6preceding Chapter - Networkexample, Services you would choose 2585 as the starting cylinder. partitions, so if you'reYour partitioning Chapter 5 - Configuring Network Chapter 7

- Introduction to Shell Scripts

Each partition also has a system ID, a number that represents an operating system. Linux uses 83 for - Development Tools partitions containing files and 82 for Linux swap. Chapter 9 - Compiling Software From Source Code Chapter 8

Chapter 10 - Maintaining the Kernel

When you partition a new disk, there is usually one partition on the disk already, containing some sort of variant on the FAT filesystem for Microsoft systems. If you want only a single partition on the disk, just Chapter 12 - Printing change the system ID to Linux with the t command inside fdisk. However, if you want to customize the Chapter 13 - Backups partitions, use d to delete any old partitions and n to add new ones. Chapter 11 - Configuring and Manipulating Peripheral Devices

Chapter 14 - Sharing Files with Samba Chapter Network File Transfer fdisk15is- easy to use because

each command steps you through the partition number and size. In safety feature: fdisk does not actually change the partition table until you Chapter 17with - Buying Hardware for Linux tell it to the w command. If you're uneasy about your changes, or you were just testing something, use Chapter 18 Further Directions q to exit without altering the disk. Chapter 16 -there User Environments addition, is an important

Appendix A - Command Classification Bibliography Here is an

example of fdisk in action on a very small disk. Command input is in boldface:

Index List of Figures

#fdisk /dev/hdc

List of Tables List of Sidebars

Command (m for help): p Disk /dev/hdc: 2 heads, 16 sectors, 247 cylinders Units = cylinders of 32 * 512 bytes Device Boot /dev/hdc1 *

Start 1

End 494

Blocks 7891+

Id 1

System FAT12

Command (m for help): d Partition number (1-4): 1 Command (m for help): n Command action e extended p primary partition (1-4) p Partition number (1-4): 1 Last cylinder or +size or +sizeM or +sizeK (1-247, default 247): 120 Command (m for help): t Partition number (1-4): 1 Hex code (type L to list codes): 83 Command (m for help): p Disk /dev/hdc: 2 heads, 16 sectors, 247 cylinders Units = cylinders of 32 * 512 bytes Device Boot /dev/hdc1

Start 1

Command (m for help): w

End 120

Blocks 1912

Id 83

System Linux

The partition table has been altered! Calling ioctl() re-read partition table. How Linuxto Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

WARNING: No IfStarch you Press have created © 2004 (347 pages)or modified any DOS 6.x partitions, please see the additional This guide describes the innerfdisk workingsmanual of a Linuxpage system for beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and information. sharing printers with Samba. Syncing disks. Table of Contents

When write the Every partition table to the disk with How Linuxyou Works—What Super-User Should Know

the w command, fdisktells the kernel to re-read the the disk and update the system's in-memory partition list (fdisk does not relay the new partition list directly to the kernel). Therefore, you should never write the partition table to a disk that Chapter 2 - Devices, Disks, Filesystems, and the Kernel already a mounted Chapter 3 has - How Linux Boots(attached) filesystem; doing so risks damage to the filesystem. partition from Chapter 1 table - The Basics

Chapter 4

- Essential System Files, Servers, and Utilities

Note ioctl operation that Chapter 5 - The Configuring Your Network

causes the kernel to re-read the partition table can fail on rare occasions. occurs, you need to reboot the system to get the kernel to see the changes.

Chapter 6

such aServices failure - If Network

Chapter 7

- Introduction to Shell Scripts

After writing the partition table, a new list of partition tables should appear on the console. If you don't see - Development Tools this list, run dmesg to see the kernel messages and look at the end of the output. For the fdisk session Chapter 9 - Compiling Software From Source Code earlier in this section, here is what you would see: Chapter 10 - Maintaining the Kernel Chapter 8

Chapter 11 - Configuring and Manipulating Peripheral Devices

hdc:12 hdc1 Chapter - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

Thehda theTransfer disk that Chapter 15 indicates - Network File example, youEnvironments create three Chapter 16 - if User

you repartitioned. The new partition list appears after the colon. For partitions on the disk, the output might appear as hdc: hdc1 hdc2 hdc3.

Chapter 17 - Buying Hardware for Linux

Note Looking at the fdisk session in this section, you may be wondering what the difference between primaryClassification and an extended partition is. The standard PC disk-partitioning scheme originally only Appendix A - a Command Bibliography allowed a maximum of four partitions, 1–4. These are the primary partitions. If you want more partitions, fdisk can designate one of these primary partitions as an extended partition, Index List of Figuresallowing you to place subpartitions in the extended partition. Each of these subpartitions is called List of Tablesalogical partition. Chapter 18 - Further Directions

List of Sidebars

After partitioning a disk, you're not quite ready to attach it to your system because you must put a filesystem on your partition(s) first.

How Linux Works: What Every Super-User Should Know 2.4 Filesystems by Brian Ward

ISBN:1593270356

Press ©of2004 (347and pages) Afilesystem No is aStarch database files directories that you can attach to a Unix system at the root (/) or This guide describes the inner workings of a Linux system beginning file filesystems system and boot process some other directory (like /usr) in a currently attached filesystem. At with one the time, resided onand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and disks and other physical media used exclusively for data storage. However, the tree-like directory structure sharing printers with Samba. and I/O interface of filesystems is quite versatile, so filesystems now perform a variety of tasks. Table of Contents

2.4.1Filesystem Types

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter - Devices, Filesystems,large and the Kernel Linux 2supports anDisks, extraordinarily number

of filesystems, including native designs optimized for as the Windows FAT family, universal filesystems like ISO9660, and others. The Chapter 4 -list Essential System and types Utilitiesof filesystems for data storage; the type names as following includes theFiles, mostServers, common Chapter 5 Configuring Your Network recognized by Linux are in parentheses next to the boldfaced filesystem names. Chapter - How Linux Linux,3foreign typesBoots such

Chapter 6

- Network Services

Extended filesystem ChapterThe 7 Second - Introduction to Shell Scripts every Linux system ChapterNearly 8 - Development Tools Chapter 9

(ext2) is native to Linux. It is fairly quick, and it defragments itself. uses ext2 or its newer, journaled version, ext3.

- Compiling Software From Source Code

Extendedthe filesystems ChapterThird 10 - Maintaining Kernel

(ext3) are ext2 filesystems augmented with journal support. This can make recovery from an abrupt system reboot Chapter 11 - Configuring and Manipulating Peripheral Devicesor failure quicker and less painful. Chapter 12 - Printing

(iso9660) ChapterISO9660 13 - Backups

is a CD-ROM standard. Most CD-ROMs use some variety of ISO9660 extension; Linux supports them. Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

FAT filesystems (msdos, vfat, umsdos) pertain to Microsoft systems. The simple msdos type supports the very primitive monocase variety in MS-DOS systems. For W indows filesystems, use vfat. The Chapter 17 - Buying Hardware for Linux umsdos filesystem is peculiar to Linux; it supports Unix features such as symbolic links on top of an Chapter 18 - Further Directions MS-DOS filesystem. It is also not very common. Appendix A - Command Classification Chapter 16 - User Environments

Bibliography Index

TheReiser filesystem (reiserfs) is relatively new. It supports a journal and is optimized for fairly small files, a condition that often occurs in Unix systems.

List of Figures List of Tables

2.4.2Creating a Filesystem

List of Sidebars

You cannot mount and store files on a partition that does not contain a filesystem. The partitioning process described in Section 2.3.4 does not create any filesystems; you must place the filesystems on the partitions in a separate step. To create a Second Extended (ext2) filesystem, use the mke2fs program on the target device, as in this example for /dev/hdc3: mke2fs /dev/hdc3

Themke2fs program automatically determines the number of blocks in a device and sets some reasonable defaults. Unless you really know what you're doing and feel like reading the mke2fs(8) manual page in detail, you shouldn't change these. When you create a filesystem, you initialize its database, including the superblock and the inode tables. The superblock is at the top level of the database, and it's so important that mke2fs creates a number of backups in case the original is destroyed. You may wish to record a few of the superblock backup numbers whenmke2fs runs, in case you need to recover it later in the event of a disk failure (see Section 2.4.8).

Warning Filesystem creation is a rare task that you should only need to perform after adding a new disk or repartitioning an old disk. You should create a filesystem just once for each new partition that has no preexisting data (or data that you want to remove). Creating a new filesystem on top of an existing filesystem will effectively destroy the old data.

Creating ext3 Filesystems The only substantial difference between ext2 and ext3 filesystems is that ext3 filesystems have a journal file containing changes not yet written to the regular filesystem database. To create an ext3 filesystem, use the-j option to mke2fs: mke2fs -j /dev/ disk_device

Don't worry if you forget the -j option when creating a filesystem. You can add a journal file to an existing filesystem with the utility. Here's an example: How Linux Works: What Every Super-User Should Know by Brian Ward tune2fs -j /dev/hda1

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

When upgrading a printers filesystem ext3, don't forget to change the ext2 to ext3in the /etc/fstab file. sharing with to Samba.

2.4.3Mounting a Filesystem

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1 - the The process Basics On Unix,

of attaching a filesystem is called mounting. When the system boots, the kernel on that data. To mount a filesystem, you must know

Chapter - Devices, Disks, Filesystems, the Kernel reads 2some configuration data andand mounts / based Chapter 3 - How Linux Boots the following: Chapter 4

- Essential System Files, Servers, and Utilities

ChapterThe 5 -filesystem's Configuring Your device Network (such Chapter 6

as a disk partition; where the actual filesystem data resides).

- Network Services

or Scripts design. ChapterThe 7 -filesystem Introductiontype, to Shell

Operating system developers use different types to adapt to their compatibility or for other reasons that aren't necessarily that good. For the ext2-/ext3-based filesystems common on Linux are quite different than the FAT-based Chapterexample, 9 - Compiling Software From Source Code found on many Windows machines. Chaptertypes 10 - Maintaining the Kernel system Tools for backward Chapterparticular 8 - Development

Chapter 11 - Configuring and Manipulating Peripheral Devices

Themount point; that is, the place in the current system's directory hierarchy where the filesystem will be attached. The mount point is always a normal directory. For instance, Linux uses /cdrom as a Chapter 13 - Backups mount point for CD-ROM devices. The mount point need not be directly below /; it may be anywhere Chapter 14 - Sharing Files with Samba on the system. Chapter 15 - Network File Transfer Chapter 12 - Printing

Chapter 16 - User Environments

When mounting a filesystem, the common terminology is "mount a device on a mount point." To learn the current filesystem status of your system, run mount. The output looks like this:

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Appendix A - Command Classification

/dev/hda1 Bibliography

on / type ext2 (rw,errors=remount-ro) on /proc type proc (rw) /dev/hda3 on /usr type ext2 (rw) List of Figures tmpfs on /dev/shm type tmpfs (rw) List of Tables none on /proc/bus/usb type usbdevfs (rw) List of Sidebars proc Index

Each line corresponds to one currently mounted filesystem, with items in this order: The device, such as /dev/hda3. Notice that some of these aren't real devices (proc, for example); these are stand-ins for real device names, because these special-purpose filesystems do not need devices. The word on. The mount point. The word type. The filesystem type, usually in the form of a short identifier. Mount options (in parentheses) — see Section 2.4.5 for more details. To mount a filesystem, use the mount command as follows with the filesystem type, device, and desired mount point: mount -t type device mountpoint For example, to mount the Second Extended filesystem /dev/hdb3 on /home/extra, use this command: mount -t ext2 /dev/hdb3 /home/extra

To unmount (detach) a filesystem, use the umount command:

umountmountpoint How Linux Works: What Every Super-User Should Know

See Section by 2.4.6 Brian forWard a few more long options.

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

2.4.4Filesystem Buffering covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Linux, like other versions of Unix, buffers (caches) all requested changes to filesystems in memory before actually writing the changes to the disk. This cache system is transparent to the user and improves Table of Contents performance because theSuper-User kernel can perform How Linux Works—What Every Should Knowa large collection of file writes at once instead of performing the changes demand. Chapter 1 - Theon Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

When you unmount a filesystem with umount, the kernel automatically synchronizes with the disk. At any - How Linux Boots other time, you can force the kernel to write the changes in its buffer to the disk by running the sync Chapter 4 - Essential System Files, Servers, and Utilities command. If (for whatever reason) you can't unmount a filesystem before you turn off the system, make Chapter 5 - Configuring Your Network sure that you run sync first. Chapter 6 - Network Services Chapter 3

Chapter 7

- Introduction to Shell Scripts

- Development Tools 2.4.5Filesystem Mount Options Chapter 9 - Compiling Software From Source Code Chapter 8

Chapter thetoKernel There10 are- Maintaining many ways change

the mount command behavior. This is often necessary with removable

Chapter Configuring and Manipulating Peripheral Devices media11or-when performing system maintenance. Chapter 12 - Printing Chapter 13 -number Backups The total

of mount options is staggering. The very extensive mount(8) manual page is a good to start and what you can safely ignore.

Chapter 14 - Sharing reference, but it'sFiles hardwith to Samba know where Chapter 15 - Network File Transfer

Options into two rough Chapter 16 fall - User Environments

categories: general options and filesystem-specific options. General options type, which was mentioned earlier. By contrast, a filesystemspecific pertains only to certain filesystem types. To activate a filesystem option, use the -o switch Chapter 18 option - Further Directions followed the option. For example, -o norock turns off Rock Ridge extensions on an ISO9660 Appendix A -by Command Classification filesystem, but it has no meaning for any other kind of filesystem. Bibliography include for specifying filesystem Chapter 17-t - Buying Hardware the for Linux

Index

Short Options

List of Figures List of Tables

The most important List of Sidebars

general options are the following: -r The -r option mounts the filesystem in read-only mode. This has a number of uses, from write protection to bootstrapping. You don't need to specify this option when accessing a read-only device such as a CD-ROM; the system will do it for you (and will also tell you about the read-only status). -n The -n option ensures that mount does not try to update the system mount database, /etc/mtab. The mount operation fails when it cannot write to this file. This is important at boot time, because the root partition (and therefore, the system mount database) are read-only at first. You will also find this option handy if you are trying to fix a system problem in single-user mode (see Section 3.2.4), because the system mount database may not be available at the time. -t The -ttype option specifies the filesystem type.

Long Options Short options like -r are too limited for the ever-increasing number of mount options; there are too few letters in the alphabet to accommodate all possible options. Short options are also troublesome because it is difficult to determine an option's meaning based on a single letter. Many general options and all filesystem-specific options use a longer, more flexible option format. To use long options with mount on the command line, start with -o and supply some keywords. Here is a complete example with the long options in boldface: mount -t vfat /dev/hda1 /dos -o ro,conv=auto There are two long options here, ro and conv=auto. The ro option specifies read-only mode, and it is the same as the -r short option. The conv=auto option is a filesystem option telling the kernel to automatically convert certain text files from the DOS newline format to the Unix style (which will be explained shortly). The most useful long options are the following:

exec,noexec Enables or disables execution of programs on the filesystem. suid,nosuid Enables or disables setuid programs (see Section 1.17). How Linux Works: What Every Super-User Should Know by Brian Ward ro,rw Mounts the filesystem as read-only or read-write.

ISBN:1593270356

No Starch Press © 2004 (347 pages)

This guide describes the inner workings a Linux system beginning the file system boot process andto remount Reattaches a currently mountedoffilesystem at the samewith mount point. Theand only real reason covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and do this is to change mount options, and the most frequent case is making a read-only filesystem sharing printers with Samba. writable. An example of why you might use this is when the system leaves the root in read-only mode during crash recovery. The following command remounts the root in read-write mode (you need the Table of Contents n option because the mount command cannot write to the system mount database when the root is How Linux Works—What Every Super-User Should Know read-only): Chapter 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

-nLinux -oBoots remount Chaptermount 3 - How

/

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 8

- Development Tools

command ChapterThe 6 -preceding Network Services

assumes that the correct device listing for / is in /etc/fstab (explained in the next section). If it is not, you must specify the device. Chapter 7 - Introduction to Shell Scripts norock,nojoliet (ISO9660 filesystem) Disables Rock Ridge (Unix) or Joliet (Microsoft) extensions. - Compiling Software From Source Code Be warned that plain, raw ISO9660 is really ugly. Chapter 10 - Maintaining the Kernel Chapter 9

Chapter 11 - Configuring and Manipulating Peripheral Devices

conv=rule (FAT-based filesystems) Converts the newline characters in files based on rule, which can be binary,text, or auto. The default is binary, which disables any character translation. To Chapter 13 - Backups treat all files as text, use text. The auto setting converts files based on their extension. For Chapter 14 - Sharing Files with Samba example, a .jpg file gets no special treatment, but a .txt file does. Be careful with this option, Chapter 15 - Network File Transfer because it can damage files. You may want to use it in read-only mode. Chapter 12 - Printing

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

2.4.6The /etc/fstab Filesystem Table

Chapter 18 - Further Directions

Appendix A - Command Classification Bibliography To mount

filesystems at boot time and take the drudgery out of the mount command, Linux systems keep list of filesystems and options in /etc/fstab. This is a plain text file in a very simple List of Figures format, as this example shows: Index a permanent List of Tables List of Sidebars

/dev/hda1 /dev/hda2 /dev/hda3 proc /dev/hdc

/ none /usr /proc /cdrom

ext2 swap ext2 proc iso9660

defaults,errors=remount-ro sw defaults defaults ro,user,nosuid,noauto

0 0 0 0 0

1 0 2 0 0

Each line corresponds to one filesystem, broken into six fields: The device. Notice that the /proc entry has a stand-in device. The mount point. The filesystem type. You may not recognize swap, for /dev/hda2. This is a swap partition (see Section 2.5). Options. Backup information for the dump command; dump does not see common use, but you should always specify this field with a 0. The filesystem integrity test order (see the fsck command in Section 2.4.8). To ensure that fsck always runs on the root first, you should always set this to 1 for the root filesystem and 2 for any other filesystems on a hard disk. Use 0 to disable the bootup check for everything else, including CD-ROM drives, swap, and the /proc filesystem. When using mount, you can take some shortcuts if the filesystem you want to work with is in /etc/fstab. For the example fstab above, to mount a CD-ROM, you need only run mount /cdrom You can also try to mount all entries in /etc/fstab that do not contain the noauto option at once, with

this command: mount -a

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced as networking, firewalls,fstab development tools, devicedefaults, management,errors, shell scripts, and You may have noticed sometopics new such options in the preceding listing, namely sharing printers with Samba. noauto, and user. These aren't covered in Section 2.4.5 because they don't make any sense outside of the/etc/fstab file. The meanings are as follows: Table of Contents How Linux Works—What Every Super-User Should Know

defaults This uses the mount defaults — read-write mode, enable device files, executables, the - The Basics setuid bit, and so on. You should use this when you don't want to give the filesystem any special Chapter 2 - Devices, Disks, Filesystems, and the Kernel options, but you do want to fill all fields in /etc/fstab. Chapter 1 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chaptererrors 5 - Configuring Your Networkparameter This ext2-specific

sets the system behavior if there is trouble mounting a is normally errors=continue, meaning that the kernel should return an Chaptererror 7 - code Introduction to Shell Scripts To get the kernel to try again in read-only mode, use and keep running. Chaptererrors=remount-ro. 8 - Development Tools The errors=panic setting tells the kernel (and your system) to halt when Chapterthere 9 - Compiling Software From Source Code is a problem. Chapterfilesystem. 6 - Network Services The default

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

This Chapternoauto 12 - Printing

option tells a mount -a command to ignore the entry. Use this to prevent a boot-time device, such as a CD-ROM or floppy drive.

of a removable-media Chaptermount 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

user This option allows normal users to run mount on this entry. This can be handy for enabling access to CD-ROM drives. Because users can put a setuid-root file on removable media with another Chapter 17 - Buying Hardware for Linux system, this option also sets nosuid,noexec, and nodev (to bar special device files). The fstab Chapter 18 - Further Directions example in this section explicitly sets nosuid. Chapter 16 - User Environments

Appendix A - Command Classification Bibliography

2.4.7Filesystem Capacity

Index

List of Figures List Toofview Tables the

size and utilization of your currently mounted filesystems, use the df command. The output

List of Sidebars looks like this:

Filesystem /dev/hda1 /dev/hda3

1024-blocks 1011928 17710044

Used 71400 9485296

Available Capacity Mounted on 889124 7% / 7325108 56% /usr

The listing has the following fields: Filesystem The filesystem device 1024-blocks The total capacity of the filesystem in blocks of 1024 bytes Used The number of occupied blocks Available The number of free blocks Capacity The percentage of blocks in use Mounted on The mount point It is relatively easy to see that the two filesystems here are roughly 1GB and 17.5GB in size. However, the capacity numbers may look a little strange because 71400 + 889124 does not equal 1011928, and 9485296 does not constitute 56 percent of 17710044. In both cases, 5 percent of the total capacity is unaccounted for. Nevertheless, the space is there. These hidden blocks are called the reserved blocks, and only the superuser may use the space if the rest of the partition fills up. This keeps system servers from immediately failing when they run out of disk space. If your disk fills up and you need to know where all of those space-hogging, illegal MP3s are, use the du

command. With no arguments, du prints the disk usage of every directory in the directory hierarchy, starting at the current working directory. (That's kind of a mouthful, so just run cd /; du to get the idea. Press CONTROL-C when youWhat get bored.) The du -s command How Linux Works: Every Super-User Should Know turns on summary mode to print only the grand total. If *. byyou Brianwant Wardto evaluate a particular directory, change to that directory and run du -sISBN:1593270356 No Starch Press © 2004 (347 pages)

blocks in df and du output is not the POSIX standard. Some systems insist on Note 1024-byte This guide describes the inner workings of a Linux system beginning with the file system and boot process and displaying the numbers 512-byte blocks. To getdevelopment around this, usedevice the -k option (both utilities covering advanced topics in such as networking, firewalls, tools, management, shell scripts, and sharingthis). printers with support The dfSamba. program also supports the -m option to list capacities in one-megabyte blocks. Table of Contents

TheLinux following pipeline is aSuper-User handy way to create How Works—What Every Should Know Chapter the terminal 1 - TheatBasics the same Chapter 2

a searchable output file (du_out) and see the results on

time.

- Devices, Disks, Filesystems, and the Kernel

Chapter - How Linux Boots du | 3tee du_out Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

2.4.8Checking - Introduction to and Shell Scripts Repairing Filesystems

Chapter 7 Chapter 8

- Development Tools

The optimizations UnixFrom filesystems offer Chapter 9 - Compiling that Software Source Code

are made possible by a sophisticated database-like work seamlessly, the kernel has to trust that there are no errors in a mounted Otherwise, serious errors such as data loss and system crashes can happen. Chapter 11 -filesystem. Configuring and Manipulating Peripheral Devices mechanism. For filesystems Chapter 10 - Maintaining the Kernelto Chapter 12 - Printing

The most Chapter 13 - frequent Backups

cause of a filesystem error is shutting down the system in a rude way (for example, with The system's filesystem cache in memory may not match the data on the disk, and the system also may be in the process of altering the filesystem when you decide to give the Chapter 15 - Network File Transfer computer kick. Even though a new generation of filesystems supports journals to make filesystem Chapter 16 - a User Environments corruption far less common, you should always shut the system down properly (see Section 3.1.5). Chapter 17 - Buying Hardware for Linux Furthermore, filesystem checks are still necessary every now and then as sanity checks. Chapter 18 - Further Directions the power switch Files on the Chapter 14 - Sharing withcomputer). Samba

Appendix A - Command Classification

You need to remember one command name to check a filesystem: fsck. However, there is a different version of this tool for each filesystem type that Linux supports. The information presented here is specific Index to second and third extended (ext2/ext3) filesystems and the e2fsck utility. You generally don't need to List of Figures typee2fsck, though, unless fsck can't figure out the filesystem type, or you're looking for the e2fsck List of Tables manual page. List of Sidebars Bibliography

To run fsck in interactive manual mode, use the device or the mount point (in /etc/fstab) as the argument. For example: fsck /dev/hdd1

Warning Never use fsck on a mounted filesystem. The kernel may alter the disk data as you run the check, causing mismatches that can crash your system and corrupt files. There is only one exception. If you mount the root as read-only in single user mode, you may use fsck on the root filesystem. In manual mode, fsck prints verbose status reports on its passes, which should look something like this when there are no problems: Pass 1: Checking inodes, blocks, and sizes Pass 2: Checking directory structure Pass 3: Checking directory connectivity Pass 4: Checking reference counts Pass 5: Checking group summary information /dev/hdd1: 11/1976 files (0.0% non-contiguous), 265/7891 blocks If fsck finds a problem in manual mode, it stops and asks you a question relevant to fixing the problem. These questions deal with the internal structure of the filesystem, such as reconnecting loose inodes and clearing blocks. The reconnection business means that fsck found a file that doesn't appear to have a name; reconnecting places the file in the lost+found directory filesystem as a number. You need to guess the name based on the content of the file. In general, it's pointless to sit through the fsck process if you just made the mistake of an impolite

shutdown. e2fsck has a -p option to automatically fix silly problems without asking you, aborting if there is a serious error. This is so common that Linux distributions run some variant of fsck -p at boot time (fsck -a isHow alsoLinux common). Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

However, if No youStarch suspect there is some major disaster, such as a hardware failure or device Pressthat © 2004 (347 pages) misconfiguration, you need to decide on a course of action, because fsck can really mess up a filesystem This guide describes the inner workings of a Linux system beginning with the file system and boot process and with larger problems. A telltale sign of as a serious problem is a lot of questions in manual mode.shell scripts, and covering advanced topics such networking, firewalls, development tools, device management, sharing printers with Samba.

If you think that something really bad happened, try running fsck -n to check over the filesystem without modifying anything. If there's some sort of problem with the device configuration (an incorrect number of Table of Contents blocks the partition table, loose cables, whatever) that you think you can fix, then fix it before running How Linuxin Works—What Every Super-User Should Know fsck 1for-real. You're likely to lose a lot of data otherwise. Chapter The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

If you suspect that only the superblock, a key filesystem database component, is corrupt (for example, - How Linux Boots someone wrote to the beginning of the disk partition), you might be able to recover the filesystem with one Chapter 4 - Essential System Files, Servers, and Utilities of the superblock backups that mke2fs creates. Use fsck -b num to replace the corrupted superblock Chapter 5 - Configuring Your Network with an alternate at block num. Chapter 6 - Network Services Chapter 3

Chapter 7

- Introduction to Shell Scripts

You may- not know where to find a backup superblock, because you didn't write the numbers down when Development Tools mke2fs ran. If the filesystem was created with the default values, you can try mke2fs -n on the device Chapter 9 - Compiling Software From Source Code to view a list of superblock backup numbers without destroying your data (again, make deadsure that Chapter 10 - Maintaining the Kernel you're using -n, because you'll really tear up the filesystem otherwise). Chapter 8

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

If the device still appears to function properly except for a few small parts, you can run fsck -c before a manual fsck to search for bad blocks. Such a failure is somewhat rare.

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Checking ext3 Filesystems

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

You normally do not need to check ext3 filesystems because the journal ensures data integrity. However, you may wish to mount an ext3 filesystem in ext2 mode. The kernel will not mount an ext3 filesystem that Appendix A - Command Classification contains a non-empty journal (if you don't shut your system down cleanly, you can expect that the journal Bibliography contains some data). To flush the journal in an ext3 filesystem to the regular filesystem database, run Index e2fsck as follows: Chapter 18 - Further Directions

List of Figures List of Tables

e2fsck -fy /dev/disk_device

List of Sidebars

The Worst Case Disk problems that are worse in severity leave you with few choices: You can try to pull the entire filesystem from the disk with dd and transfer it to a partition on another disk that's the same size. You could try to patch up the filesystem as well as you can, mount it in read-only mode, and salvage what you can. In both cases, you still need to repair the filesystem before you mount it (unless you feel like picking through the raw data by hand). To answer y to all of the fsck questions, use fsck -y, but do this as a last resort. Note There is an advanced utility called debugfs for users with in-depth knowledge of filesystems, or for those who feel like experimenting on a filesystem that isn't important. If you're really desperate, such as in the event of a catastrophic disk failure without backups, there isn't a lot you can do other than try to get a professional service to "scrape the platters."

2.4.9Special-Purpose Filesystems Not all filesystems represent storage on physical media. Most versions of Unix have filesystems that serve as system interfaces. This idea goes back along way; the /dev mechanism is an early model of using files for I/O interfaces. The /proc idea came from the eighth edition of research Unix [Killian]. Things really got rolling when the people at Bell Labs (including many of the original Unix designers) created Plan 9 [Bell Labs], a research operating system that took filesystem abstraction to a whole new level. The special filesystem types in common use on Linux include the following: proc, mounted on /proc. The name "proc" is actually an abbreviation of "process." Each numbered

directory inside /proc is actually the process ID of a current process on the system, and the files in those directories represent various aspects of the processes. /proc/self represents the current process.How TheLinux LinuxWorks: proc What filesystem a great deal of additional kernel and hardware Every includes Super-User Should Know information, such as /proc/cpuinfo. Purists shudder and say that this additional information does ISBN:1593270356 by Brian Ward not belong in /proc, rather in /dev or some other directory, but it's probably too late to change it No Starch Press ©but 2004 (347 pages) in LinuxThis now. guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printerson with Samba. usbdevfs, mounted /proc/bus/usb. Programs that interact with the USB interface and its devices often need the files here. The files in a usbdevfs filesystem provide interesting information on Table of Contents the bus status. How Linux Works—What Every Super-User Should Know

mounted Chaptertmpfs, 1 - The Basics

on /dev/shm. You can employ your physical memory and swap space as temporary you like, using the size and nr_blocks long toLinux control the maximum size. However, you must be careful not to pour things into a tmpfs, Chapteroptions 3 - How Boots your System systemFiles, will Servers, eventually run out of memory, and programs will start to crash. For years, Chapterbecause 4 - Essential and Utilities used version of tmpfs for /tmp, and this is a frequent problem on long-running ChapterSun 5 -systems Configuring Youra Network Chaptersystems. 6 - Network Services with tmpfs. You can mount Chapterstorage 2 - Devices, Disks, Filesystems, and thetmpfs Kernelwherever

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 2.5 SwapHow and Virtual Memory by Brian Ward

ISBN:1593270356

Noof Starch © 2004Linux (347 pages) If you run out real Press memory, has a virtual memory system that automatically moves memory This to guide inner workings of called a Linux swapping, system beginning with the the file system and boot processare and pages (chunks) anddescribes from a the hard disk. This is because pages of idle programs covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and swapped to sharing the diskprinters in exchange for active pages residing on the disk. The disk area used to store memory with Samba. pages is called swap space. Table Contents Theof free command's

output includes the current swap usage in kilobytes as follows:

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

... Chapter 3 Swap: Chapter 4

total used free ... ... ... - How Linux Boots 514072 189804 324268 - Essential System Files, Servers, and Utilities

- Introduction to Shell Scripts 2.5.1Using a Disk Partition as Swap Space

Chapter 7 Chapter 8 Chapter To use9

- Development Tools

- Compiling Software From an entire disk partition asSource swap,Code follow these steps:

Chapter 10 - Maintaining the Kernel

1. Make certain that the partition is empty.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

2. Runmkswapdev, where dev is the partition's device. This command puts a swap signature on the partition.

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter - Network File Transfer 3. 15Execute swapon dev to

register the space with the kernel.

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux After creating a swap partition, you Chapter 18 - space Furtheras Directions the swap soon as

can put a new swap entry in your /etc/fstab to make the system use the machine boots. This entry is from the fstab example in Section 2.4.6:

Appendix A - Command Classification Bibliography

/dev/hda2

Index

none

swap

sw

0 0

List of Figures List of Tables List of Sidebars

2.5.2Using a File as Swap Space You can also use a regular file as swap space. It's not quite as fast as a swap partition, but if you're in a pinch where you would be forced to repartition the disk to use a swap partition, using a file as swap space works fine. Use these commands to create an empty file, initialize it as swap, and add it to the swap pool: dd if=/dev/zero of=swap_file bs=1024k count=num_mb mkswapswap_file swaponswap_file

Here, swap_file is the name of the new swap file, and num_mb is the desired size, in megabytes. To remove a swap partition or file from the kernel's active pool, use the swapoff command.

2.5.3How Much Swap do You Need? At one time, the Unix conventional wisdom said that you should always reserve at least twice as much swap as you have real memory. The enormous disk and memory capacities now available cloud the issue. On one hand, disk space is so plentiful that double the memory size may seem inadequate, given the amount of disk space available. On the other hand, you may never even dip into your swap space because you have so much real memory. Some things never change, though. Reserve two to five times as much disk space as you have real memory for swap. It doesn't make sense to go any lower, because you may actually risk running out of memory. If you go higher and actually intend to use all of this swap space, you will likely suffer serious performance problems because the system will spend all of its time swapping (a condition known as thrashing).

How Linux Works: What Every Super-User Should Know Chapter 3: How Linux Boots by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

You now know the physical structure of a Linux system, what the kernel is, and how to work with processes. This chapter teaches you how the system starts (boots) — that is, how the kernel gets into Table of Contents memory and how the regular system processes get started. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics As it turns out, there isn't much to the boot process:

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

1. 3A -boot finds Chapter How loader Linux Boots

the kernel image on the disk, loads it into memory, and starts it.

2. The kernel initializes the devices and its drivers.

Chapter 6

- Network Services 3. The kernel mounts the root filesystem.

Chapter 7

- Introduction to Shell Scripts

Chapter - Development Tools 4. 8The kernel starts a program Chapter 9

called init.

- Compiling Software From Source Code

5. 10init sets thethe rest of the Chapter - Maintaining Kernel

processes in motion.

Chapter 11 - Configuring and Manipulating Peripheral Devices

6. 12The last processes Chapter - Printing

that init starts as part of the boot sequence allow you to log in.

Chapter 13 - Backups

Identifying each stage of the boot process is invaluable in fixing boot problems and understanding the system as a whole. To start, zero in on the boot loader, which is the initial screen or prompt you get after Chapter 15 - Network File Transfer the computer does its power-on self-test, asking which operating system to run. After you make a choice, Chapter 16 - User Environments the boot loader runs the Linux kernel, handing control of the system to the kernel. Chapter 17 - Buying Hardware for Linux Chapter 14 - Sharing Files with Samba

Chapter 18 - Further Directions

There is a detailed discussion of the kernel elsewhere in this book (Section 2.2 explains the role of the kernel, and Chapter 10 tells you how to build one yourself), but this chapter covers the kernel initialization Bibliography stage, the stage when the kernel prints a bunch of messages about the hardware present on the system. Index The kernel starts init just after it displays a message proclaiming that the kernel has mounted the root List of Figures filesystem: Appendix A - Command Classification

List of Tables

List of Sidebars

VFS: Mounted root (ext2 filesystem) readonly.

Soon after, you will see a message about init starting, followed by system service startup messages, and finally you get a login prompt of some sort.

Note On Red Hat Linux, the init note is especially obvious, because it "welcomes" you to "Red Hat Linux." All messages thereafter show success or failure in brackets at the right-hand side of the screen. Most of this chapter deals with init, because it is the part of the boot sequence where you have the most control. Section 3.2 deals with the boot loaders.

3.1 init

How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

No Starch Press © 2004init. (347 pages) There is nothing special about It is a program just like any other on the Linux system, and you'll find This guide the inner workingsThe of a Linux beginning with file system and boot process and it in /sbin along withdescribes other system binaries. main system purpose of init isthe to start and stop other programs covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and in a particular sequence. All you have to know is how this sequence works. sharing printers with Samba.

There are a few different variations, but most Linux distributions use the System V style discussed here. use a simpler version that resembles the BSD init, but you are unlikely to encounter How Linux Works—What Every Super-User Should Know this.

Table of Contents Some distributions Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

3.1.1Runlevels - How Linux Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

At any5 given time onYour a Linux system, Chapter - Configuring Network

a certain base set of processes are running. This state of the and it is denoted with a number from 0 through 6. The system spends most of its time in a single to runlevel. However, when you shut the machine down, init switches to a different Chapter 7 - Introduction Shell Scripts runlevel order to terminate the system services in an orderly fashion and to tell the kernel to stop. Yet Chapter 8 in - Development Tools another is Software for single-user mode, discussed in Section 3.2.4. Chapter 9 runlevel - Compiling From Source Code machine called Services its runlevel, Chapter 6 -is Network

Chapter 10 - Maintaining the Kernel

The easiest way to get handle on Peripheral runlevelsDevices is to examine Chapter 11 - Configuring andaManipulating Look for line like Chapter 12 -aPrinting

the init configuration file, /etc/inittab.

the following:

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba id:5:initdefault: Chapter 15 - Network File Transfer Chapter 16 - User Environments

This line that the default Chapter 17 -means Buying Hardware for Linuxrunlevel with four separated Chapter 18 -fields Further Directions

on the system is 5. All lines in the inittab file take this form, by colons occuring in the following order:

Appendix A - Command Classification

A unique Bibliography Index

identifier (a short string, such as id in the preceding example)

The applicable runlevel number(s)

List of Figures List of Tables

The action that init should take (in the preceding example, the action is to set the default runlevel to 5)

List of Sidebars

A command to execute (optional) There is no command to execute in the preceding initdefault example because a command doesn't make sense in the context of setting the default runlevel. Look a little further down in inittab, until you see a line like this: l5:5:wait:/etc/rc.d/rc 5

This particular line is important because it triggers most of the system configuration and services through therc*.d and init.d directories (see Section 3.1.2). You can see that init is set to execute a command called /etc/rc.d/rc 5 when in runlevel 5. The wait action tells when and how init runs the command: run rc 5 once when entering runlevel 5, and then wait for this command to finish before doing anything else. There are several different actions in addition to initdefault and wait, especially pertaining to power management, and the inittab(5) manual page tells you all about them. The ones that you're most likely to encounter are explained in the following sections.

respawn Therespawn action causes init to run the command that follows, and if the command finishes executing, to run it again. You're likely to see something similar to this line in your inittab file: 1:2345:respawn:/sbin/mingetty tty1

Thegetty programs provide login prompts. The preceding line is for the first virtual console (/dev/tty1), the one you see when you press ALT-F1 or CONTROL-ALT-F1 (see Section 3.3 ). The respawn action brings the login prompt back after you log out.

ctrlaltdel Thectrlaltdel How Linux action Works: controls What what Every theSuper-User system does Should when Know you press CONTROL-ALT-DELETE on a ISBN:1593270356 virtual console. by Brian On most Ward systems, this is some sort of reboot command, using the shutdown command, No Starch Press © 2004 (347 pages) which is covered in Section 3.1.5. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

sysinit

Thesysinit action is the very first thing that init should run when it starts up, before entering any Table of Contents runlevels. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

3.1.2How Processes Start - Devices, Disks, Filesystems,in andRunlevels the Kernel

Chapter 2 Chapter 3

- How Linux Boots

You are readySystem to learn how initand starts the Chapter 4 now - Essential Files, Servers, Utilities

system services, just before it lets you log in. Recall this

inittab from earlier: Chapter 5 - line Configuring Your Network Chapter 6

- Network Services

Chapter 7 - Introduction to Shell Scripts l5:5:wait:/etc/rc.d/rc 5 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter This small 10 - Maintaining line triggers the many Kernel other

programs. rc stands for run commands, and you will hear people refer So, where are these commands, anyway?

Chapter - Configuring Manipulating Peripheral Devices to the 11 commands asand scripts, programs, or services. Chapter 12 - Printing

For runlevel 5, in Chapter 13 - Backups

this example, the commands are probably either in /etc/rc.d/rc5.d or /etc/rc5.d. 2 uses rc2.d, and so on. You might find the following items in the

Runlevel uses rc1.d, Chapter 14 - 1Sharing Files withrunlevel Samba rc5.d15directory: Chapter - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux S10sysklogd S20ppp

Chapter 18 - Further Directions S12kerneld S25netstd_nfs Appendix A - Command Classification S15netstd_init S30netstd_misc Bibliography S18netbase Index S20acct List of Figures S20logoutd

S45pcmcia S89atd S89cron

S99gpm S99httpd S99rmnologin S99sshd

List of Tables List of Sidebars

Therc 5 command starts programs in this runlevel directory by running the following commands: S10sysklogd start S12kerneld start S15netstd_init start S18netbase start ... ... S99sshd start Notice the start argument in each command. The S in a command name means that the command should run in start mode, and the number (00 through 99) determines where in the sequence rc starts the command. Therc*.d commands are usually shell scripts that start programs in /sbin or /usr/sbin. Normally, you can figure out what one of the commands actually does by looking at the script with less or another pager program. You can start one of these services by hand. For example, if you want to start the httpd Web server program manually, run S99httpd start. Similarly, if you ever need to kill one of the services when the machine is on, you can run the command in the rc*.d directory with the stop argument (S99httpd stop, for instance). Some rc*.d directories contain commands that start with with K (for "kill," or stop mode). In this case, rc runs the command with the stop argument instead of start. You are most likely to encounter K commands in runlevels that shut the system down.

3.1.3Adding and Removing Services If you want to add, delete, or modify services in the rc*.d directories, you need to take a closer look at

the files inside. A long listing reveals a structure like this: How What Every Should Know lrwxrwxrwx . Linux . . Works: S10sysklogd ->Super-User ../init.d/sysklogd ISBN:1593270356 by Brian Ward lrwxrwxrwx . . . S12kerneld -> ../init.d/kerneld No . Starch © 2004 (347 pages) lrwxrwxrwx . .Press S15netstd_init -> ../init.d/netstd_init This.guide the inner workings of a Linux system beginning with the file system and boot process and lrwxrwxrwx . .describes S18netbase -> ../init.d/netbase covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and ... sharing printers with Samba. Table Contents Theofcommands

in an rc*.d directory are actually symbolic links to files in an init.d directory, usually in these links so that they can use the same startup scripts Chapter 1 - The Basics for all runlevels. This convention is by no means a requirement, but it often makes organization a little Chapter 2 - Devices, Disks, Filesystems, and the Kernel easier. How Linux Every Super-User Shouldcontain Know /etc orWorks—What /etc/rc.d. Linux distributions

Chapter 3

- How Linux Boots

Chapter 4 - Essential Files, Servers, andinit.d Utilities To prevent one of System the commands in the

directory from running in a particular runlevel, you might in the appropriate rc*.d directory. This does work, but if you make a Chapter 6 and - Network mistake ever Services need to put the link back in place, you might have trouble remembering the exact name Chapter - Introduction Shell Scripts remove links in the rc*.d directories, but rather, add an underscore of the 7link. Therefore,toyou shouldn't Chapter Development (_) to 8the- beginning ofTools the link name like this: Chapter 5 removing - Configuring Networklink think of theYour symbolic

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

mv S99httpd _S99httpd

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13time, - Backups At boot rc ignores

_S99httpd because it doesn't start with S or K. Furthermore, the original name is still obvious, and you have quick access to the command if you're in a pinch and need to start it by hand.

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16a- service, User Environments To add you must

create a script like the others in the init.d directory and then make a directory. You may need to read Chapter 7 first if you aren't familiar Chapter 18 - scripts. Further Directions with shell However, the easiest way to write a script is to examine the scripts already in init.d, Appendix - Command make aAcopy of oneClassification that you understand, and modify the copy. Chapter 17 -link Buying Hardware forrc*.d Linux symbolic in the correct

Bibliography Index When

adding a service, make sure that you choose an appropriate place in the boot sequence to start the service starts too soon, it may not work, due to a dependency on some other service. For List non-essential of Tables services, most systems administrators prefer numbers in the 90s, after most of the services List that of Sidebars came with the system. List service. of Figures If the

Linux distributions usually come with a command to enable and disable services in the rc*.d directories. For example, in Debian, the command is update-rc.d, and in Red Hat Linux, the command is chkconfig. Graphical user interfaces are also available. Using these programs helps keep the startup directories consistent and helps with upgrades. HINT One of the most common Linux installation problems is an improperly configured XFree86 server that flicks on and off, making the system unusable on console. To stop this behavior, boot into single-user mode and alter your runlevel or runlevel services. Look for something containing xdm,gdm or kdm in your rc*.d directories, or your /etc/inittab.

3.1.4Controlling init Occasionally, you need to give init a little kick to tell it to switch runlevels, to re-read the inittab file, or just to shut down the system. Because init is always the first process on a system, its process ID is always 1. You can control init with telinit. For example, if you want to switch to runlevel 3, use this command: telinit 3 When switching runlevels, init tries to kill off any processes that aren't in the inittab file for the new runlevel. Therefore, you should be careful about changing runlevels. When you need to add or remove respawning jobs or make any other change to the inittab file, you must tell init about the change and cause it to re-read the file. Some people use kill -HUP 1 to tell init to do this. This traditional method works on most versions of Unix, as long as you type it correctly. However, you can also run this telinit command: telinit q

You can also use telinit s to switch to single-user mode (see Section 3.2.4). How Linux Works: What Every Super-User Should Know by Brian Ward

3.1.5Shutting Down No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

covering how advanced topics such as networking, management, shell machine scripts, and init also controls the system shuts down andfirewalls, reboots.development The propertools, waydevice to shut down a Linux printers with Samba. is to use thesharing shutdown command.

There are two basic Table of Contents

ways to use shutdown. If you halt the system, it shuts the machine down and keeps it use this command:

down. make the machine halt immediately, How LinuxTo Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 - Devices, Disks, Filesystems, and the Kernel shutdown -h now Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 -modern Configuring Your Network On most machines with

reasonably recent versions of Linux, a halt cuts the power to the machine. For a reboot, use -r instead of -h.

Chapter 6 -also Network Services You can reboot the machine. Chapter 7

- Introduction to Shell Scripts

The shutdown processTools takes Chapter 8 - Development

several seconds. You should never reset or power off a machine during this time to shut down. This argument is mandatory, but there are many 10 ways of specifying it. If you want the machine to go down sometime in the future, one way is to use Chapter - Maintaining the Kernel +n, where n is the number of minutes shutdown should wait before doing its work. For other options, look Chapter 11 - Configuring and Manipulating Peripheral Devices at the 12 shutdown(8) manual page. Chapter - Printing stage.9In -the preceding example, now is the Chapter Compiling Software From Source Code

Chapter 13 - Backups

To make system in ten Chapter 14 -the Sharing Files reboot with Samba

minutes, run this command:

Chapter 15 - Network File Transfer Chapter 16 - User shutdown -rEnvironments +10 Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

On Linux, shutdown notifies anyone Appendix A - Command Classification

logged on that the machine is going down, but it does little real work. a time other than now,shutdown creates a file called /etc/nologin. When this file is present, the system prohibits logins by anyone except the superuser. Index If you specify Bibliography List of Figures

When system List of Tables

shutdown time finally arrives, shutdown tells init to switch to runlevel 0 for a halt and a reboot. When init enters runlevel 0 or 6, all of the following takes place, which you can verify by looking at the scripts inside rc0.d and rc6.d:

runlevel 6 for List of Sidebars

1. init kills every process that it can (as it would when switching to any other runlevel). 2. The initial rc0.d/rc6.d commands run, locking system files into place and making other preparations for shutdown. 3. The next rc0.d/rc6.d commands unmount all filesystems other than the root. 4. Furtherrc0.d/rc6.d commands remount the root filesystem read-only. 5. Still more rc0.d/rc6.d commands write all buffered data out to the filesystem with the sync program (see Section 2.4.4). 6. The final rc0.d/rc6.d commands tell the kernel to reboot or stop with the reboot,halt, or poweroff program. Thereboot and halt programs behave differently for each runlevel, potentially causing confusion. By default, these programs call shutdown with the -r or -h options. but if the system is already at the halt or reboot runlevel, the programs tell the kernel to shut itself off immediately. If you really want to shut your machine down in a hurry (disregarding any possible damage from a disorderly shutdown), use the -f option.

Linux Works: What Every Super-User Should Know 3.2 BootHow Loaders by Brian Ward

ISBN:1593270356

No Starch Press © 2004 pages) Before the kernel runs init, a (347 boot loader starts the kernel. On occasion, you need to tell the boot loader This guide describes the innersystems, workings of a Linux system beginning modes. with the file system and boot process and to load different kernels or operating and to start in different This is especially important covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and when trying sharing to fix aprinters systemwith that has a problem that prevents a full boot. To fix such a problem, you may Samba. need single-user mode or an alternate kernel. Table of Contents

The boot loader loads a kernel image into memory and hands control of the CPU to the new image, parameters are simple text strings like -s for booting in Chapter 1 - The Basics single-user mode and root=partition for using partition as the root filesystem instead of the Chapter 2 - Devices, Disks, Filesystems, and the Kernel default. You can specify a runlevel number as a parameter to make the system boot into a runlevel other Chapter 3 - How Linux Boots than the default. How Linux Works—What Should Know possibly supplying itEvery with Super-User some parameters. These

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 in - Configuring Your Network To type a kernel name and parameters,

however, you first need to know how to get to a boot prompt. different boot loaders out there, and because you can control a boot Chapter 7 behavior, - Introduction to Shell Scripts loader's Linux distributions customize to their hearts' content. Chapter 6 - Network Services Unfortunately, there are several Chapter 8

- Development Tools

Chapter 9 -sections Compilingtell Software Fromto Source The next you how get toCode a boot Chapter 10 - to Maintaining theto Kernel you need know how install

prompt in order to enter a kernel name and parameters. If a boot loader or change its configuration, see Section 10.5.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

3.2.1LILO

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

LILO (Linux Loader) has been around for almost as long as the Linux kernel. The LILO boot prompt usually ends with boot:. If your system boots with LILO, it's likely that you get a fancy screen of graphics at boot time, because this is the default for many distributions, including Red Hat Linux. If you see a screen like Chapter 17 - Buying Hardware for Linux this, look for a part that reads "Press Control-x for text mode." If you see that message, type CONTROL-X Chapter 18 - Further Directions to get to the boot prompt. Appendix A - Command Classification Chapter 15 - Network File Transfer Chapter 16 - User Environments

Bibliography

If the system defaults to text mode, look at the prompt as soon as it appears. If the prompt says LILO with nothing else, press the SHIFT key to get the rest of the boot prompt to appear. On the other hand, if you List of Figures get a boot prompt immediately, you need to watch out, because the system likely will boot if you don't type List of Tables anything in a certain amount of time. Index

List of Sidebars

Once you're at a LILO boot prompt, press the TAB key to show a list of kernel and operating system options. The default kernel name is probably something like linux. To boot this kernel with no options, enterlinux. To use options, specify them after the kernel name: linuxoption1 option2 ...

For example, to boot the system in single-user mode, type this: linux -s

Or, to boot linux in single-user mode with the root filesystem as /dev/hda3 instead of your normal default, type this: linux root=/dev/hda3 -s

3.2.2GRUB GRUB stands for Grand Unified Bootloader, a system that is slowly replacing LILO. GRUB has plenty of whiz-bang features, but most important is its ability to navigate filesystems, so you can read files without loading a kernel. Wiseguy Solaris and BSD administrators like to say that they have enjoyed this capability for some time. GRUB has a menu interface that's easy enough to navigate, but if you need to boot from a different kernel, change the root partition, or supply extra kernel parameters, you should get into the mini-shell. Press c at the menu to get this prompt: grub>

Let's say that you want to boot the kernel at /boot/vmlinuz with a root of /dev/hda3. Furthermore, How Linux Works: What Every Super-User Should Know your system is messed up, so you need single-user mode with the -s kernel option. Type the following at ISBN:1593270356 by Brian Ward the GRUB prompt: No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and root (hd0,2) sharing printers with Samba. kernel /boot/vmlinuz root=/dev/hda3 -s boot Table of Contents How Linux Works—What Every Super-User Should Know Chapter Theroot 1 - The (hd0,2) Basics

line sets GRUB's idea of the current root partition — that is, the filesystem where hard drive (that is, the first disk that GRUB finds; for Chapter example, 3 - the HowLinux Linux Boots device /dev/hda if this is your first hard disk). However, 2 specifies the third partition Chapter (/dev/hda3) 4 - Essential because System GRUB Files, Servers, partition and numbers Utilities start at 0. Chapter GRUB2 expects - Devices, to Disks, find the Filesystems, kernel. hd0 and the is the Kernel first

Chapter 5

- Configuring Your Network

The word sets a Chapter 6 - kernel Network Services

kernel image and its parameters. /boot/vmlinuz refers to a kernel image file on (hd0,2). Unfortunately, GRUB does not normally pass the information from the preceding root() Chapter 7 - Introduction to Shell Scripts line on8 to- the kernel, so you should always specify root=partition as a kernel parameter. Chapter Development Tools Chapter 9

- Compiling Software From Source Code

can combine the Note Chapter 10 - You Maintaining the Kernel Chapter 11 Chapter 12

root and kernel lines by preceding the kernel image with the GRUB root partition. Therefore, the two lines could be written as the single line kernel - Configuring and Manipulatingpreceding Peripheral Devices root=/dev/hda3 -s . - (hd0,2)/boot/vmlinuz Printing

Chapter 13 - Backups

The last boot, Chapter 14 line, - Sharing Filestells withGRUB Samba

to load and execute the kernel image.

Chapter 15 - Network File Transfer

Note On certain systems (especially those with SCSI disks and stock kernels), you may need an initial RAM disk:

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

/boot/initrd Appendix A - initrd Command Classification Bibliography Index List of FiguresSee Section

10.5.4 for information on why you may need an initial RAM disk.

List of Tables

In case you're trying to boot a partition with another boot loader (such as a Windows partition) by hand with GRUB, try the following, where partition uses the GRUB device syntax explained earlier (e.g., hd(0,1)):

List of Sidebars

rootnoverifypartition makeactive chainloader +1 boot

3.2.3Other Boot Loaders There are many other ways to boot a kernel, including from DOS via LOADLIN or SYSLINUX, over the network, or even directly from the PC BIOS with LinuxBIOS! Most other boot loaders work like LILO, although some do not support the TAB key to list options. You may need to pay attention to boot diagnostics for this information. However, the way you enter parameters is usually identical to LILO and GRUB.

3.2.4Single-User Mode and Emergency Booting When something goes wrong with the system, an administrator's first recourse for booting quickly to a usable state is single-user mode. The idea is that the system quickly boots to a root shell instead of going through the whole mess of services. On Linux, single-user mode is usually runlevel 1. You may need to type the root password to enter single-user mode. Common tasks in single-user mode include the following: Checking filesystems after a system crash Fixing problems in critical files, such as /etc/fstab,/etc/passwd, and /etc/inittab

Restoring from backups after a system crash Don't expectHow too Linux manyWorks: amenities inEvery single-user mode. You Know may need to set the terminal type (enter What Super-User Should TERM=linux) to get full-screen editors to work, and the network may not be available. You can ISBN:1593270356 configure by Brian Ward the network No andStarch otherPress systems by hand if necessary, but it's a pain. © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

When you finish with single-user can exitfirewalls, the shell to see if tools, the system starts normally. covering advanced topicsmode, such asyou networking, development device management, shell scripts, and printers withidea Samba. However, it'ssharing usually a good to reboot the system, because the transition from single-user mode to regular multi-user mode is not always perfect. Table of Contents

If you have a real mess on your hands, and even single-user mode doesn't work, you can try the -b kernel parameter for an emergency boot shell instead of any kind of orderly startup. This does not mount the root Chapter 1 - The Basics filesystem as read-write or give you much of anything else, so you'll probably need to do some Chapter 2 - Devices, Disks, Filesystems, and the Kernel remounting, and possibly mount the /proc filesystem before getting anything useful done. However, if Chapter 3 - How Linux Boots things are really this broken, you might consider using a rescue CD-ROM instead of this rudimentary Chapter 4 - Essential System Files, Servers, and Utilities emergency boot shell mode. You may also be able to get an emergency boot shell by using the Chapter 5 - Configuring Your Network init=/bin/sh kernel parameter. Chapter 6 - Network Services How Linux Works—What Every Super-User Should Know

Chapter 7

- Introduction to Shell Scripts

Finally, if you break your kernel or boot loader, you won't be able to get to single-user mode without extra Tools help. You- Development can often boot your system with a kernel from a bootable CD-ROM by passing the root Chapter 9 - Compiling Software From Source Code parameter to the CD-ROM's kernel boot loader. Your system might look somewhat strange without your Chapter 10 - Maintaining the Kernel regular kernel, but you should still be able to move files around or perhaps even compile a new kernel to Chapter 11 - Configuring and Manipulating Peripheral Devices get yourself out of the jam. Chapter 8

Chapter 12 - Printing

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

HowConsoles Linux Works: What Every Super-User Should Know 3.3 Virtual by Brian Ward

ISBN:1593270356

No Starch 2004 (347 pages) The final stage of thePress boot© process starts one or more programs that allow you to log in to the system Thishas guide describes thedisplay inner workings a Linux system withan theXfile system System and boot process console. Linux two primary modes:ofconsole (text) beginning mode, and Window server and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and (graphics mode, usually via a display manager). The kernel boots in console mode, but on most sharing printers with Samba. distributions the system switches over to graphics mode near when the rc*.d commands complete. Table of Contents

Linux has several virtual consoles. Each virtual console may run in graphics or text mode. When in text mode, you can switch between consoles with an ALT-Function key combination — for example, ALT-F1 Chapter Basics takes 1you- The to /dev/tty1, ALT-F2 goes to /dev/tty2, and so on. How Linux Works—What Every Super-User Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 -console How Linux Boots A virtual used by

XFree86 in graphics mode is slightly different. Rather than getting a virtual an XFree86 server takes over a free virtual console. Chapter 5 - Configuring Your Network For example, if you have getty processes running on tty1 and tty2, a new XFree86 server takes over Chapter Network Services tty3.6In -addition, after XFree86 puts a virtual console into graphics mode, you must normally press a Chapter 7 - Introduction to Shell Scripts CONTROL-ALT-Function key combination to switch to another virtual console instead of the simpler ALTChapter 8 -key Development Tools Function combination. Chapter 4 assignment - Essential System Files, Servers, and Utilities console directly from /etc/inittab,

Chapter 9

- Compiling Software From Source Code

The upshot of all of this is that Chapter 10 - Maintaining the Kernel

if you want to see your text console after your system boots, press press ALT-F2, ALT-F3, and so on, until you get to the

CONTROL-ALT-F1. To get back to Peripheral the X11 session, Chapter 11 - Configuring and Manipulating Devices X session. Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 4: Essential System Files, Servers, and by Brian Ward No Starch Press Utilities This guide describes the inner workings of a Linux system beginning with the file system and boot process and

ISBN:1593270356

© 2004 (347 pages)

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Overview Table of Contents

When you first look in the /etc directory or do a process listing, you may feel overwhelmed. Fortunately, very few of these files are terribly critical to the system's operation. This chapter shows you what is Chapter 1 - The Basics important. How Linux Works—What Every Super-User Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 - How Linux Boots The subject material in this

chapter covers the parts of the system that make the infrastructure covered in in Chapter 1. In particular, you will see the following:

Chapter 4 2 - Essential System Files, Servers, tools and Utilities Chapter available to the user-level covered Chapter 5

- Configuring Your Network

ChapterConfiguration 6 - Network Services files that Chapter 7

the system libraries access to get server and user information

- Introduction to Shell Scripts

programs Tools (sometimes ChapterServer 8 - Development Chapter 9

called daemons) that run when the system boots

- Compiling Software From Source Code

utilities that ChapterConfiguration 10 - Maintaining the Kernel

can be used to tweak the server programs and configuration files

Chapter 11 - Configuring and Manipulating Peripheral Devices

As in the previous chapters, there is virtually no networking material here. The network is separate from the elementary parts of the system. In Chapter 5 you'll see where the network fits in. Chapter 13 - Backups Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 4.1 System Logging by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347diagnostic pages) Most systemNoprograms write their output to the syslog service. The syslogd daemon waits for This depending guide describes of a Linux system funnels beginningthe with the fileto system process and messages, and onthe theinner typeworkings of message received, output a file,and theboot screen, users, covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and some combination of these, or just ignores it. The system logger is one of the most important parts of the sharing printers with Samba. system. When something goes wrong and you don't know where to start, you should check the system log files first. Here is a sample log file message:

Table of Contents

How Linux Works—What Every Super-User Should Know

Aug 19 Chapter 1 -17:59:48 The Basics

duplex sshd[484]: Server listening on 0.0.0.0 port 22.

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Most Linux distributions use the /var/log directory to store log files, but you can find out for sure by - Essential System Files, Servers, and Utilities looking at syslog.conf, the syslogd configuration file. It contains lines like this: Chapter 5 - Configuring Your Network Chapter 4 Chapter 6

- Network Services

kern.* Chapter 7 - Introduction to Shell Scripts

/dev/console /var/log/messages authpriv.* Chapter 9 - Compiling Software From Source/var/log/secure,root Code mail.* /var/log/maillog Chapter 10 - Maintaining the Kernel cron.* /var/log/cron Chapter 11 - Configuring and Manipulating Peripheral Devices *.emerg * Chapter 12 - Printing local7.* /var/log/boot.log Chapter 13 - Backups *.info;authpriv.none Chapter 8 - Development Tools

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

The type information to Chapter 16 -of User Environments

be logged is on the left, and the place where it is logged to is on the right. Most are normal files, but there are some exceptions: /dev/console is a special18device forDirections the system console, root means to send a message to the superuser if that user is Chapter - Further logged Ain,- Command and * means to send a message to all users currently on the system. You can also send Appendix Classification messages to another host with @host. Bibliography of the 17 log- targets in this example Chapter Buying Hardware for Linux

Index

Log messages List of Figures

carry a facility and a priority. The facility is a general category of message (Check the syslog.conf(5) manual page for a current list of all facilities). Most are fairly obvious from their name List of Tables (mail, for example). The preceding syslog.conf sample catches messages carrying the authpriv, List of Sidebars mail,cron, and local7 facilities. In line 6, * is a wildcard that catches output related to all facilities. In the syslog.conf file, the priority follows the dot (.) after the facility. The priority may be one of debug, info,notice,warning,err,crit,alert, or emerg. This is also the order of the priorities, with emerg being the highest. Note You can exclude log messages from a facility in syslog.conf by specifying a priority of none, as shown on line 2 of the preceding example. It is important to understand that when you put a specific priority in a syslog.conf line, syslogd sends messages with that priority and all higher priorities to the destination on that line. Therefore, in the preceding example file, the *.info actually catches most syslog messages and puts them into /var/log/messages because info is a relatively low priority. You can catch all priorities by using * as a wildcard. An extra daemon called klogd traps kernel messages and (usually) sends them to syslogd. You may wish to direct kernel messages into a separate file with a line like this in your syslog.conf: kern.*

/var/log/kern.log

If you want to send a log message to the syslog service manually (for example, when writing a script), use thelogger command, as in this example: logger -p daemon.info something bad just happened

Very little can go wrong with syslogd. The most common problem is where syslog.conf doesn't catch a certain facility or priority. Another problem is that log files have a tendency to fill their disk partitions after some time. However, most distributions automatically trim the files in /var/log with automatic invocations of logrotate or some other utility.

The Linux syslogd has a few more features than its counterparts in other Unix variants. The discussion here only covers the basics that apply to most Unix systems. If you're really interested in it, or if there's some character yourWorks: configuration file that you can't figure out, take a look at the syslog.conf(5) manual Howin Linux What Every Super-User Should Know page. ISBN:1593270356 by Brian Ward No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux 4.2 A Glance atWorks: /etc What Every Super-User Should Know by Brian Ward

ISBN:1593270356

No Starch Press (347 pages) Most configuration files on© a2004 Linux system are in /etc, and because there are so many packages on a guide describes the inner a Linux system beginning with the actually file system and boottoprocess and Unix system,This /etc accumulates files workings quickly. of This makes it hard to see what matters a running covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and system. sharing printers with Samba.

In previous chapters, you saw files like inittab and fstab for booting the system. Table 4-1 identifies those and other critical configuration files and where they are discussed in the book.

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter File 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Table 4-1: Essential Configuration Files

fstab Chapter 5 - Configuring Your Network Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

group

init.d Chapter 8 - Development Tools Chapter 9

Function Filesystems

2.4.6

User management

4.3.2

Boot sequence

3.1.3

- Compiling Software From Source Code

inittab

Chapter 10 - Maintaining the Kernel

Section

Boot sequence

Chapter 11 - Configuring and Manipulating Peripheral ld.so.cache SharedDevices libraries

3.1.1 8.1.4

Chapter 12 - Printing

ld.so.conf Chapter 13 - Backups

Shared libraries

8.1.4

Chapter 14 - Sharing Files with Samba

User management

4.3

Boot sequence

3.1.2

User management

4.3

passwd

Chapter 15 - Network File Transfer

rc*.d Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

shadow

Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: WhatFiles Every Super-User Should Know 4.3 UserHow Management by Brian Ward

ISBN:1593270356

No Starch Pressallows © 2004 (347 pages) people to log in to the same machine without interfering with one The user system in Unix different Thislowest guide describes the inner a Linux system beginning with the file and boothelp process another. At the level, users areworkings nothingofmore than numbers (user IDs), butsystem login names to and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and avert confusion and boredom. sharing printers with Samba.

The plain-text file /etc/passwd maps login names to user IDs, and it looks something like this: Table of Contents How Linux Works—What Every Super-User Should Know

root:x:0:0:Super-user:/root:/bin/sh - The Basics daemon:*:1:1:daemon:/usr/sbin:/bin/sh Chapter 2 - Devices, Disks, Filesystems, and the Kernel bin:*:2:2:bin:/bin:/bin/sh Chapter 3 - How Linux Boots sys:*:3:3:sys:/dev:/bin/sh Chapter 4 - Essential System Files, Servers, and Utilities nobody:*:65534:65534:nobody:/home:/bin/false Chapter 5 - Configuring Your Network juser:x:3119:1000:J. Random User:/home/juser:/bin/bash Chapter 6 - Network Services beazley:x:143:1000:David Beazley:/home/beazley:/bin/bash Chapter 7 - Introduction to Shell Scripts Chapter 1

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

The format is straightforward. Each line represents one user, with seven fields separated by colons:

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

The user (login) name.

Chapter 12 - Printing

ChapterThe 13 -user's Backups encrypted

password. On most Linux systems, the password is not actually stored in the file. shadow is similar to passwd, but normal users do not have read Chapterpermission 15 - Network Transfer The second field in passwd or shadow is the encrypted password, and it onFile shadow. Chapterlooks 16 - User like Environments a bunch of garbage, such as d1CVEWiB/oppc (in Unix, passwords are never stored in clear Chaptertext). 17 - Buying Hardware Linux The rest of the for fields in shadow deal with matters such as password expiration dates. Chapterpasswd 14 - Sharing with Samba file, Files but in the shadow

Chapter 18 - Further Directions

AnAx -inCommand the second field in the Appendix Classification

passwd file indicates that the encrypted password is stored in shadow. that the user cannot log in, and if the field is blank (that is, appears as ::), no Index password is required to log in. Watch out for blank passwords. You should never have a user without a password. List of Figures An* indicates Bibliography

List of Tables

Theuser List of Sidebars

ID (UID), the user's representation to the kernel. It should be unique. You can have two entries with the same user ID, but it will confuse you and some of your software.

Thegroup ID (GID). It should be one of the numbered entries in the /etc/group file. Groups determine file permissions and little else. This group is also called the user's primary group. The user's real name (often called the GECOS field). Sometimes there are commas in this field, denoting room and telephone numbers. The user's home directory. The user's shell (the program that runs when the user logs in). Figure 4-1 identifies the various fields in one of the entries in the preceding example.

Figure 4-1: An entry in the password file.

Note A user and home directory are collectively known as an account. There are a few special users in /etc/passwd. The superuser (root) always has UID 0 and GID 0, as in the preceding example. There are other users with no login privileges, such as daemon. These generally vary from system to system, and you should leave them alone. "Nobody" is a special under-privileged user that some processes run as, because the nobody user cannot write to anything on the system. These special users are called pseudo-users. They can't log in to the system, but the system can start processes with their user IDs for security reasons. Note The/etc/passwd file syntax is special and fairly strict, allowing for no comments or blank lines.

4.3.1Manipulating Users and Passwords How Linux Works: What Every Super-User Should Know

Regular users with /etc/passwd with the passwd command. By default, the passwd command ISBN:1593270356 by interact Brian Ward changes theNo user's Starch password, Press © 2004but (347you pages) can also use -f to change the user's real name, or -s to change the user's shell to one listed in /etc/shells. (Two for changing real and name shelland are This guide describes the inner workings of aother Linux commands system beginning with the filethe system bootand process covering advanced topics such as program, networking,running firewalls,as development tools, when device changing management, chfn and chsh.) passwd is an suid-root the superuser theshell scripts, and sharing printers with Samba. /etc/passwd file. Table of Contents

Changing /etc/passwd as the Superuser

How Linux Works—What Every Super-User Should Know Chapter 1 -the Thepasswd Basics Because

file is in plain text, the superuser may use any text editor to make changes. To add a appropriate line and create a home directory for the user; Chapter 3 is - How Boots There is a special program called vipw that allows you to lock the passwd file deleting the Linux opposite. Chapter 4 it - Essential System Files,To Servers, and Utilities and edit as the superuser. set another user's password, use passwduser as the superuser. Chapter 2 - need Devices, Filesystems, theadd Kernel user, you to Disks, do nothing moreand than an

Chapter 5

- Configuring Your Network

Chapter 6 - Network Services However, most distributions

frown on editing passwd directly because it is easy to make a mistake. For adduser and userdel to add and remove users. Even if you Chapter 8 - Development use these commands Tools or vipw, though, you should still know about the password file format, because you Chapter 9 - Compiling From Source Code may need to edit it Software in a pinch. Chapter 7 - Red Introduction to Shell example, Hat Linux hasScripts the commands

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

4.3.2Working with Groups

Chapter 12 - Printing

Chapter 13 - Backups

Groups Unix offer way to share Chapter 14in - Sharing Filesawith Samba

files with certain other users on the system, but deny access to all other users. The idea is that you can set read or write permission bits (described in Section 1.17) for the Chapter 15 - Network File Transfer group,16but not Environments the world (everyone else). This was once important because many users shared one Chapter - User machine, thisHardware has become less significant in recent years as workstations have become more personal. Chapter 17 - but Buying for Linux Chapter 18 - Further Directions

As mentioned earlier, /etc/passwd has a group field. The /etc/group file defines the group IDs, as shown in this example:

Appendix A - Command Classification Bibliography Index

root:*:0:juser List of Figures daemon:*:1: List of Tables bin:*:2: List of Sidebars sys:*:3: adm:*:4: disk:*:6:juser,beazley nogroup:*:65534: user:*:1000: The fields in /etc/group are as follows: The group name. (This is what shows up when you run a command like ls -l.) The group password. This is hardly ever used; you can use * or any other default value. The group ID (a number). The GID must be unique within the group file. This number goes into a user's group field in their /etc/passwd entry. An optional list of users that belong to the group. In addition to the users listed here, users with the corresponding group ID in their passwd file entries also belong to the group. Figure 4-2 identifies the fields in a group file entry.

Figure 4-2: An entry in the group file. To see the groups you belong to, run the groups command.

Note Linux distributions have a convention of creating a new group for each new user with the same name the Works: user. What Every Super-User Should Know Howas Linux by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 4.4 gettyHow and Login by Brian Ward

ISBN:1593270356

Nomentioned Starch Pressgetty, © 2004 (347 Section 3.1.1 a pages) program that attaches to terminals and displays a login prompt. On This guide getty describesisthe inner workings of a Linux system beginning theitfile process and most Linux systems, uncomplicated because the system onlywith uses forsystem loginsand onboot virtual covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and terminals, with lines in /etc/inittab like this one for /dev/tty1: sharing printers with Samba.

1:2345:respawn:/sbin/getty Table of Contents

38400 tty1

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

In this example, 38400 is the baud rate. Virtual terminals ignore the baud rate; it's only there for backward - Devices, Disks, Filesystems, and the Kernel compatibility with terminals connected to real serial lines. Some getty programs (like the mingetty that Chapter 3 - How Linux Boots Red Hat uses for virtual terminals) don't need the baud rate setting. Chapter 4 -Linux Essential System Files, Servers, and Utilities Chapter 2

Chapter 5

- Configuring Your Network

You are probably most interested in the name of the file that getty prints as the login greeting: - Network Services /etc/issue. This is a quick and satisfying way to deface your system without doing any real damage.

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8 - type Development Tools After you your login name,

getty replaces itself with the login program, which then asks for your login replaces itself with your shell. Otherwise, you get a

Chapter 9 - Compiling Software From Source Code password. If you type the correct password, Chapter 10 - Maintaining the Kernel

"Login incorrect" message.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 -know Printing You now what

getty and login do, but it's unlikely that you'll ever need to configure or change on serial ports have been largely confined to the dustbin of history. The login Chapter 14 -has Sharing Files with Samba program an excessive number of options and configuration files, but they are mostly useless because Chapter 15 - with Network File Transfer they deal security for network login methods, such as telnet, that are insecure in the first place. You Chapter 16 -in User Environments will learn Chapter 6 that you should not use them. Chapter - Backups them, 13 because terminals

Chapter 17 - Buying Hardware for Linux

Note you want to send Chapter 18 - If Further Directions

and receive faxes or dial up to your machine through your own modem, you mgetty, an advanced getty that can work with fax and voice modems.

needClassification to work with Appendix A - may Command Bibliography Index List of Figures List of Tables List of Sidebars

How the Linux Works: 4.5 Setting TimeWhat Every Super-User Should Know by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) A well-functioning Unix machine depends on accurate timekeeping. The kernel is responsible for describes workings of a Linux beginning with the file system and boot and maintaining This the guide system clock,the theinner clock consulted whensystem you run commands such as date. You process can also covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and set the system clock with the date command, but this is usually a bad idea, because you'll never get the sharing printers with Samba. time exactly right. You want your system clock to be very close to the correct time. Table of Contents

PC hardware has a battery-backed "real-time" clock. It's not the greatest clock in the world, but it's better than nothing. The kernel usually sets its time based on this clock at boot time, and you can reset the Chapter 1 clock - The to Basics system the current hardware time with hwclock. If your hardware clock is in UTC (Universal Chapter 2 - Devices, Disks, Filesystems, and the Kernel Coordinated Time, or Greenwich Mean Time), run this command: How Linux Works—What Every Super-User Should Know

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

hwclock- Configuring --hctosys --utc Your Network

Chapter 5 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

You should try to keep your hardware clock in UTC to avoid any trouble with time zone or daylight savings - Development Tools time corrections. However, if you insist on keeping the hardware clock set to the local time, run this Chapter 9 - Compiling Software From Source Code command instead: Chapter 8

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

hwclock --hctosys Chapter 12 - Printing

--localtime

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

Unfortunately, theFile kernel isn't Chapter 15 - Network Transfer

terribly good at keeping time, and because Unix machines often stay up for they tend to develop a drift. In addition, it's fairly rude to make the system clock jump ahead or back by running hwclock on a frequent basis; time-based system events can get lost Chapter 17 - Buying Hardware for Linux or munged. If youDirections want to gradually change the system clock based on the hardware clock, run this Chapter 18 - Further command: Appendix A - Command Classification months years at a time, Chapter 16 and - User Environments

Bibliography

adjtimex Index

--adjust

List of Figures List of Tables

However, this List of Sidebars

is only good for updating the clock manually when it has already drifted. To keep the time up to date, you need to run a network time daemon (see Section 4.5.2).

4.5.1Time Zones The system clock runs in UTC. System libraries convert this into local time and compensate for daylight savings time and any other strange circumstances (such as living in Indiana). To set your system's time zone, make a symbolic link to the appropriate time zone file in /usr/share/zoneinfo from /etc/localtime. For example, here is the command to configure a United States Pacific Time Zone setting: ln -sf /usr/share/zoneinfo/US/Pacific /etc/localtime

A long listing of the link should contain this output: /etc/localtime -> /usr/share/zoneinfo/US/Pacific

If you want to use a different time zone than the system default, you can do so by setting the TZ environment variable like this: $ export TZ=US/Central $ date

4.5.2Network Time If your machine is permanently connected to the Internet, you can run an NTP (Network Time Protocol)

daemon and get the time from a remote server. The main NTP Web page is http://www.ntp.org/, but if you don't really feel like reading through the mounds of documentation there, do this: How ISP Linux What Every Super-User 1. Ask your forWorks: the closest NTP time server.Should Know by Brian Ward

ISBN:1593270356

No Starch Press © in 2004 (347 pages) 2. Put that time server /etc/ntpd.conf. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced suchtime. as networking, firewalls, development tools, device management, shell scripts, and 3. Runntpdate servertopics at boot sharing printers with Samba.

4. Runntpd at boot time. Table of Contents

If your does not Super-User have a permanent Internet How Linuxmachine Works—What Every Should Know to maintain the time Chapter 1 - The Basics

connection, you can use a daemon such as chronyd

during disconnections.

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

HINT can also Chapter 3 - You How Linux Bootsset

your hardware clock based on the network time. First, set your system time from the network with ntpdate (or ntpd). Then run this command:

Chapter 6 - Network Services-utc hwclock --systohc Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What EveryTasks Super-User Should Know 4.6 Scheduling Recurring with Cron by Brian Ward

ISBN:1593270356

No a Starch Press © 2004 cron (347 pages) Unix provides service called that runs programs repeatedly on a fixed schedule. Most experienced Thisconsider guide describes inner workings a Linux because system beginning with the file system and boot process and administrators cron the to be vital to theofsystem it can perform automatic system covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and maintenance. For example, cron runs log file rotation utilities. You should know about cron not only in sharing printers with Samba. the interest of knowing about everything that runs on your system, but also because it is just plain useful. Table Contents Youofcan run any

program you like with cron, choosing the times that suit you. A program running through you need to create an entry line in your crontab file, Chapter 1 - The Basics usually with the crontab command. Here is a typical crontab file entry that runs a command daily at 9:15 Chapter 2 - Devices, Disks, Filesystems, and the Kernel AM: How Linux Every Know cron is Works—What called a cron job.Super-User To installShould a cron job,

Chapter 3 Chapter 4

15 095 Chapter

- How Linux Boots

- Essential System Files, Servers, and Utilities

*- Configuring * * /home/juser/bin/spmake Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

The five -whitespace-delimited fields at the beginning specify the schedule time (see also Figure 4-3 ): Compiling Software From Source Code

Chapter 9

Chapter 10 - Maintaining the Kernel

Minute (0–59)

Chapter 11 - Configuring and Manipulating Peripheral Devices ChapterHour 12 - (0–23) Printing Chapter 13 - Backups ChapterDay 14 -of Sharing with Samba monthFiles (1–31) Chapter 15 - Network File Transfer

(1–12) ChapterMonth 16 - User Environments Chapter 17 - Buying Hardware for Linux

weekDirections (0–7; 0 and ChapterDay 18 -of Further

7 are Sunday)

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Figure 4-3: An entry in the crontab file. The preceding example says to run spmake daily, because the day of month, month, and day of week fields are all * (the * character matches all possible values, meaning every day of the month, every month, or every day of the week). If you want to run the job only on the 14th of each month, use this crontab line: 15 09 14 * * /home/juser/bin/spmake

You may select more than one time for each field. For example, if you would like the program to run on the 5th as well as the 14th, use 5,14 in the third field: 15 09 5,14 * * /home/juser/bin/spmake

The remainder of the line is the command to run. When cron runs the job, the command may generate standard output or error or exit abnormally. If that happens, cron mails this information to you. You may want to redirect the output to /dev/null or some log file if you find this annoying. The crontab(5) manual page is a full reference for the cron file format. However, there is also a crontab(1) manual page for the installation utility, so you'll need to use man 5 crontab to get to the right one.

4.6.1Installing Crontab Files Each user can have their own crontab file. The system usually stores all crontabs in /var/spool/cron/crontabs. Normal users can't write to this directory. Instead, the crontab command installs, lists, edits, and removes a user's crontab. The easiest way to install a crontab is to put your crontab entries into a file, then use crontabfile to

install file as your current crontab. The crontab command checks the file format to make sure that you haven't screwed anything up. If you want to list your cron jobs, run crontab -l. To remove the crontab, use crontabHow -r.Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

Using temporary filesPress to create andpages) manipulate your crontab can be a little messy, so if you want to edit No Starch © 2004 (347 and install your crontab in one motion, run crontab If you make with a mistake, crontab tellsprocess you where This guide describes the inner workings of a Linux-e. system beginning the file system and boot and the mistake covering is and asks if you would like to try editing again.development tools, device management, shell scripts, and advanced topics such as networking, firewalls, sharing printers with Samba.

4.6.2System Crontab Files

Table of Contents

How Linux Works—What Every Super-User Should Know

Rather than use the superuser's crontab for scheduling recurring system tasks, Linux distributions normally - The Basics have an /etc/crontab file. Do not use the crontab command to edit this file; it has a slightly different Chapter 2 - Devices, Disks, Filesystems, and the Kernel format with one more field — the user that should run the job. Here is an example for a job to run at 6:42 Chapter 3 - How Linux Boots AM, running as the superuser (root): Chapter 4 - Essential System Files, Servers, and Utilities Chapter 1

Chapter 5

- Configuring Your Network

42 6 6* -*Network * root /usr/local/bin/cleansystem Chapter Services Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Some9distributions also useFrom the /etc/cron.d Chapter - Compiling Software Source Code have any but the they have Chapter 10 - name, Maintaining Kernel

directory to store system crontab files. These files may the same format as /etc/crontab.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

> /dev/null 2>&1

How Linux Works: What Every Super-User Should 4.7 Scheduling One-Time Tasks with AtKnow by Brian Ward

ISBN:1593270356

Norun Starch Press 2004 (347 pages) If you want to a job in ©the future but don't want to use cron because the command should only run Thisdo guide describes the inner workings of a Linuxifsystem beginning with the fileatsystem boot process once, you can it with the at service. For example, you want to run myjob 10:30and PM, enter thisand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and command: sharing printers with Samba.

at of 22:30 Table Contents myjob How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

End the input with a CONTROL-D (at reads the commands from the standard input). - How Linux Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

To check that the job has been scheduled, use atq, or to remove it, use atrm. You also can schedule jobs - Configuring Your Network days into the future by adding the date (in DD.MM.YY format; for example, at 22:30 30.09.03).

Chapter 5 Chapter 6

- Network Services

Chapter - Introduction Shell There7isn't too much to else to Scripts the at

command. at actually does not see much use in common practice. Tools However,- Development it can be handy for the odd time that you need to shut the system down in the future.

Chapter 8 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 4.8 Tracking Individual Processes by Brian Ward

ISBN:1593270356

Noto Starch Press 2004 (347 pages) You saw how use ps in©Section 1.16 for listing process characteristics at any given time. ps is good for This guide the inner workingsbut of a file systemchange and bootover process andUsing getting a snapshot of describes the current processes, it Linux doessystem little tobeginning tell youwith howthe processes time. advanced topics such as networking, firewalls, development tools, device management, shell scripts, and ps alone, it'scovering not terribly easy to pick out processes that are using too much CPU time or memory. sharing printers with Samba.

Thetop program displays the current system status and many of the fields that you might see in a ps listing, the display every second. By default, top shows the most active processes (that is, those How Linux Works—What Every Super-User Should Know currently taking up the most CPU time).

Table Contents but of it also updates Chapter 1

- The Basics

Chapter 2 -send Devices, Disks, Filesystems, and the Kernel You can commands to top with keystrokes. Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

These are some of the most important commands:

SPACEBAR Updates the display immediately

ChapterM5Sorts - Configuring Your Networkmemory by current resident Chapter 6

ChapterT7Sorts - Introduction to Shell ScriptsCPU by total (cumulative) Chapter 8

usage

- Network Services

usage

- Development Tools

by current CPUFrom usage (theCode default) ChapterP9Sorts - Compiling Software Source Chapter 10 - Maintaining the Kernel

Displays only and oneManipulating user's processes Chapteru11 - Configuring Peripheral Devices Chapter 12 - Printing

? Displays a usage summary for all top commands

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba

If you want to know how much CPU time a process uses during its entire lifetime, use time. (If your shell has a built-in time command, you may need to run /usr/bin/time to get the full output shown below.) For Chapter 16 - User Environments example, to measure the CPU time used by ls, run this command: Chapter 15 - Network File Transfer

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

time ls Appendix A - Command Classification Bibliography Index

Afterls terminates, you should get some output like this:

List of Figures List of Tables

0.05user List of Sidebars

0.09system 0:00.44elapsed 31%CPU (0avgtext+0avgdata 0maxresident)k 0inputs+0outputs (125major+51minor)pagefaults 0swaps

User time is the number of seconds that the CPU has spent running the program's own code. On modern processors, some commands run so quickly that you may get a zero value here because the actual CPU time is so low that time rounds down to zero. System time is how long the kernel spends doing the process's work (for example, reading files and directories). Elapsed time is the total time it took to run the process from start to finish, including the time that the CPU spent doing other tasks. This number is not very useful for performance measurements. See Section 4.10 for a description of the other fields.

4.8.1Finding Open Files with lsof Thelsof command lists open files and the processes that are using these open files. Because Unix places such a great emphasis on files, lsof is among the most useful tools for finding trouble spots. lsof does not stop at regular files — it can list network sockets, dynamic libraries, pipes, and more. Runninglsof on the command line usually produces a tremendous amount of output. Here is a fragment of what you might see: COMMAND init init init init init init

PID 1 1 1 1 1 1

USER root root root root root root

FD cwd rtd txt mem mem 10u

TYPE DIR DIR REG REG REG FIFO

DEVICE 3,1 3,1 3,1 3,1 3,1 3,1

SIZE 4096 4096 24480 999542 1251176

NODE 2 2 16212 32329 32208 97634

NAME / / /sbin/init /lib/ld-2.3.2.so /lib/libc-2.3.2.so /dev/initctl

... ... vi vi vi ... vi

3511 juserWhat cwd DIR 3,4 How Linux Works: Every Super-User Should Know 3511Wardjuser rtd by Brian juser txt No 3511 Starch Press © 2004 (347 pages)

DIR REG

3,1 3,3

4096 4096 327048

163866 /home/juser/w 2 / ISBN:1593270356 561520 /usr/bin/vi

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering topics such firewalls, development tools, device management, shell scripts, and 3511advanced juser 3rWas networking, REG 3,4 18993 163867 /home/juser/w/c sharing printers with Samba.

Table Theoffields Contents in this

output are as follows:

How Linux Works—What Every Super-User Should Know ChapterCOMMAND 1 - The Basics The

command name for the process that holds the file descriptor.

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

process ID. Files, Servers, and Utilities ChapterPID 4 -The Essential System Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

USER The user running the process. - Introduction to Shell Scripts

Chapter 7 Chapter 8

- Development Tools

ChapterFD 9 The - Compiling Software or From Codeof file descriptor theSource purpose

the open file. A file descriptor is a number that a process uses in conjunction with the system libraries to identify and manipulate a file.

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing ChapterTYPE 13 - Backups The file

type (regular file, directory, socket, etc.).

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

major and ChapterDEVICE 16 - UserThe Environments

minor number of the device that holds the file.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

SIZE The file's size.

Appendix A - Command Classification Bibliography Index

NODE The file's inode number.

List of Figures List of Tables

NAME The List of Sidebars

filename.

The lsof(1) manual page contains a full list of what you might see for each field, but you should be able to guess just by looking at the output. For example, look at the entries with cwd in the FD field. These lines indicate current working directories of the processes. Another example is the very last line, showing a file that the user is currently editing with vi. There are two basic approaches to running lsof: List everything and pipe the output to a command like less, and then run a search to find what you're looking for. Narrow down the list that lsof provides with command-line options. If you use command-line options, you can provide a filename as an argument, and lsof will list only the entries that match the argument. For example, the following command displays entries for open files in /usr: lsof /usr To list the open files for a particular process ID, run this command: lsof -p pid lsof has dozens of other options; lsof -h provides a short summary. Most options pertain to the output format. Make sure that you look at Section 6.5.1 for lsof network features. Note lsof is highly dependent on kernel information. If you upgrade your kernel, you may need to upgrade lsof.

4.8.2Tracing Program Execution with strace and ltrace

With the exception of time, the tools you have seen so far examine active processes. However, if you have no idea why a program dies almost immediately after starting up, even lsof won't help you. You would have a difficult time even running with Should a failedKnow command. How Linux Works:lsof What concurrently Every Super-User by Brian Ward

ISBN:1593270356

ThestraceNo (system call trace) andpages) ltrace (library trace) commands can help you discover what a program Starch Press © 2004 (347 attempts to do. These tools produce large amounts of output, what to look This guide describes the innerextraordinarily workings of a Linux system beginning with thebut file once systemyou andknow boot process and for, you will covering be in a good position down firewalls, problems. advanced topics for suchtracking as networking, development tools, device management, shell scripts, and sharing printers with Samba.

Asystem call is a privileged operation that the kernel must perform for a process, such as opening and reading data from a file. strace prints all of the system calls that a process makes. To get the idea, run this Table of Contents command: How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 -cat Devices, Disks, Filesystems, and the Kernel strace /dev/null Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter The first 5 -part Configuring of the output Your Network deals Chapter 6

primarily with loading shared libraries. You can ignore this stuff:

- Network Services

Chapter 7 - Introduction to Shell Scripts execve("/bin/cat", ["cat",

"/dev/null"], [/* 52 vars */]) = 0 = 0x804b348 Chapter 9 - Compiling Software From Source Code open("/etc/ld.so.preload", O_RDONLY) = -1 ENOENT (No such file or directory) Chapter 10 - Maintaining the Kernel open("/etc/ld.so.cache", O_RDONLY) = 3 Chapter 11 - Configuring and Manipulating Peripheral Devices fstat64(3, {st_mode=S_IFREG|0644, st_size=14834, ...}) = 0 Chapter 12 - Printing old_mmap(NULL, 14834, PROT_READ, MAP_PRIVATE, 3, 0) = 0x40015000 Chapter 13 - Backups close(3) = 0 Chapter 14 - Sharing Files with SambaO_RDONLY) open("/lib/libc.so.6", = 3 Chapter 15 - Network File Transfer read(3, "\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\200^\1"..., 1024) = 1024 Chapter 8 - Development Tools brk(0)

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions In addition, you can skip by

all of the mmap output until you get to the lines that look like this:

Appendix A - Command Classification Bibliography

fstat64(1, {st_mode=S_IFCHR|0666, st_rdev=makedev(1, 3), ...}) = 0 open("/dev/null", O_RDONLY|O_LARGEFILE) = 3 List of Figures fstat64(3, {st_mode=S_IFCHR|0666, st_rdev=makedev(1, 3), ...}) = 0 List of Tables brk(0) = 0x804b348 List of Sidebars brk(0x804c348) = 0x804c348 brk(0) = 0x804c348 brk(0x804d000) = 0x804d000 read(3, "", 4096) = 0 close(3) = 0 close(1) = 0 _exit(0) = ? Index

Now you see some interesting things. First, look at the open() call, which opens a file. The 3 as a result means success (3 is a file descriptor). Then, near the end, you see where cat reads from /dev/null (the read() call — notice that the file descriptor is 3). Then there is nothing more to read, so the program closes the file descriptor and exits. So what happens when there's a problem? Try strace cat not_a_file instead and examine the open() call: open("not_a_file", O_RDONLY|O_LARGEFILE) = -1 ENOENT (No such file or directory) Here, strace not only reports the error at the system-call level, but it also gives you a small description of the error. Missing files are the most common problems with Unix programs, so if the syslog and other log information isn't very helpful, and you have nowhere else to turn, strace can be of great use. You can even use strace on daemons that detach themselves. Here's an example: strace -o crummyd_strace -ff crummyd In this example, the -o option to strace logs the action of any child process that crummyd spawns into

crummyd_strace.pid, where pid is the process ID of the child process. TheltraceHow command tracks What shared library calls. The output is similar to strace, but be warned, there are Linux Works: Every Super-User Should Know usually manybymore library calls than system calls. See Section 8.1.4 for more informationISBN:1593270356 on shared Brianshared Ward libraries (ltrace doesn't work on statically linked binaries). No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: WhatPriorities Every Super-User Should Know 4.9 Adjusting Process by Brian Ward

ISBN:1593270356

Press It is possibleNo toStarch change the© 2004 way(347 thepages) kernel schedules a process so that the process gets more or less CPU This processes. guide describes thekernel inner workings of aprocess Linux system beginning the file system and boot process time than other The runs each according to with its scheduling priority, which is aand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and number between -20 and 19, with -20 being the foremost priority (yes, this can be confusing). sharing printers with Samba.

Theps -l command lists the current priority of a process, but it's a little easier to see how it works with as shown here:

Table of Contents thetop command,

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Tasks: - Devices, 79 total, 1 running, 77 sleeping, 0 stopped, 1 zombie Disks, Filesystems, and the Kernel Cpu(s): 9.4% us, 1.0% sy, 0.4% ni, 88.4% id, 0.6% wa, 0.0% hi, 0.1% si Chapter 3 - How Linux Boots Mem: 320364k total, 301420k used, 18944k free, 17320k buffers Chapter 4 - Essential System Files, Servers, and Utilities Swap: 514072k total, 13260k used, 500812k free, 68260k cached Chapter 5 - Configuring Your Network Chapter 2

Chapter 6

- Network Services

PID USER PR NI VIRT RES SHR - Introduction to Shell Scripts 23066 bri 16 0 1868 896 1732 Chapter 8 - Development Tools 10382 bri 15 0 93288 74m 28m Chapter 9 - Compiling Software From Source Code 1 root 16 0 1348 480 1316 Chapter 10 - Maintaining the Kernel 2 root 34 19 0 0 0 Chapter 11 - Configuring and Manipulating Peripheral Devices 3 root 5 -10 0 0 0 Chapter 12 - Printing 4 root 5 -10 0 0 0 Chapter 13 - Backups 5 root 15 0 0 0 0 Chapter 14 - Sharing Files with Samba 6 root 25 0 0 0 0 Chapter 15 - Network File Transfer 7 root 15 0 0 0 0 Chapter 16 - User Environments 8 root 15 0 0 0 0 Chapter 17 - Buying Hardware for Linux 9 root 10 -10 0 0 0 Chapter 18 - Further Directions 10 root 19 0 0 0 0 Appendix A - Command Classification 11 root 15 0 0 0 0 Bibliography 127 root 16 0 1412 572 1360 Index 129 root 16 0 1344 464 1312 List of Figures 134 daemon 19 0 1436 404 1388 List of Tables 136 root 16 0 1380 516 1352 List of Sidebars Chapter 7

S %CPU %MEM TIME+ COMMAND R 5.6 0.3 0:00.06 top S 1.9 23.7 200:04.75 MozillaFirebird S 0.0 0.1 0:04.28 init S 0.0 0.0 0:00.00 ksoftirqd/0 S 0.0 0.0 0:06.36 events/0 S 0.0 0.0 0:08.89 kblockd/0 S 0.0 0.0 0:00.02 khubd S 0.0 0.0 0:00.00 pdflush S 0.0 0.0 1:29.48 pdflush S 0.0 0.0 1:01.23 kswapd0 S 0.0 0.0 0:00.00 aio/0 S 0.0 0.0 0:00.00 scsi_eh_0 S 0.0 0.0 0:00.00 kseriod S 0.0 0.2 0:03.24 syslogd S 0.0 0.1 0:00.02 klogd S 0.0 0.1 0:00.00 portmap S 0.0 0.2 0:00.03 inetd

In the top output, the PR column lists the kernel's current schedule priority for the process. The higher the number, the less likely the kernel is to schedule the process if others need CPU time. The schedule priority changes frequently during program execution according to the amount of CPU time that the process consumes. The schedule priority alone does not determine the kernel's decision to give CPU time to a process. Next to the priority column is the nice value (the NI column), a hint for the kernel's scheduler. This is what you care about when trying to influence the kernel's decision. The kernel adds the nice value to the current priority to determine the next time slot for the process. By default, the nice value is 0. If you want a certain process to take a backseat to other processes, running only when the other tasks have nothing to do, you can change the nice value to 19 with the renice command (where pid is the process ID of the process that you want to change): renice 19 pid

This comes in handy when you're running some big computation in the background and don't want it to bog down your interactive session. If you're the superuser, you can set the nice value to a negative number, but this is almost always a bad idea because system processes may not get enough CPU time. In fact, you likely won't need to alter nice values much because most Linux systems have only a single user, and that user does not perform much real computation. The nice value was much more important in the days when there were many users on a single machine.

How Linux Works: What Every Super-User Should Know 4.10Monitoring System Performance by Brian Ward

ISBN:1593270356

No Starch behave Press © 2004 (347 pages) a distribution's default settings, and you can spend hours and days Most Linux systems well under guide describes the inner workings of a Linux systemany beginning with the file system and boot process and trying to tuneThis your machine's performance without attaining meaningful results. Sometimes covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and performancesharing can be improved, though, and this section concentrates primarily on memory and processor printers with Samba. performance, and looks at how you can find out if a hardware upgrade might be worthwhile. Table of Contents

The two most important things that you should know about performance on your system are the load average and the system's swap/page fault behavior. The load average is the average number of processes Chapter 1 -ready The Basics currently to run. The uptime command tells you three load averages in addition to how long the Chapter 2 - Devices, Disks, Filesystems, and the Kernel kernel has been running: How Linux Works—What Every Super-User Should Know

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

... up -91 days, ... load average: 0.08, 0.03, 0.01 Configuring Your Network

Chapter 5 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

The three numbers here are the load averages for the past minute, 5 minutes, and 15 minutes. As you can - Development Tools see, this system isn't very busy, because the processor has been running at 1 percent capacity for the past Chapter 9 - Compiling Software From Source Code quarter hour (because the last number is 0.01). Most systems exhibit a load average of 0 when you're Chapter 10 - Maintaining the Kernel doing anything except compiling a program or playing a game. A load average of 0 is usually a good sign, Chapter 11 - Configuring and Manipulating Peripheral Devices because it means that your processor isn't even being challenged, and you're saving power by not running Chapter 12 - Printing a silly screensaver. Chapter 8

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba

If the load average is around 1, it's not necessarily a bad thing; it simply means that the processor has something to do all of the time — you can find the process currently using most of the CPU time with the Chapter 16 - User Environments top command. If the load average goes up near 2 or above, multiple processes are probably starting to Chapter 17 - Buying Hardware for Linux interfere with each other, and the kernel is trying to divide the CPU resources evenly. (Unless, of course, Chapter 18 - Further Directions you have two processors, in which case, a load average of 2 means that both processors have just enough Appendix A - Command Classification to do all of the time.) Chapter 15 - Network File Transfer

Bibliography Index A high

load average does not necessarily mean that your system is having trouble. A system with enough I/O resources can easily handle many running processes. Don't panic if your load average is List of Tables high and your system still responds well. The system is just running a lot of processes. The processes List of Sidebars have to compete with each other for the CPU, and therefore, they will take longer to do their computation than they would if there were one CPU for each process, but there's nothing to worry about. List of Figures memory and

However, if you sense that the system is slow and the load average is high, you're probably running into memory problems. A high load average can result from the kernel thrashing, or rapidly swapping processes to and from swap space on the disk. Check the free command or /proc/meminfo to see how much of the real memory is being used for buffers. If there isn't much buffer memory (and the rest of the real memory is taken), then you need more memory. A situation where the kernel does not have a piece of memory ready when a program wants to use it is called a page fault (the kernel breaks memory into small chunks called pages). When you get a lot of page faults, it bogs the system down because the kernel has to work to provide the pages, robbing normal processes of their chance to run. Thevmstat command tells you how much the kernel is swapping pages in and out, how busy the CPU is, and a number of other things. It is probably the single most powerful memory-performance monitoring tool out there, but you have to know what the output means. Here is some output from vmstat 2, which reports statistics every two seconds: procs r b w 2 0 0 0 0 0 0 0 0 0 0 0 ...

swpd 145680 145680 145680 145680

memory free buff 3336 5812 3328 5812 3328 5812 3328 5812

cache 89496 89496 89496 89496

swap si so 1 1 0 0 0 0 0 0

io bi 2 0 0 0

bo 2 0 42 0

system in cs 2 2 102 38 111 44 101 35

us 2 0 1 0

cpu sy 0 0 0 1

id 0 99 99 99

The output falls into categories: procs for processes, memory for memory usage, swap for the pages pulled in and out of swap, io for disk usage, system for the number of times the kernel switches into kernel code, and cpu for the time used by different parts of the system. The preceding output is typical for a system that isn't doing much. You need to ignore the first line of

numbers because it's incomplete and doesn't make sense. Here, the system has 145680KB of memory swapped out to the disk (swpd) and 3328KB of real memory free, but it doesn't seem to matter, because thesi and so columns report What that the kernel is not swapping anything in or out from the disk. (In this How Linux Works: Every Super-User Should Know example, Mozilla is Ward taking up extensive residence on the swap partition. Mozilla has a habit of loading a lot ISBN:1593270356 by Brian of stuff into memory is started, No Starch when Press ©it2004 (347 pages)never bothering to actually use it.) The buff column indicates the amount of memory that the kernel is using forofdisk buffers. This guide describes the inner workings a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers withdistribution Samba. On the far right, you see the of CPU time, under us,sy, and id. These are the percentages of time that the CPU is spending on user tasks, system (kernel) tasks, and idle time. In the preceding example, there aren't too many user processes running (using a maximum of 1 percent of the CPU), the Table of Contents kernel practically nothing, while the Know CPU is sitting around doing nothing 99 percent of the time. How Linuxdoing Works—What Every Super-User Should Chapter 1

- The Basics

Now, watch what happens when a and big,the nasty program Chapter 2 - Devices, Disks, Filesystems, Kernel

starts up sometime later (the first two lines are right

before3 the program runs): Chapter - How Linux Boots Chapter 4

- Essential System Files, Servers, and Utilities

Chapter procs5

- Configuring Your Networkmemory swap - Network Services swpd free buff cache si so Chapter - Introduction to Shell7312 Scripts58980 1 0 07 140988 4668 0 0 Chapter - Development Tools 7312 58980 0 0 08 140988 4668 0 0 Chapter - Compiling 3056 Software 6780 From Source Code 6 1 0 09 140988 58496 14 Chapter - Maintaining the Kernel 1 1 010 140988 3304 5900 58364 32 268 Chapter - Configuring and Manipulating Peripheral88 Devices 0 0 0 011 140988 3496 5648 58160 Chapter - Printing 3300 1 0 012 140988 5648 58248 0 0 Chapter - Backups 3056 2 3 013 140988 4208 59588 42 14 Chapter - Sharing Files with Samba 2 1 014 140464 3100 2608 65416 16 96 Chapter - Network File Transfer 4 0 015 140392 3180 2416 69780 0 14 Chapter - User Environments 2 2 016 140392 3056 2428 73076 106 0 Chapter - Buying Hardware Linux 81544 2 1 017 141176 4072 for2112 28 220 Chapter - Further Directions 1 2 018 141636 3056 1892 87012 0 1960 Appendix - Command 3056 Classification 3 0 0 A145960 1876 89864 0 3044 Bibliography ... Chapter r b w6

bi 0 0 1506 100 250 38 2062 2398 4490 7184 7314 3532 1458

io bo 0 0 14 268 0 0 14 176 14 68 252 1974 3056

system in cs 118 148 101 31 174 2159 195 2215 186 573 188 1792 249 1395 437 713 481 704 549 1173 514 1748 504 1054 490 876

us 0 0 23 41 4 11 20 3 1 0 20 2 1

cpu sy id 0 100 0 99 5 72 5 53 6 89 6 83 6 74 11 85 5 94 9 90 19 61 7 91 6 92

Index List of Figures

The CPU starts List of Tables

to see some usage for an extended period, especially from user processes. The amount of starts to deplete as the new program requires new pages, and the kernel starts to kick pages out into swap space (the so column) to make space. Unfortunately, as the kernel does this, it has to wait for the disk to do its work, and the CPU sits idle while processes block (the b column), because they also have to wait for the memory pages that they need. You can see the effects of swapping all over the output here; more memory would have fixed this particular problem.

buffer space List of Sidebars

This section hasn't explained all of the vmstat output columns. You can check on them in the vmstat(8) manual page, but you may have to learn more about operating systems first from a class or a book like Operating System Concepts [Silberschatz]. However, try to avoid getting really obsessed with performance. If you're trying to squeak 3 percent more speed out of something and you're not working on a huge computation, you're probably wasting your time.

How Linux Works: What Every Super-User Should Know 4.11Running Commands as the Superuser by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347commands, pages) Before you see any more system you should learn more about how to run commands as the This probably guide describes the inner of can a Linux withand the file system process and superuser. You already knowworkings that you runsystem the subeginning command enter the and rootboot password to covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and start a root shell. This practice works, but it has these disadvantages: sharing printers with Samba.

You have no record of system-altering commands.

Table of Contents

How Linux Every of Super-User Should YouWorks—What have no record the users who Know performed Chapter 1

ChapterYou 2 -don't Devices, Disks, Filesystems, the Kernel have access to yourand normal familiar Chapter 3

system-altering commands.

- The Basics

shell environment.

- How Linux Boots

to type theFiles, rootServers, password. ChapterYou 4 -have Essential System and Utilities Chapter 5

- Configuring Your Network

Most larger workstation installations employ a package named sudo to allow administrators to run - Network Services commands as root when they are logged in as themselves. For example, if you want to use vipw to edit Chapter 7 - Introduction to Shell Scripts the/etc/passwd file, you could do it like this: Chapter 8 - Development Tools Chapter 6

Chapter 9

- Compiling Software From Source Code

sudo 10 vipw Chapter - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

When13 you run this Chapter - Backups

command, sudo logs this action with the syslog service under the local2 facility, so that

you have recordFiles of what you did. Chapter 14 - a Sharing with Samba Chapter 15 - Network File Transfer

Of course, the system doesn't let just any user run commands as the superuser; you must configure the privileged users in the /etc/sudoers file. As it turns out, sudo has a great many options (that you'll Chapter 17 - Buying Hardware for Linux probably never use), and the side effect of this is that the /etc/sudoers file has a somewhat Chapter 18 - Further Directions complicated syntax. Here is an example file that gives user1 and user2 the power to run any command Appendix A - Command Classification as root without having to enter a password: Bibliography Chapter 16 - User Environments

Index

User_Alias List of Figures

ADMINS = user1 , user2

List of Tables List of Sidebars ADMINS ALL

root

= NOPASSWD: ALL

ALL=(ALL) ALL

The first line defines an ADMINS user alias with the two users, and the second line grants the privileges. TheALL = NOPASSWD: ALL part means that the users in the ADMINS alias can use sudo to execute commands as root. The second ALL means "any command." The first ALL means "any host" (if you have more than one machine, you can set different kinds of access for each machine or for groups of machines, but this book will not explain that feature). Theroot ALL=(ALL) ALL simply means that the superuser may also use sudo to run any command on any host. The extra (ALL) means that the superuser may also run commands as any other user. You can extend this privilege to the ADMINS users by changing the /etc/sudoers line shown earlier to this: ADMINS ALL = (ALL) NOPASSWD: ALL

Note Use the visudo command to edit /etc/sudoers. This command checks for file syntax errors after you save the file. That's all you need to know about sudo for now. If you need its more advanced features, consult the sudoers(5) and sudo(8) manual pages.

4.11.1Real UID and Effective UID When changing user IDs with programs like sudo, keep in mind that there is more than one active user ID in a running program. The ID that controls your access rights is the effective user ID. When you run a setuid program, Linux sets the effective user ID to the program's owner during execution, but it keeps your original user ID in what is called a real user ID.

There is an additional saved user ID that is set to the program's owner when you run a setuid program. The idea is that a process can switch its effective user ID to the real or saved user ID during execution to perform different tasksWorks: as different user IDs. How Linux What Every Super-User Should Know by Brian Ward

ISBN:1593270356

The reason that you might different user IDs is that, by default, sudo changes the real user ID along No Starch Press © see 2004 (347 pages) with the effective and saved user IDs.workings Some programs don't like to have realfileuser ID of you do This guide describes the inner of a Linux system beginning withathe system androot. boot If process and not want sudo to change thetopics real such useras ID,networking, add this line to your /etc/sudoers file: covering advanced firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Defaults

stay_setuid

Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 5: Configuring Your Network by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Networking is the practice of sending data from one computer to another computer. For a simple connection to the Internet, you need to do the following:

Table of Contents

How Linux Works—What Every Super-User Should Know

Connect a network interface on your machine to a network

Chapter 1

- The Basics

ChapterDefine 2 - Devices, Disks,to Filesystems, the Kernel a gateway the rest ofand the Internet Chapter 3

- How Linux Boots

ChapterShow 4 - Essential System Files, Servers, andhostnames Utilities your machine how to resolve Chapter 5

- Configuring Your Network

Unfortunately, there are so Chapter 6 - Network Services

many different kinds of networks that there is no one simple formula to get your system talking to the rest of the world. For Ethernet connections with a static (fixed) IP address, a separate Chapter 7 - Introduction to Shell Scripts command or file performs Chapter 8 - Development Tools each of the preceding steps. However, DHCP (Dynamic Host Configuration Protocol) and PPP (Point-to-Point Protocol) connections use different configuration Chapter 9 - configurations Compiling Software From Source Code schemes. This chapter Chapter 10 - Maintaining the begins Kernel with setting up static Ethernet interfaces because they are easy to understand, and thenand it moves on toPeripheral DHCP and PPP, including DSL (Digital Subscriber Line) and PPPoE Chapter 11 - Configuring Manipulating Devices (PPP 12 over Ethernet) connections. Chapter - Printing Chapter 13 - Backups

After you know how to connect your machine to a network, you're ready to move on to more advanced topics, such as building your own networks and configuring firewalls, described later in this chapter. Chapter 15 - Network File Transfer Chapter 14 - Sharing Files with Samba Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 5.1 Network Layers by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) If you really No want to understand Linux network configuration, you must be able to distinguish each layer in guide the in inner of from a Linux system beginning with the filelevel: system and boot process and the network.This Here aredescribes the layers theworkings Internet, the top level to the bottom

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Application Layer Contains the "language" that applications and servers use to communicate; usually a protocol of some sort. Common application layer protocols include Hypertext Transfer Table of Contents Protocol (HTTP,Every used for the World How Linux Works—What Super-User ShouldWide Know Web), Secure Shell (SSH), and the File Transfer Protocol Chapter(FTP). 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots Transport Layer Defines the data transmission characteristics of the application layer. This is host- Essential System Files, Servers, and Utilities specific information, and it includes data-integrity checking, source and destination ports, and Chapter 5 - Configuring Your Network specifications for breaking application data into packets. TCP (Transmission Control Protocol) is the Chapter 6 - Network Services most common transport layer protocol. Chapter 4

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

ChapterInternet 9 - Compiling Codepackets LayerSoftware DefinesFrom howSource to move Chapterparticular 10 - Maintaining the Kernelrule packet-transit

from the source host to the destination host. The set for the Internet is known as IP (Internet Protocol). This is sometimes

Chaptercalled 11 - Configuring andlayer. Manipulating Peripheral Devices the network Chapter 12 - Printing Chapter 13 - Backups

Layer Defines ChapterHost-to-Network 14 - Sharing Files with Samba

how to send packets from the Internet layer across the physical medium, such as Ethernet or a modem. This is sometimes called the physical layer. Chapter 15 - Network File Transfer Chapter 16 - User Environments

This may overly complicated, Chapter 17 - sound Buying Hardware for Linux

but it's important that you understand it, because your data must travel through these layers twice before it reaches its destination. Your bytes leave the application layer on Chapter 18 - Further Directions the source host, then go down to the physical medium, across the medium, and then up again to the Appendix A - Command Classification application layer on the destination host. Bibliography Index

Unfortunately, the layers sometimes bleed in strange ways, and terms like TCP/IP reflect the integration. The distinction is only getting more vague — in particular, devices that once only dealt with the Internet List of Tables layer now sometimes look at the transport layer data to determine where to send data. List of Figures

List of Sidebars

To connect your Linux machine to the network, you need to concentrate on the Internet and host-tonetwork layers, so let's get straight to them. If you want to know a lot more about layers (and networks in general), look at Computer Networks [Tanenbaum]. Note You have heard of another set of layers known as the ISO OSI (Open Systems Interconnection) Reference Model. This is a seven-layer network model often used in teaching and designing networks, but this book does not cover the OSI model because it is of little practical use for understanding how Linux Internet networking works.

How Linux Works: What Every Super-User Should Know 5.2 The Internet Layer by Brian Ward

ISBN:1593270356

Pressit© is 2004 (347 pages) The InternetNo asStarch we know based on the Internet Protocol, version 4 (IPv4). The basic idea is that each describes inner workings of a Linux system beginning with where the file a system process and computer onThis theguide Internet has the a numeric IP address in the form of a.b.c.d, and dand areboot one-byte covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and numbers from 1 to 254, and b and c are one-byte numbers from 0 to 255. Technically, an IP address is just sharing printers with Samba. a four-byte (32-bit) number, but it's usually easiest to deal with the address as a dotted-quad sequence of decimal numbers, like 10.23.2.37, instead of something ugly like the hexadecimal 0x0A170225.

Table of Contents

How Linux Works—What Every Super-User Should Know

Asubnet is a group of IP addresses in some (hopefully) regular order. For example, the hosts between The Basics 10.23.2.1- and 10.23.2.254 could comprise a subnet, or all of the hosts between 10.23.1.1 and Chapter 2 - Devices, Disks, Filesystems, and the Kernel 10.23.255.254 could also be a subnet. Chapter 1 Chapter 3

- How Linux Boots

Chapter 4 -are Essential System Files, Servers, and Utilities how Subnets important because they determine

your packets move between different machines. To your machine must know that other computer's IP address. If the Chapter 6 - Network Services destination is on your local area network's subnet, your system can send the data directly to that host, but Chapter - Introduction to Shell Scripts if not, 7your machine probably has to send it to a gateway (or router) that transmits your data across Chapter 8 network - Development another on itsTools way to the final destination. Chapter 5 - Configuring Your Network communicate with another computer,

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

5.2.1More on Subnets

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

Asubnet defines Chapter 13 -mask Backups

a subnet; for example, the subnet mask for 10.23.2.1- 10.23.2.254 is the mask "covers" the bits in an address that are common to the subnet. For example, here are the binary forms of 10.23.2.0 and 255.255.255.0: Chapter 15 - Network File Transfer 255.255.255.0. InFiles pure binary form, Chapter 14 - Sharing with Samba Chapter 16 - User Environments Chapter 17 - Buying Hardware00001010 for Linux 10.23.2.0: Chapter 18 - Further Directions 255.255.255.0: 11111111

00010111 00000010 00000000 11111111 11111111 00000000

Appendix A - Command Classification Bibliography

Now, Index

let's "cover" the bits in 10.23.2.0 with the 1s in 255.255.255.0 by marking these bits in bold:

List of Figures List of Tables 10.23.2.0:

00001010 00010111 00000010 00000000

List of Sidebars

Look at the bits that aren't in bold. You can set any number of these bits to 1 to get a valid IP address in this particular subnet (with two exceptions: all 0s and all 1s). Putting it all together, you can see that a host computer with an IP address of 10.23.2.1 and a subnet mask of 255.255.255.0 can directly communicate with other computers that have IP addresses beginning with 10.23.2 (to talk to the rest of the Internet, your computer needs to use a gateway). You can denote this entire subnet as 10.23.2.0/255.255.255.0. If you're lucky, you will deal only with easy subnet masks like 255.255.255.0 or 255.255.0.0, but you may be unfortunate and encounter stuff like 255.255.255.192, where it isn't quite so simple to determine the set of addresses that belong to the subnet. It helps to know that 192 is 0xC0 in hexadecimal, from which you should be able to figure out what addresses belong to such a subnet. If you aren't familiar with conversion between decimal, binary, and hexadecimal formats, you should probably learn now. The dc (desk calculator) program has excellent facilities for converting between different radix representations. A common shorthand for subnet masks is to identify the number of bits at the start of the subnet mask that have a value of 1. For example, 255.255.255.0 contains 24 1-bits to start the 32-bit sequence, so you can write the earlier example of 10.23.2.0/255.255.255.0 as 10.23.2.0/24. Table 5-1 shows several example subnet masks. Table 5-1: Subnet Masks

Long Form

Short Form

255.0.0.0

8

255.255.0.0

16

255.240.0.0

12

255.255.255.0

24

255.255.255.192

26

Therefore, to specify 10.0.0.0/255.0.0.0, you can use 10.0.0.0/8. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 5.3 BasicHow ICMP Tools by Brian Ward

ISBN:1593270356

No Starch Press 2004 (347 pages) Before you configure your©network devices, you should learn how to use some ICMP (Internet Control This guide describes thepackets inner workings of a root Linuxout system beginning with the file system and boot process and Message Protocol) tools. ICMP help you problems with connectivity and routing.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

ping (see http://ftp.arl.mil/~mike/ping.html) is one of the most basic network debugging tools. It sends ICMP echo request packets to a host. If the host gets the packet and feels nice enough, it sends an ICMP Table of Contents echo response packet in return. How Linux Works—What Every Super-User Should Know Chapter 1 -that The Basics Let's say you run

ping 10.1.2.21 and you get this output:

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

PING 10.1.2.21 (10.1.2.21): 56 data - Essential System Files, Servers, and Utilities 64 bytes from 10.1.2.21: icmp_seq=0 Chapter 5 - Configuring Your Network 64 bytes from 10.1.2.21: icmp_seq=1 Chapter 6 - Network Services 64 bytes from 10.1.2.21: icmp_seq=2 Chapter 7 - Introduction to Shell Scripts 64 bytes from 10.1.2.21: icmp_seq=4 Chapter 8 - Development Tools 64 bytes from 10.1.2.21: icmp_seq=5 Chapter 4

Chapter 9

- Compiling Software From Source Code

bytes ttl=255 ttl=255 ttl=255 ttl=255 ttl=255

time=8.0 time=3.2 time=3.4 time=3.4 time=3.2

ms ms ms ms ms

Chapter 10 - Maintaining the Kernel Chapter 11 - important Configuring parts and Manipulating Peripheral Devices The most of the output are the icmp_seq

number and the round-trip time. ping sends a

Chapter 12 - Printing

sequence of echo request packets, one every second.

Chapter 13 - Backups

Chapter - Sharing withbetween Samba Notice14that there'sFiles a gap

2 and 4 in this example. This usually means that there's some kind of to get packets out of order, but if this happens, there's still some kind of Chapter 16 -because User Environments problem ping sends only one packet a second. If a response takes more than a second to arrive, Chapter 17 - BuyingisHardware for Linux the connection extremely slow. Chapter 15 - Network File Transfer connectivity problem. It is possible

Chapter 18 - Further Directions

The round-trip timeClassification is the total Appendix A - Command

elapsed time between the moment that the request packet was transmitted that the response packet arrived. If there are incomplete routes between the request source and the destination, ping immediately reports the ICMP "host unreachable" packets that come back as a Index result of the disconnection. List of Figures and moment Bibliography

List of Tables

OnofaSidebars wired LAN, List

you should expect absolutely no packet loss and very low numbers for the round-trip time (the preceding example output is from a wireless network). You should also expect no packet loss from your network to and from your ISP, as well as reasonable, steady round-trip times. Sadly, not all hosts on the Internet respond to ICMP echo request packets as they once did. Therefore, you may come across situations where you can connect to a Web site on a host, but not get a ping response. Another useful ICMP-based program is traceroute; it will come in handy when you reach the material on routing later in the chapter. Use traceroutehost to see the exact path your packets take to a remote host. One of the best things about traceroute is its reporting of return-trip times at each step in the route, as demonstrated in this output fragment:

4 5 6 7 8 9 10

206.220.243.106 1.163 ms 0.997 ms 1.182 ms 4.24.203.65 1.312 ms 1.12 ms 1.463 ms 64.159.1.225 1.421 ms 1.37 ms 1.347 ms 64.159.1.38 55.642 ms 55.625 ms 55.663 ms 209.247.10.230 55.89 ms 55.617 ms 55.964 ms 209.244.14.226 55.851 ms 55.726 ms 55.832 ms 209.246.29.174 56.419 ms 56.44 ms 56.423 ms

Because this output shows a big latency jump between hop 6 and hop 7, that part of the route is probably some sort of long-distance link. You can put these ICMP tools to use when setting up a working network interface, as the next few sections will show you how to do.

How Linux Works: What Every and Super-User Know 5.4 Configuring Interfaces theShould Host-to-Network Layer by Brian Ward

ISBN:1593270356

No Starchyou Press © 2004 (347 pages) On a Linux system, connect the Internet layer to the physical medium, such as an Ethernet network or This guide describes with the inner workings of a LinuxCommon system beginning with the file system boot process a modem-based connection, a network interface. network interface namesand are eth0 (theand advanced topics such as networking, firewalls, development tools, device management, shell scripts, and first Ethernetcovering card in the computer) and ppp0 (a PPP interface). sharing printers with Samba.

The most important command for viewing or manually configuring the network interface settings is see your current interface's settings, run this command:

Table of Contents ifconfig. To

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

ifconfig -a - Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

You do not need the -a in Linux, but other Unix variants require this option. The output should look - Network Services something like this:

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

eth0 9 Chapter

Link Software encap:Ethernet HWaddr - Compiling From Source Code

00:40:05:A0:7F:96 Bcast:10.1.2.255 Mask:255.255.255.0 UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 - Configuring and Manipulating Peripheral Devices RX packets:806961 errors:1 dropped:0 overruns:0 frame:0 - Printing TX packets:811658 errors:0 dropped:0 overruns:0 carrier:0 - Backups collisions:0 - Sharing Files with Samba RX bytes:726765161 (693.0 Mb) TX bytes:110229902 (105.1 Mb) - Network File Transfer

inet addr:10.1.2.2 Chapter 10 - Maintaining the Kernel Chapter 11 Chapter 12 Chapter 13 Chapter 14 Chapter 15

Chapter 16 - User Environments

lo 17 - Buying Link encap:Local Chapter Hardware for Linux

Loopback Mask:255.0.0.0 UP LOOPBACK RUNNING MTU:16436 Metric:1 Appendix A - Command Classification RX packets:44 errors:0 dropped:0 overruns:0 frame:0 Bibliography TX packets:44 errors:0 dropped:0 overruns:0 carrier:0 Index collisions:0 List of Figures RX bytes:3569 (3.4 Kb) TX bytes:3569 (3.4 Kb) List of Tables inet addr:127.0.0.1 Chapter 18 - Further Directions

List of Sidebars

The left side contains interface names, and the right side contains the settings for each interface. You can see that each interface has an IP address (inet addr) and a subnet mask (Mask), but you should also take careful note of the lines containing UP and RUNNING, because these tell you that the interface is working. Thelo interface is a virtual network interface that is called the loopback because it "loops back" to itself. 127.0.0.1 is the IP address of localhost, so connecting to this address is the same as connecting to the machine that you're currently using. Your system calls ifconfig from one of its init.d scripts at boot time to configure the lo loopback interface. It's the only part of the network that is actually the same on any Linux machine, so it's a great place to start when you're trying to figure out how your particular distribution sets up networks. For example, in Red Hat Linux, each network interface has a script in /etc/sysconfig/networkscripts. You should be able to find the loopback device configuration by digging around in /etc with grep ifconfig. If you have a static IP address on an Ethernet interface, your system's boot sequence should set up the interface in a manner very similar to the loopback. However, you can manually configure an IP address and netmask for an Ethernet network interface named eth0 with this command: ifconfig eth0 address netmask mask

The preceding command allows your machine to talk to every other host in the subnet defined by address and mask, but it does not let you go beyond the subnet, because you have not supplied a default gateway (gateways will be explained in the next section ). If you do not connect your system to the network with a static IP address on an Ethernet network, but rather, have a link such as a PPP or PPP-over-Ethernet (PPPoE) DSL connection, or if you use DHCP to get host information, you do not configure your interface with ifconfig (see Sections 5.7,5.8, and 5.9 for those cases). However, even with those other types of connections, ifconfig -a is very useful for

debugging. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 5.5 Configuring a Default Gateway by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) In the previous section , you saw how to manually configure an Ethernet network interface with a particular guide describes the innerto workings of a outside Linux system with the fileasystem and boot process and address andThis mask. You can connect networks yourbeginning subnet by adding default gateway to your covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and kernel's IP routing table with this command: sharing printers with Samba.

route add default Table of Contents

gw gw-address

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 7

- Introduction to Shell Scripts

Chapter 9

- Compiling Software From Source Code

Thegw-address parameter is theand IP address Chapter 2 - Devices, Disks, Filesystems, the Kernelof

your default gateway; it must be an address in a locally connected subnet defined by the address and mask settings of your network interface (as described in Chapter 3 - How Linux Boots theprevious section ). If you have a static IP address, a default route setting usually goes along with an Chapter 4 - Essential System Files, Servers, and Utilities ifconfig commandYour in your boot sequence. For other kinds of connections, other programs usually set Chapter 5 - Configuring Network the default route. Services Chapter 6 - Network To view current default Chapter 8 the - Development Tools

route, run this command:

Chapter - Maintaining the Kernel route10 -n Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

The output should Chapter 13 - Backups

look something like this:

Chapter 14 - Sharing Files with Samba Chapter 15 -IP Network File Transfer Kernel routing table Chapter 16 - User Environments Destination Gateway Chapter 17 - Buying Hardware for Linux 10.1.2.0 0.0.0.0 Chapter 18 - Further Directions 0.0.0.0 10.1.2.1

Genmask 255.255.255.0 0.0.0.0

Flags Metric Ref U 0 0 UG 0 0

Use Iface 0 eth0 0 eth0

Appendix A - Command Classification Bibliography

Theifconfig Index

command that configured the eth0 network interface in this example added the first route the last line is the default gateway, because it has a netmask of 0.0.0.0, which allows the List of Tables host to reach all other hosts on the Internet. The gateway's IP address is 10.1.2.1, and you can see that you that gateway through the eth0 network interface. List of reach Sidebars List of Figures line. However,

If you mistype a gateway address when adding a route, you cannot attach another gateway until you delete the erroneous entry. To remove the current default gateway, run this command: route del -net default

Figure 5-1 on the next page shows a typical local area network with a gateway, or router. The subnet is 10.1.2.0/255.255.255.0 with a default gateway of 10.1.2.1. Each IP address represents a network interface, as does the uplink IP on the gateway. If you do not run the gateway, you do not need to worry about its uplink — for example, if you are configuring a host with an IP address of 10.1.2.4, you need only know that 10.1.2.1 is the local IP address on the gateway.

Figure 5-1: A typical local area network with an Internet link.

Note If your netmask is 255.255.255.0, your router is probably at node 1 of the subnet (for example, 10.1.2.1 in 10.1.2.0/255.255.255.0). This is convention, not necessarily reality. A properly configured default gateway allows you to connect to the rest of the world. However, you still

need to know how to convert common names, or hostnames, to IP addresses. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How LinuxHostnames Works: What Every Super-User Should Know 5.6 Resolving by Brian Ward

ISBN:1593270356

No configuration Starch Press © 2004 pages) network connection is hostname resolution. Simply put, your The last bit of for (347 a simple This guide describes inner workings of a Linux beginning with the file system and boot process and computer needs to know how the to translate a name such system as www.example.com to an IP address. Without covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and this capability, your Internet connection is practically worthless — no one in their right mind advertises IP sharing printers with Samba. addresses for Web sites and email addresses, partly because a host's IP address is subject to change, but also because it's not easy to remember a bunch of numbers.

Table of Contents

How Works—What Should TheLinux most basic wayEvery to doSuper-User this mapping is Know with the Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

/etc/hosts file, which looks like this:

127.0.0.1 localhost - How Linux Boots 10.1.1.3 atlantic.aem7.net Chapter 4 - Essential System Files, Servers, and Utilities 10.1.1.4 pacific.aem7.net Chapter 5 - Configuring Your Network Chapter 3

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

atlantic pacific

In the bad old days, there was one central hosts file that everyone repeatedly copied to their own - Compiling Software From Source Code machine to stay up to date. This might have worked for a handful of machines, but as the Chapter 10 - Maintaining the Kernel ARPANET/Internet grew, this quickly got out of hand. The Domain Name System (DNS) decentralized Chapter 11 - Configuring and Manipulating Peripheral Devices hostname resolution. The idea is that your machine's resolver (in the C library) asks a nameserver for the Chapter 12 - Printing IP address corresponding to a hostname. If the nameserver does not know, it can find out who is Chapter 13 - Backups responsible for that name and ask for the IP address from the responsible party's nameserver. If you do Chapter 14 - Sharing Files with Samba not already know the DNS server addresses that your ISP uses, ask your provider for them. Chapter 9

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Let's say that your ISP's nameserver addresses are 10.32.45.23 and 10.3.2.3. Put the servers in your like this:

Chapter 17 /etc/resolv.conf - Buying Hardware for Linux system's file Chapter 18 - Further Directions Appendix A - Command Classification

search mydomain.example.com example.com nameserver 10.32.45.23 Index nameserver 10.3.2.3 List of Figures Bibliography

List of Tables List of Sidebars

Thesearch line in the preceding example asks the resolver to look for the IP address of host.mydomain.example.com, and for host.example.com if you ask for an incomplete domain namehost that does not resolve on the first attempt. For a simple network configuration where you do not have control of your own nameserver, there is little else to know about DNS except how to make sure that your machine's hostname resolution works. To verify this, type hostknown_name where known_name is some Internet name that you know exists (such as www.example.com ). The output should be something like this:

known_name has address 10.218.44.5

You should also be able to look up a name based on its IP address with hostaddress. If the address owner is doing their part, you should get the hostname corresponding to address, but DNS administrators often do not configure their servers to return these hostnames. Furthermore, the mapping of hostname to address is not one-to-one; you can have many hostnames for a single address. Before moving on, take a look at /etc/nsswitch.conf. It should have a line like this: hosts:

files dns

Puttingfiles ahead of dns here ensures that your system checks the /etc/hostsfile for the hostname of your requested IP address before asking the DNS server. This is usually a good idea (especially for looking up localhost), but your /etc/hosts file should be as short as possible. Don't put anything in there because you want to boost performance; it will burn you later. You can put all the hosts within a small private LAN in /etc/hosts, but the general rule of thumb is that if a particular host has a DNS entry, it has no place in /etc/hosts.

Note The/etc/hosts file is also useful for resolving hostnames in the early stages of booting, when the network may not be available.

DNS is a fairly broad topic, and if you have any responsibility for domain names, have a look at DNS and BIND [Albitz]. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 5.7 Using DHCP Clients by Brian Ward

ISBN:1593270356

NoHost Starch Press © 2004 (347Protocol pages) The Dynamic Configuration (DHCP) allows a host to get its IP address, subnet mask, default Thisservers, guide describes the inner workings of a Linux beginning file system and bootthese process and gateway, DNS and other information from the system network, so thatwith youthe don't have to type covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and parameters by hand. Network administrators like DHCP because users don't have to nag them for IP sharing printers with Samba. addresses when they want to connect to the network. Table Contents Likeof ifconfig,

DHCP works on a network interface name. All Linux distributions have a network interface setup option for DHCP, so if you don't feel like digging around to try to find out what file controls the Chapter 1 - The Basics interface settings, it's all right to let your distribution's setup program do the work. How Linux Works—What Every Super-User Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter - How Linux Boots When3your machine asks

a DHCP server for an IP address, it is really asking for a lease on an address for your machine can ask to renew the lease.

Chapter 4 -amount Essentialof System Servers, and Utilities a certain time.Files, When the lease is up, Chapter 5

- Configuring Your Network

Most distributions use the Chapter 6 - Network Services

ISC (Internet Software Consortium) dhclient program to request and retrieve server. To get a lease, you can run dhclient by hand on the command line, but before Chapter 8 - Development Tools doing so you must remove any default gateway route. Once you have done that, you can anSoftware IP leaseFrom by running the following command: Chapter 9 request - Compiling Source Code IP address information fromScripts a DHCP Chapter 7 - Introduction to Shell

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring dhclient eth0 and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing with Samba dhclient storesFiles its process ID

in /var/run/dhclient.pid and its lease information in

Chapter 15 - Network File Transfer /var/state/dhclient.leases. Chapter 16 - User Environments

Red Hat versions and earlier Chapter 17 -Linux Buying Hardware7for Linux pump 18 -i- Further interface, but Chapter Directions

use a program called pump instead of dhclient. You can run it with you may want to consider getting dhclient from ISC or as an RPM.

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 5.8 PPP How Connections by Brian Ward

ISBN:1593270356

No Starch Press © 2004 connections (347 pages) So far, you have seen Internet based on a local area network (LAN) and a default gateway on guide describes inner workings and of a Linux systemline beginning with the and boot that network.This However, if you the have a modem telephone to connect tofile thesystem Internet, you process cannotand use covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and the same host-to-network layer interfaces described in previous sections because your connection does sharing printers with Samba. not run over the Ethernet physical medium. Table of Contents

The most popular standard for single-machine Internet connectivity with a modem is PPP (Point-to-Point Protocol). Although PPP is a very flexible protocol, its main use is to connect one machine without a direct Chapter 1 - The Basics IP connection to second machine (a PPP server) that has one, with the second machine possibly asking Chapter 2 - Devices, Disks, Filesystems, and the Kernel the first for a username and password along the way. How Linux Works—What Every Super-User Should Know

Chapter 3

- How Linux Boots

Chapter - Essential Files, Servers, and Utilities When4you dial up System and register with a PPP server,

the server gives you your own IP address and tells you initiates, the PPP software on your machine knows how to reach Chapter 6 - Network Servicesand the server knows how to reach your machine's IP address. To reach the rest the server's IP address, Chapter - Introduction to the Shelldefault Scripts gateway to the server's IP address and let the server do the rest. Figure of the 7Internet, you set Chapter 8 - Development Tools your local IP address and the server's IP address. As with the routers in LANs, 5-2 shows the link between Chapter - Compiling From the Source Code uplink IP address. you do9 not need to Software worry about server's Chapter Configuring about 5its -IP address.Your AfterNetwork the connection

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Figure 5-2: A typical PPP link. Although it's nice to know how this process works, you are probably more interested in actually getting a connection to work. Specifically, you want to know the answers to these questions: How do I get my modem to dial the server's number? Where do I put my username and password? How do I start and stop a network interface like ppp0? The key to the whole mess is a pppd, a system daemon that acts as an intermediary between a serial port on your machine and a PPP network interface such as ppp0. To set up everything, you need to do four things: 1. Verify that your serial port, modem, and login (username and password) work. 2. Create an options file in /etc/ppp/peers containing configuration options. 3. Create a chat script to make your modem dial out (and possibly log in). 4. Set up Password Authentication Protocol (PAP) or Challenge Handshake Authentication Protocol (CHAP) user authentication if necessary. These four steps are explained in the following sections. If your distribution's dial-up configuration tool works for you, it may not be worth your while to read through these sections. However, if you don't read through them, at least run ifconfig when you're connected to see what the PPP interface name is, because you may need it later in the chapter for Network Address Translation (NAT) or firewalling.

5.8.1Testing Your Serial Port and Modem Before you start with the full pppd setup, you should use minicom to make sure that your modem works

and that you can initiate a PPP connection. Modems talk to your computer through serial port devices, so the first thing you need to do is determine the serial port that your modem is connected to. How Linux Works: What Every Super-User Should Know

Note Don't try toWard use a Winmodem with Linux. See Section 17.2.4. by Brian

ISBN:1593270356

No Starch Press © 2004 (347 pages)

As mentioned in Section 2.3.2, Linux serial port devices are at /dev/ttyS*. If you're having problems, This guide describes the inner workings of a Linux system beginning with the file system and boot process and it's best to check your boot messages described firewalls, in Section 4.1 to see if the modem setup looks right and covering advanced topics such as as networking, development tools, device management, shell scripts, and to verifysharing that you're printers using with Samba. the correct serial port device. In addition, you can run cat /proc/ioports for more port statistics. Most modern hardware and kernels actually recognize the hardware configuration correctly, but if you have extra serial ports on different hardware interrupt numbers Table of Contents (IRQs), you may need to Super-User run setserial to specify the hardware parameters that the serial port uses. For How Linux Works—What Every Should Know example: Chapter 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 - How/dev/ttyS3 Linux Boots setserial

irq 5

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6 setserial(8) - Network Services See the manual Chapter 7

page for more options and a good overall explanation of serial ports.

- Introduction to Shell Scripts

Now you get downTools to the Chapter 8 -can Development

business of checking the connection to the dial-up server with these steps: and other minicom settings with this command:

Chapter - Compiling Software From serial Source port, Code 1. 9Configure the baud rate, Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

minicom -s

Chapter 12 - Printing

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

2. After choosing your settings, exit the configuration menu. minicom then attempts to connect to the serial port.

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter - Buying Hardware Linux 3. 17Upon success, youforshould Chapter 18 - FurtherYou Directions ENTER. should

be able to enter AT commands. Test it by typing AT and then pressing get OK as a response. If you're having trouble, skip to step 7 and then back to

Appendix step A - Command Classification 1. Bibliography Index 4.

Reset your modem (that is, clear its volatile data) and dial your ISP's number by typing these two commands:

List of Figures modem List of Tables List of Sidebars

atz atdtnumber

5. Your modem should connect with a CONNECT message. W ait five or ten seconds after you see the CONNECT message. You're looking for "garbage" like this: ~ÿ}#À!}!}!} }.}%}&} } If you get this junk immediately after you see the CONNECT message, you've got a PPP connection, and furthermore, you probably need to use the PAP or CHAP authentication system when dialing up. Make a note of this and skip to the last step. 6. If you get something like Username: instead, type in your username (and password, if necessary). After logging in, keep going (you might need to type ppp or something similar) until you get the "garbage" mentioned in the previous step. In this case, you probably do not need to use PAP or CHAP. 7. Exitminicom by pressing CONTROL-A, then x. If minicom hangs when you're trying to exit, you can wait a little while to see if it times out, or you can be impatient, open another window, and use kill -KILL on the minicom process. When interacting with the modem and remote server, take careful notes of all the settings you used, what you had to type, and the responses you got back. You'll need this information to write a chat script.

5.8.2Starting pppd with Options Files Now that you know how to log in to your ISP's server manually, you can create a configuration file containing the same connection settings you used with minicom -s. This allows you to make pppd dial the telephone number automatically.

Pick a name for the ISP and create an options file called /etc/ppp/peers/name, with the following lines: How Linux Works: What Every Super-User Should Know ISBN:1593270356 by Brian Ward ttyS1 115200 crtscts No Starch Press © 2004 (347 connect '/usr/sbin/chat -vpages) -f /etc/ppp/chat-name' This guide describes the inner workings of a Linux system beginning with the file system and boot process and noauth covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and defaultroute sharing printers with Samba. mru 1500

Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

The first line specifies the modem device, the CPU-to-modem speed, and the hardware flow control. You - Devices, Disks, Filesystems, and the Kernel will read about these options in Section 5.8.5. Don't bother to tweak anything yet; for now, just make sure Chapter 3 - How Linux Boots that your pppd can start properly. Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 - Configuring Your Network Now make a chat file named /etc/ppp/chat-name.

This chat file determines the connection - Network Services commands sent through the serial line and the responses that you expect from your ISP. For now, just fill it Chapter 7 following - Introduction to Shell Scripts with the lines, where number is your ISP's telephone number: Chapter 6 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

ABORT10 "NO CARRIER" Chapter - Maintaining the Kernel ABORT11 BUSY Chapter - Configuring and Manipulating Peripheral Devices "" ATZ Chapter 12 -OK Printing ATDTnumber CONNECT Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Try to establish a connection by starting pppd with this command:

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

pppd 18 call name Chapter - Further Directions Appendix A - Command Classification Bibliography

Monitor Index

the progress by looking at your system log. The pppd syslog facility name is daemon, so the log information List of Figures is probably in /var/log/daemon.log or something similar. However, the chat program used for initializing the modem connection may use a different facility, such as local2. List of Tables List of Sidebars

You should get messages like this in your log file: Jul Jul Jul Jul

29 29 29 29

18:40:46 18:40:47 18:40:47 18:40:48

mikado mikado mikado mikado

pppd[634]: chat[635]: pppd[634]: pppd[634]:

pppd 2.4.1 started by root, uid 0 [chat messages] Connect script failed Exit.

Take a careful look at the chat messages. They should tell you if the modem is dialing up, and if it gets an answer and connection from the remote server. Even if the preceding connection settings work so far, expect the configuration to fail because you haven't supplied a username and password. W atch the failure in the log carefully, because it tells you how to proceed. For example, if the log file says Connect script failed as in the preceding example, then you have a problem with the dial-up portion (in addition to not having supplied a username and password). In particular, look out for these types of failures: I/O errors happen when your serial port and modem are not set up correctly. Double-check the first line of the options file to make sure it matches the settings that you verified earlier with minicom. If the remote system uses PAP or CHAP, expect an authentication error. Skip to Section 5.8.4 to see how to configure PAP and CHAP. Timeouts generally go along with incomplete chat scripts. Proceed to the next section to see how to finish your script. Bad chat output, such as NO CARRIER and BUSY, are signs of telephone line problems. Doublecheck the ISP's telephone number. To stop a PPP daemon after it finishes its chat sequence, use the following command, substituting the appropriate network interface name if yours is not ppp0:

kill `cat /var/run/ppp0.pid` How Linux Works: What Every Super-User Should Know by Brian Ward 5.8.3Chat Scripts No Starch Press © 2004 (347 pages)

ISBN:1593270356

guide describes the inner workings of a Linux system beginning with the file system and boot process and Achat scriptThis is a file containing commands that go out through the serial line and responses that you covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and expect to receive thewith serial line (the responses come from the modem or ISP, depending on the sharingfrom printers Samba. current stage of the dial-up process). Recall this chat script line from the previous section: Table of Contents How Linux Works—What Every Super-User Should Know ATDTnumber CONNECT Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

This means that theBoots chat Chapter 3 - How Linux

program should dial with the ATDTnumber modem command and expect a response, chat moves to the next thing in the chat file. After stepping through the entire file, and assuming that everything goes as anticipated, chat returns Chapter 5 - Configuring Your Network success pppdServices proceeds with a PPP connection. Chapter 6 and - Network response CONNECT. After a CONNECT Chapter 4 - of Essential System Files,receiving Servers, and Utilities

Chapter 7

- Introduction to Shell Scripts

The details of your chat script Chapter 8 - Development Tools

depend on your ISP, and you should be armed with the information you got script. However, here is a script that works for most service providers use Cisco equipment (where username is your username and password is your password): Chapter 10 - that Maintaining the Kernel inSection before trying to complete your Chapter 9 - 5.8.1 Compiling Software From Source Code

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter - Printing ABORT12 "NO CARRIER" Chapter - Backups ABORT13 BUSY Chapter 14 -OK Sharing Files with Samba "" ATZ Chapter 15 - Network File Transfer ATDTnumber CONNECT Chapter 16 - User Environments "" ername: Chapter 17 - Buying Hardware for Linux username ssword: Chapter 18 - Further \qpassword > Directions Appendix A - Command Classification

ppp

Bibliography Index List of ABORT Figures The

keywords and strings at the top of the script cause chat to exit with an error if it encounters strings. In addition, \qstring tells chat not to send string to syslogd. In this case, it List of chat Sidebars tells not to send password to syslogd when making a record of the connection. List of Tables one of those

Remember that if you use PAP or CHAP, your chat script likely should not contain any username or password information. However, if your chat script does contain username and password details (like the preceding script), you should be mostly done after you finish the script — try to verify the connection with ifconfig -a, and try to access the Internet. If everything works, skip to Section 5.8.5 for information on how to tweak your options file. Note For more information on chat, see the chat(8) manual page.

5.8.4PAP and CHAP Many dial-up ISPs require that logins use PAP (Password Authentication Protocol) or CHAP (Challenge Handshake Authentication Protocol). If your ISP has such a requirement, get started by adding the following entry for your username to the end of the /etc/ppp/peers/name options file from Section 5.8.2: nameusername

Warning Don't put require-pap in your options file. This option is primarily for running a PPP gateway; it requires the remote system to authenticate with your system.

PAP If your ISP uses a PAP server, edit /etc/ppp/pap-secrets. The lines in that file have this format: your_hostname

remote_hostname

password

ip_address

The references to hostnames are primarily for use by PPP servers. For a simple client machine, you can put this in pap-secrets: How Linux Works: What Every Super-User Should Know

username

by Brian Ward * No Starch Press © 2004 (347 pages)

password

ISBN:1593270356

*

This guide describes the inner workings of a Linux system beginning with the file system and boot process and advanced topics such as networking, development tools, device management, The* meanscovering to accept any remote hostname. Don'tfirewalls, bother with the IP address, either, becauseshell thescripts, serverand sharing printers with Samba. should give you one. Table Contents Theofpreceding

instructions will work if you have only one ISP. However, if you have multiple ISPs, do the

How Linux Works—What following for each: Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

1. Pick a name for the ISP (isp_name).

Chapter 3

- How Linux Boots 2. Add the following line to the ISP's options file in /etc/ppp/peers:

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

isp_name Chapter 6remotename - Network Services Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

3. Add the following to your pap-secrets file:

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 username - Printing

isp_name

password

*

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

CHAP

Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter Hardware for Linux If you 17 run- Buying into a CHAP server, proceed Chapter username 18 - Further and password Directionsinto

as you would with a PAP server and multiple ISPs, but enter the /etc/ppp/chap-secrets in the two-line format that follows:

Appendix A - Command Classification Bibliography

username isp_name

Index

List of Figures

isp_name username

your_password their_password

List of Tables List of Sidebars

5.8.5Options Files The options files in /etc/ppp/peers contain valid pppd command-line options. Therefore, you could run pppd at the shell prompt with these options as command-line arguments, and indeed, some distributions (like Red Hat Linux) use scripts to set up big pppd invocations, completely bypassing /etc/ppp/peers. However, it's far more convenient to use options files because they enable you to invoke pppd call file to activate the connection. Note In addition to the per-connection file in /etc/ppp/peers, you need a /etc/ppp/options file for global settings that apply to all pppd processes. This file must exist, even if it's empty. As mentioned earlier, the first two options in the options file are the serial device (with or without /dev/ at the front) and the serial port speed. For most serial ports and modems, 115200 is an appropriate speed, but you may wish to lower it to 57600 or lower for really slow systems. Recall that the following was the first options line in Section 5.8.2: ttyS1 115200 crtscts All other pppd options follow the serial port and baud rate. Here are some of the most important pppd options: crtscts Enables RTS/CTS hardware flow control (popular with PC hardware). defaultroute Sets the kernel's default route to the machine on the other side of the PPP connection. Don't forget this option; otherwise, you won't be able to reach anything on the Internet beyond the host on the other end of the PPP connection, which usually isn't very useful. If you happen to forget this when testing, you can manually add a route with the route command (see Section 5.11). noauth Specifies that the remote machine should not send you a username and password; this is another option that you don't want to forget.

connectcommand Initializes the serial port with the specified command, usually a chat invocation like this: How Linux Works: What Every Super-User Should Know by Brian Ward connect '/usr/sbin/chat -v -f /etc/ppp/chat-name'

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering such as networking, firewalls, development device management, scripts, and nodetach Runadvanced pppd intopics non-daemon mode; this prevents the shelltools, prompt from returningshell immediately sharing printers with Samba. after you run pppd from the command line. This is handy for debugging, because you can press CONTROL-C to interrupt a connection.

Table of Contents

How Linux Every Super-User Should mruWorks—What size The maximum receive unitKnow option

tells the remote server not to send any chunks of data The default is 1500 bytes; 3000 works for faster connections. Do not set this (or Chapter 2 - Devices, Disks, Filesystems, and the Kernel mtu) to a number lower than 1300, because many applications prefer that their data be sent in larger Chapter 3 - How Linux Boots chunks. Chapterlarger 1 - The Basics than size.

Chapter 4

- Essential System Files, Servers, and Utilities

Chaptermtu 5 size - Configuring Your Network The maximum transmission

unit option requests that your machine not send (transmit) any than size to the remote server. The default is 1500 bytes. The quality of your Chaptertelephone 7 - Introduction Shell Scripts line ortoswitch often determines how high you may set size. Chapterchunks 6 - Network Services of data larger Chapter 8

- Development Tools

Chaptername 9 - name Compiling Software From Source Codeas Forces pppd to use name

the username (or local system name) for PAP or CHAP

Chapterauthentication. 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapterremotename 12 - Printing name

Forces pppd to use name as the remote system name for PAP or CHAP

Chapterauthentication. 13 - Backups Chapter 14 - Sharing Files with Samba

Activates verbose Chapterdebug 15 - Network File Transfer

syslog debugging.

Chapter 16 - User Environments

Note your Hardware connection frequently Chapter 17 - If Buying for Linux

hangs or drops, and the ARQ light on your modem blinks often, you poor switch or telephone line. If you hear any "static" when you pick up your (especially before making a call), your telephone company may be overloading your Appendix A - telephone Command Classification Bibliography local phone switch. See if they will put you on a better switch. It's also possible that there's a problem between your phone jack and the phone network box in your building. Index have a Chapter 18 - probably Further Directions

List of Figures

The pppd(8) manual page has many more options. Keep in mind that most options are only relevant when you're running a PPP server, not a client. To be entirely truthful, there is no technical difference between a PPP server and a PPP client. They are simply peers that know how to contact each other. However, when one of the peers acts as a gateway to the rest of the Internet, you often say that this peer is the server.

List of Tables

List of Sidebars

5.8.6PPP Directory Permissions The/etc/ppp directory should be mode 700; that is, the superuser should have read-write-execute access, and no other users should have access. However, any user can run pppd call name if that user has read access to the chat script and pppd is setuid root. Some distributions do not trust pppd and do not have the setuid bit set by default. As with any program, the setuid bit is a certainly a matter of concern if you don't trust your own users, but it's not so critical if you're the only user on the system. There is no standard for which user should start PPP (or even how to set up the connection). PPP has always been somewhat clumsy to operate because the Internet grew up around networks that were always active. Broadband connections solve this problem, though not everyone has access to them (or wants them).

How Linux Works: What Every Super-User Should Know 5.9 Broadband Connections by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) The term broadband vaguely refers to connections faster than a conventional modem link. For most users, guide describes the inner workings of One a Linux beginning with the file system boot process and this means aThis DSL or cable modem connection. of system the most frustrating things aboutand broadband covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and providers is sharing that they don't tend to tell you what kind of technology they use. printers with Samba.

Most DSL or cable modems have an Ethernet port, requiring you to have an Ethernet interface on your computer, and as you saw in Section 5.4 , it's not hard to set up an Ethernet interface (in theory, at least). How Linux Works—What Every Super-User Should Know Unfortunately, not all providers send straight IP from the Ethernet port, so things can get more Chapter 1 - The Basics complicated.

Table of Contents

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 most - Howpart, Linuxyour Bootssetup For the

depends on the kind of broadband connection you have. These rules

Chapter 4 - apply: Essential System Files, Servers, and Utilities generally Chapter 5

- Configuring Your Network

Chapter 6

- Network Services Cable modem These devices usually speak straight IP, and you can do the network configuration with - Introduction to Shell Scripts DHCP. Plug your Linux machine into the cable modem and look at Section 5.7 . If you have a static Chapter 8 - Development Tools (fixed) IP address, you should be able to set up the connection by hand as described in Section 5.4 . Chapter 9 - Compiling Software From Source Code You may need to perform some configuration on the cable modem before it will connect to the outside Chapter 10 - Maintaining the Kernel world, but that's usually done with a Web browser. Chapter 7

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing ChapterDSL 13 - with Backups a dynamic

IP address DSL providers usually send PPP over Ethernet (PPPoE) through common kind of DSL connection, and as luck would have it, it's the Chaptermost 15 - complicated. Network File Transfer See Section 5.9.2 for more information on PPPoE. Chaptertheir 14 - devices. Sharing Files with This is Samba the most Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

a Directions static IP ChapterDSL 18 - with Further

address Some DSL providers talk straight IP over Ethernet if you have a fixed IP address. In this case, you can use the manual configuration described in Section 5.4 . Appendix A - Command Classification Bibliography

The preceding rules are based on the hardware available to service providers, but your provider may be different. Telephone companies prefer PPPoE because it's easier for them to monitor and authenticate, List of Figures but cable companies tend not to care. You can probably determine the type of connection the ISP provides List of Tables by looking at the setup instructions for Windows. If you see anything in the Windows screenshots with List of Sidebars "pppoe" in the name, it's probably a PPP-over-Ethernet connection. Index

Note If a broadband service forces you to use a modem or another device that doesn't have an Ethernet port, you will probably have a very difficult time getting it to work under Linux. Evaluate alternative ISPs. Don't expect your ISP's technical support to be very helpful to anyone running Unix. It doesn't matter that they're using technology that came straight from Unix machines — you're a fringe user, meaning that you have to figure it out yourself.

5.9.1Routers Before you connect your Linux machine directly to a broadband connection, you need to ask yourself this very important question: Is it really worth it? The alternative is to purchase a small router. These very inexpensive devices not only speak straight IP and PPPoE, but often include a multi-port 10/100Base-T Ethernet switch and a wireless access point. They can do network address translation, route packets from the outside world to ports on their internal networks, and more. (Sometimes they even have pretty lights that serve as eye candy when you have nothing else to do.) Routers are especially attractive for Linux users with PPPoE connections. PPPoE is a hassle, because you have to worry about several configuration files and daemons, not to mention possible trouble when upgrading. If you put a router between a DSL connection and your Linux machine, you can configure your machine's IP address statically or with DHCP. You can also build a network with a router. Their built-in switches not only share the broadband connection with all of the machines on the network, but also link those machines with each other. Of course, a Linux machine with two Ethernet cards and a hub or switch can do anything that a router can do. In fact, you have much finer control over a full-blown Linux machine acting as a router. However, very few people actually have a use for the fancy tricks you get with Linux, and the cost of a router is not much

more than the cost of a switch. If you decideHow to purchase a router, Section 5.10 for Ethernet networking details. Otherwise, if you Linux Works: What skip EverytoSuper-User Should Know are using PPPoE toWard connect to your ISP and you want to do everything on your Linux machine, continue ISBN:1593270356 by Brian reading. No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and 5.9.2PPP Over Ethernet sharing printers with Samba. (PPPoE)

PPPoE support in Linux is still in a somewhat experimental stage. To use it, get the rp-pppoe package from http://www.roaringpenguin.com/ to extend pppd to full Asymmetric Digital Subscriber Line (ADSL) How Linux Works—What Every Super-User Should Know support. You also need a reasonably recent version of pppd, such as 2.4.1. All of this might come with Chapter 1 - The Basics your distribution, but as with most new software, it's a good idea to compile your own set from source code Chapter 2 - Devices, Disks, Filesystems, and the Kernel (seeChapter 9). Chapter 3 - How Linux Boots

Table of Contents

Chapter 4

- Essential System Files, Servers, and Utilities The easiest way to set up rp-pppoe is to run adsl-setup as root. This creates appropriate - Configuring Your Network /etc/ppp/pppoe.conf and /etc/ppp/pap-secrets files for your machine. If you read through Chapter 6 - Network Services pppoe.conf, you'll find only two critical settings: Chapter 5 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

ETH=interface Chapter 9 - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel

USER=username Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

Most computers have only one Ethernet card, so you'll probably use eth0as the ETH setting. USER is your username at your ISP. This must match the settings in pap-secrets (see Section 5.8.4 for Chapter 15 - Network File Transfer information on PAP). Chapter 16 - User Environments Chapter 14 - Sharing Files with Samba

Chapter 17 - Buying Hardware for Linux

To manually start the connection, run this command:

Chapter 18 - Further Directions

Appendix A - Command Classification

adsl-start Bibliography Index List of Figures

After you verify that everything works correctly, you can put adsl-start in an init.d script to activate the connection at boot time. adsl-start is a shell script that processes pppoe.conf and then runs List of Sidebars asdl-connect, which in turn runs a big, ugly pppd command line. In principle, you could put all of this into an options file, but it is almost certainly not worth the hassle. List of Tables

To stop the connection, use adsl-stop.

Warning Back up your /etc/resolv.conf if you put any kind of work into it, because adslconnect may replace your DNS settings.

How Linux Works: What Every Super-User Should Know 5.10Ethernet Networks by Brian Ward

ISBN:1593270356

No far Starch © 2004 pages) Ethernet is by andPress away the (347 most popular physical medium for local area networks. Although there This guide describes the inner workings of a Linux system beginning with the file system and boot process and have been several kinds of cables, cable topologies, connectors, and speeds in Ethernet history, the basic covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and hardware, protocol specification, and programming techniques have proved remarkably robust. Figure 5-3 sharing printers with Samba. on the next page shows the physical appearance of an Ethernet network. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7 - Introduction to Shell Scripts Figure 5-3: A twisted-pair Ethernet Chapter 8

local area network.

- Development Tools

Chapter 9 -networks Compiling have Software From been Sourcecheap, Code Ethernet always

but the unshielded twisted-pair (UTP) devices that gained inexpensive almost to the point of absurdity. Many new computers (and Chapter 11 such - Configuring andgame Manipulating Peripheral devices as video consoles) have Devices built-in Ethernet interfaces. Old twisted-pair networks operate Chapter 12 - Printing at 10 megabits per second and are called 10Base-T networks. The current standard is 100Base-T (running Chapter - Backups at 10013Mb/s); it's sometimes called Fast Ethernet. 100Base-T requires category 5 cable, and 10Base-T Chapter 14 work - Sharing with Samba devices withFiles most 100Base-T switches and hubs. If you need something a little bit faster, you can go Chapter 15 - Ethernet; Network File Transfer to Gigabit 1000Base-T uses twisted-pair like its predecessors, and 1000Base-SX is the fiberChapter 16 - User If Environments optic version. you don't run a supercomputer center, it's unlikely that you'll need anything like this — Chapter 17 -hard-pressed Buying Hardware Linux a 100Base-T network. you'll be to for saturate Chapter 10 - Maintaining the are Kernel popularity in the 1990s now

Chapter 18 - Further Directions

To build network, Classification you need a Appendix Aa - Command

network interface card (NIC) for each of your computers, a hub or switch, cables to connect the computers to the hub or switch. If you run out of network ports, it's easy to add another hub or switch. Index and some Bibliography

List of Figures

Each node List of Tables

on an Ethernet network has a hardware address, also called the MAC (Media Access Control) ifconfig -a shows yours; in the example in Section 5.4 , the hardware address was 00:40:05:A0:7F:96.

address. Running List of Sidebars

The first three bytes of a MAC address make up a vendor code, or OUI (Organizationally Unique Identifier). For example, Sun Microsystems' OUI is 08-00-20. You can look up an OUI at http://standards.ieee.org/regauth/oui/index.shtml . You do not need to bother with the MAC address except when debugging.

Note Each node on your network should have a different MAC address even if two Ethernet cards are of the same model, and most Ethernet devices carry a label with the MAC address. Unfortunately, you may come across a batch of NIC cards with a duplicate address or two. You could try to return the duplicates, but many modern cards also allow you to change the MAC address with an extra utility.

5.10.1Ethernet and IP IP over Ethernet is very straightforward. When you want to send a packet to some other host on your local area network, your machine must know that host's MAC address. Using a series of ARP (Address Resolution Protocol) broadcasts, your host maps the IP address of the target to the target's MAC address and then sends the IP packet out on the wire to that MAC address. Your host also caches the destination MAC address inside the kernel. To view your system's current ARP cache, run the following command: arp -a

If you don't have DNS working yet, use arp -na instead, to disable hostname resolution. Linux arp with no arguments gives a slightly more formatted list than either of the above options, but this format is not standard across all versions of Unix. Note Remember that ARP only applies to machines on local subnets. To reach destinations outside your subnet, your host sends the packet to the router, and it's someone else's problem after that.

The only real problem you can have with ARP is that your system's cache can get out of date if you're moving an IP address from one network interface card to another, because the cards have different MAC How Linux Works: What Every Super-User Should Know addresses (for example, this can happen when testing a machine). Unix systems invalidate the ARP cache ISBN:1593270356 by Brian Ward entry if thereNoisStarch no response after a while, so there shouldn't be any trouble other than a small delay for Press © 2004 (347 pages) invalidated data. However, if you want to delete an ARP cache entry immediately, use this command: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and Samba.

sharing printers with arp -d host Table of Contents

How Every Super-User Should Know network YouLinux canWorks—What also view the ARP cache for a single Chapter 1

interface like this:

- The Basics

Chapter 2

Devices, Disks, Filesystems, and the Kernel arp -i -interface

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network The arp(8) manual page explains how to manually set ARP cache entries, but you should not need to do - Network Services this.

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8 - Don't Development Tools Note confuse ARP Chapter 9 Chapter 10

with RARP (Reverse Address Resolution Protocol). RARP transforms a MAC address. Before DHCP became popular, some diskless - workstations Maintaining theand Kernel other devices used RARP to get their configuration, but RARP is rare today. - address Compilingback Software Source Code to aFrom hostname or IP

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

5.10.2Private Networks

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba

Let's say you File decide to build Chapter 15 -that Network Transfer hub or16switch, and cables ready. Chapter - User Environments

your own network at home or at the office. You have your Ethernet cards, Your next question is, "W hat IP subnet should I use?"

Chapter 17 - Buying Hardware for Linux

You can pay your ISP for a block of Internet addresses if you need real Internet routing to a number of individual hosts inside your local network. However, this costs a lot of money and isn't useful for anything Appendix A - Command Classification but a highly decentralized site, such as a university. As a much less expensive alternative, you can pick a Bibliography subnet from the addresses in the RFC 1918 Internet standards document, shown in Table 5-2 on the next Index page. List of Figures Chapter 18 - Further Directions

List of Tables

Table 5-2: Private List of Sidebars

Networks Defined by RFC 1918

Network

Subnet Mask

Short Form

10.0.0.0

255.0.0.0

10.0.0.0/8

192.168.0.0

255.255.0.0

192.168.0.0/16

172.16.0.0

255.240.0.0

172.16.0.0/12

Unless you plan to have more than 254 hosts on a single network, pick a small subnet such as 10.0.0.0/255.255.255.0, which uses the addresses 10.0.0.1 through 10.0.0.254. (Networks with this netmask are sometimes called class C subnets. This term is technically somewhat obsolete but still useful in practice.) You can carve up private subnets in any way that you please, experimenting to your heart's content. So what's the catch, you say? It's very simple — hosts on the real Internet know nothing about these private subnets and will not route to them. W ith no extra help, your hosts cannot talk to the outside world. Therefore, if you have a single Internet connection, you need to have some way to fill in the gap between that connection and the rest of the hosts on your private network. Network Address Translation (NAT) does exactly this; see Section 5.14. Refer back to Figure 5-1 on page 94 for an illustration of a typical network. The gateway can be a regular Linux machine or one of the devices described in Section 5.9.1.

How Linux Works: What Every Super-User Should Know 5.11Configuring Routes by Brian Ward

ISBN:1593270356

No act Starch Press © 2004 (347 pages) from one host or subnet to another. Let's say that you have two Routing is the of transferring packets This guide describes inner workings Linux system fileEthernet system and boot process LAN subnets, 10.0.0.0/24 andthe 10.0.1.0/24, andofaa Linux routerbeginning machinewith withthe two cards, one and advanced topics such as networking, firewalls, development tools, device management, shell scripts, and connected tocovering each subnet. The router has two IP addresses: 10.0.0.1 for eth0 and 10.0.1.1 for eth1. sharing printers with Samba. Figure 5-4 shows the two networks; the router's routing table looks like this (obtained by running route n):

Table of Contents

How Linux Works—What Every Super-User Should Know

Destination Chapter 1 - The Basics

Gateway

Genmask

10.0.0.0 0.0.0.0 255.255.255.0 Chapter 2 - Devices, Disks, Filesystems, and the Kernel 10.0.1.0 0.0.0.0 Chapter 3 - How Linux Boots

255.255.255.0

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Flags Metric Ref U 0 0 U 0 0

Use Iface 0 eth0 0 eth1

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Figure 5-4: Two subnets joined with a router.

Appendix A - Command Classification Bibliography

Furthermore, let's say that the hosts on each subnet have the router as their default gateway (10.0.0.1 for 10.0.0.0/24 and 10.0.1.1 for 10.0.0.0/24). Therefore, if 10.0.0.37 wanted to send a packet to anything List of Figures outside of 10.0.0.0/24, it would pass the packet to 10.0.0.1. Now let's say that you want to send a packet List of Tables from 10.0.0.37 to 10.0.1.23. The packet goes to 10.0.0.1 (the router) via its eth0 interface, and now you List of Sidebars want it to go back out through the router's eth1 interface. To make the Linux kernel perform this basic routing function, the only thing you need to do is enable IP forwarding on the router with the following command: Index

echo 1 > /proc/sys/net/ipv4/ip_forward

This is easy enough, but what if you have another subnet, 10.0.2.0/24, connected to the host at 10.0.0.37 on that host's second network interface, as shown in Figure 5-5? After configuring 10.0.0.37's second Ethernet interface to 10.0.2.1, you now need to figure out how everything else in 10.0.0.0/24 and 10.0.1.0/24 can talk to 10.0.2.0/24. Let's start with the router that connects 10.0.0.0/24 and 10.0.1.0/24.

Figure 5-5: Three subnets. You can tell the router that 10.0.0.37 handles 10.0.2.0/24 with this command: route add -net 10.0.2.0 netmask 255.255.255.0 gw 10.0.0.37

The routing table on the router now looks like this: How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

Destination Gateway Genmask Flags Metric Ref Use Iface No Starch Press © 2004 (347 pages) 10.0.2.0 This guide describes 10.1.2.37 255.255.255.0 UG 0 0 0 eth0 the inner workings of a Linux system beginning with the file system and boot process and 10.0.0.0 covering advanced 0.0.0.0 255.255.255.0 U 0 0 0 eth0 topics such as networking, firewalls, development tools, device management, shell scripts, and with Samba. 10.0.1.0 sharing printers 0.0.0.0 255.255.255.0 U 0 0 0 eth1 Table of Contents

As Linux an added bonus,Every recallSuper-User that all traffic How Works—What Shouldfrom Know10.0.1.0/24

initially goes to the router, because 10.0.1.1 is that subnet. Therefore, anything on 10.0.1.0/24 can now talk to 10.0.2.0/24, and vice versa 2(as- long as Disks, you set the default for the hosts on 10.0.2.0/24 to 10.0.2.1). But what about Chapter Devices, Filesystems, androute the Kernel 10.0.0.0/24? Chapter 3 - How Linux Boots the default router on Chapter 1 - The Basics

Chapter 4

- Essential System Files, Servers, and Utilities

Technically, this also works now, because the packets go to 10.0.0.1 (eth0 on the router), then back out - Configuring Your Network the same network interface to 10.0.0.37. This is inefficient and a bit slower, of course, because the packets Chapter 6 - Network Services to 10.0.2.0/24 must go across the same wire twice, with the router handling the packet between the Chapter 7 - Introduction to Shell Scripts transmissions. If you want to "fix" this, you must run a route command similar to the one above for each Chapter 8 - Development Tools host on 10.0.0.0/24. Chapter 9 - Compiling Software From Source Code Chapter 5

Chapter 10 - Maintaining the Kernel

Say that the router has a connection to the Internet, and that this is the router's default gateway. Theoretically, there's no problem in sending packets out of your network to the rest of the Internet. Chapter 12 - Printing Unfortunately, if your IP addresses are in private networks (as in this section) you run into the same Chapter 13 - Backups problem described in Section 5.10.2 — you will never get anything back. Again, you need to run NAT (see Chapter 14 - Sharing Files with Samba Section 5.14) or do some other trick to get everything within the network talking to the outside world. Chapter 11 - Configuring and Manipulating Peripheral Devices

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: Layer: What EveryTCP, Super-User Should KnowServices 5.12TheHow Transport UDP, and by Brian Ward

ISBN:1593270356

No Starch pages) move from host to host on the Internet. That's clear enough, but it So far, you have onlyPress seen© 2004 how(347 packets guide describes the inner workings of athe Linux system beginning with the and boot process and says nothingThis about how your computer presents packet data it receives tofile its system running processes. You covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and want more than one application to be able to talk to the network at the same time (for example, you might sharing printers with Samba. have email and several Web clients running), and you also want to receive the data in some form that's easier to handle than packets.

Table of Contents

How Linux Works—What Every Super-User Should Know

Transport layer protocols and services perform these tasks. The two most popular transport protocols are - The Basics the Transmission Control Protocol (TCP) and the User Datagram Protocol (UDP). Both define ports on Chapter 2 - Devices, Disks, Filesystems, and the Kernel network nodes. W hen a program on your machine wants to talk to a service on a remote machine, it opens Chapter 3 - How Linux Boots a port on the local machine and requests a connection to a port on the remote machine (a connection is Chapter 4 - Essential System Files, Servers, and Utilities defined by the two hosts, the ports on each side, and a special packet sequence). After the transport layer Chapter 5 - Configuring Your Network services on both sides establish the connection, the hosts can exchange data. Chapter 1

Chapter 6

- Network Services

Chapter 7 - Introduction to Shell Scripts Transport layer services have complex

implementations because they must convert a series of packets the correct order) into a data stream for programs. Luckily, you need to know Chapter - Compiling Software From Source Code next to9 nothing about this mess. Chapter 8 - Development Tools (not necessarily arriving in

Chapter 10 - Maintaining the Kernel

In TCP UDP, a port is a number. If a program Chapter 11and - Configuring and Manipulating Peripheral Devicesaccepts

connections on a port, it is said to listen on that ports for various services; for example, email servers listen on TCP port 25, and most servers listen on TCP port 80. Only the superuser may use ports 1 through 1023. All users Chapter 13 - Web Backups may listen on andFiles create from ports 1024 on up. Chapter 14 - Sharing with connections Samba port. There are well-known Chapter 12 - Printing

Chapter 15 - Network File Transfer

On a Unix system, the /etc/services Chapter 16 - User Environments protocols. This plain-text fileLinux consists Chapter 17 - Buying Hardware for

file maps service names to port numbers and transport layer of lines like these:

Chapter 18 - Further Directions Appendix ssh A - Command Classification 22/tcp Bibliography smtp Index domain

# SSH Remote Login Protocol

25/tcp 53/udp

List of Figures List of Tables

The first column List of Sidebars

holds the service names. The second column in the /etc/services file defines the port number and a transport layer protocol. Take a look at /etc/services on your machine. Notice that the services file does not define the programs that listen on ports on your computer.

You will learn more about how programs listen and connect to the application layer in the next chapter. The rest of this chapter is devoted to three advanced networking topics: firewalls, NAT (IP masquerading), and wireless networking.

How Linux Works: What Every Super-User Should Know 5.13Firewalls by Brian Ward

ISBN:1593270356

Starch Press 2004 between (347 pages) a network and the rest of the Internet, attempting to ensure that Afirewall is aNomachine that© sits This guide describes theharms inner workings of a Linux beginning the filefeatures system and process and nothing "bad" from the Internet the network. Yousystem can also set upwith firewall forboot each machine, covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and where the machine screens all of its incoming and outgoing data at the packet level (as opposed to the sharing printers with Samba. application layer, where server programs usually try to perform some access control of their own). Firewalling on individual machines is sometimes called IP filtering.

Table of Contents

How Linux Works—What Every Super-User Should Know

To understand how firewalls work, consider that there are three times when a system can filter packets:

Chapter 1

- The Basics

ChapterWhen 2 - Devices, Disks,receives Filesystems, and the Kernel the system a packet Chapter 3

- How Linux Boots

the system sends packetand Utilities ChapterWhen 4 - Essential System Files,aServers, Chapter 5

- Configuring Your Network

the system forwards ChapterWhen 6 - Network Services Chapter 7

(routes) a packet to another host or gateway

- Introduction to Shell Scripts

With no firewalling in place, a system just processes packets and sends them on their way. - Development Tools

Chapter 8 Chapter 9

- Compiling Software From Source Code

Firewalls put checkpoints for packets at the points of data transfer identified above. The checkpoint drops, rejects, or accepts packets, usually based on some of these criteria:

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices ChapterThe 12 -source Printingor

destination IP address or subnet

Chapter 13 - Backups ChapterThe 14 -source Sharingor Files with Samba destination port

(in the transport layer information)

Chapter 15 - Network File Transfer

network ChapterThe 16 -firewall's User Environments

interface

Chapter 17 - Buying Hardware for Linux

In Linux, create firewall Chapter 18 -you Further Directions

rules in a series known as a chain that is part of a networking table (for the most part, you will only work with one table named filter that controls basic packet flow). The Appendix A - Command Classification iptables command, available since kernel version 2.4.0, manipulates these rules and chains. To use Bibliography iptables, your kernel configuration must have packet filtering (in the networking options) and IP tables Index support (in the netfilter configuration submenu). You will learn more about kernel configuration in Chapter List of Figures 10 . List of Tables List of Sidebars

There are three basic chains: INPUT for incoming packets, OUTPUT for outgoing packets, and FORWARD for routed packets. To view the current configuration, run this command:

iptables -L

Theiptables command should list an empty set of chains, as follows: Chain INPUT (policy ACCEPT) target prot opt source

destination

Chain FORWARD (policy ACCEPT) target prot opt source

destination

Chain OUTPUT (policy ACCEPT) target prot opt source

destination

Each chain has a default policy that specifies what to do with a packet if no rule matches the packet. The policy for all three chains in this example is ACCEPT, meaning that the kernel allows the packet to successfully pass through the packet-filtering system. For the purposes of this book, the only other value that makes any sense is DROP, which means that the kernel will discard the packet. To set the policy on a chain, use iptables -P as in this example: iptables -P FORWARD DROP

Warning Don't do anything rash with the policies on your machine until you've read through the rest of this section. Let's say that someone at 192.168.34.63 is annoying you, so you'd like to prevent them from talking to

your machine. Run this command: Linux Works: What Every Super-User Should Know iptables How -A INPUT -s 192.168.34.63 -j DROP by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

The-A INPUT Thisparameter guide describes appends the inner a rule workings to the of a INPUT Linux system chain.beginning The -s with 192.168.34.63 the file system and part boot specifies process and the coveringinadvanced networking, tools, device matching management, scripts, and source IP address the rule,topics andsuch -j as DROP tells thefirewalls, kernel development to discard any packet theshell rule. sharing printers with Samba. Therefore, your machine will throw out any packet coming from 192.168.34.63. Table of Contents To see the rule

in place, run iptables -L:

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chain INPUT (policy ACCEPT) - Devices, Disks, Filesystems, and the Kernel target prot opt source Chapter 3 - How Linux Boots DROP all -- 192.168.34.63 Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

destination anywhere

Chapter 6

- Network Services As luck would have it, though, your good buddy at 192.168.34.63 has told everyone on his subnet to open - Introduction to Shell Scripts connections to your SMTP port (TCP port 25), so now you want to get rid of that traffic as well:

Chapter 7 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

iptables -A INPUT -s 192.168.34.0/24 -p tcp --destination-port 25 -j DROP

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

This example adds a netmask qualifier to the source address, as well as -p tcp to specify TCP packets only. A further restriction, --destination-port 25 says that the rule should only apply to traffic to port Chapter 14 - Sharing Files with Samba 25. The IP table list for INPUT now looks like this: Chapter 13 - Backups

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chain17 INPUT Chapter - Buying (policy Hardware forACCEPT) Linux target prot opt Chapter 18 - Further Directions

source DROP all -192.168.34.63 Appendix A - Command Classification DROP tcp -- 192.168.34.0/24 Bibliography

destination anywhere anywhere

tcp dpt:smtp

Index List of Figures

AllofisTables well until List because you List of Sidebars

you hear from someone you know at 192.168.34.37, saying that they can't send you email blocked their machine. Thinking that this is a quick fix, you run this command:

iptables -A INPUT -s 192.168.34.37 -j ACCEPT However, it doesn't work. For the reason, look at the new chain: Chain INPUT (policy target prot opt DROP all -DROP tcp -ACCEPT all --

ACCEPT) source 192.168.34.63 192.168.34.0/24 192.168.34.37

destination anywhere anywhere anywhere

tcp dpt:smtp

The kernel reads the chain from top to bottom, using the first rule that matches. The first rule does not match 192.168.34.37, but the second does, because it applies to all hosts from 192.168.34.1 to 192.168.34.254, and this second rule says to drop packets. Once a rule matches, the kernel carries out the action and does not look further down in the chain. (You might remark that 192.168.34.37 can send packets to any port on your machine except port 25, because the second rule only applies for port 25.) Therefore, you have to move the third rule to the top. The easiest way to do this is to first delete the third rule with this command: iptables -D INPUT 3 Then, insert that rule at the top of the chain with iptables -I: iptables -I INPUT -s 192.168.34.37 -j ACCEPT If you want to insert a rule at some other place than the top of a chain, put the rule number after the chain

name (for example, iptables -I INPUT 4 ...). Although thisHow littleLinux tutorial mayWhat showEvery you Super-User how to insert rulesKnow and how the kernel processes IP chains, it Works: Should doesn't evenbycome close to illustrating firewall strategies that actually work. Let's talk about that ISBN:1593270356 now. Brian Ward No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and 5.13.1Firewall Strategies covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

There are two basic kinds of firewall scenarios: one for protecting individual machines (where you set rules in each machine's INPUT chain), and one for protecting a network of machines (where you set rules in the Table of Contents router's FORWARD chain). In both cases, you cannot expect to have serious security by using a default How Linux Works—What Every Super-User Should Know policy of ACCEPT, continuously inserting rules to drop packets from sources that start to send bad stuff to Chapter 1 - The Basics you. Instead, you must adopt the strategy of allowing only the packets that you trust and denying Chapter 2 - Devices, Disks, Filesystems, and the Kernel everything else. Chapter 3 - How Linux Boots Chapter 4

- Essential System Files, Servers, and Utilities For example, let's say that your machine has an email server on TCP port 25 and an SSH server on TCP - Configuring Your Network port 22. There is no reason for any random host to talk to any other port on your machine, and you Chapter 6 - Network Services shouldn't give any such host a chance. Here's how to set it up. Chapter 5 Chapter 7

- Introduction to Shell Scripts

Chapter 8 -the Development Tools policy First, set INPUT chain Chapter 9

to DROP:

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

iptables -P INPUT DROP

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

If you want to enable ICMP traffic (for ping and other utilities), use this line:

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

iptables -AEnvironments INPUT -p Chapter 16 - User

icmp -j ACCEPT

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Let's say that your host's IP address is my_addr. Make sure that you can receive packets sent from yourself to both your own network IP address and 127.0.0.1 (localhost): Bibliography Appendix A - Command Classification Index

iptables List of Figures iptables List of Tables

-A INPUT -s 127.0.0.1 -j ACCEPT -A INPUT -s my_addr -j ACCEPT

List of Sidebars

If you have control of your entire subnet (and trust everything on that subnet), you can replace my_addr with your subnet address and subnet mask; for example, 10.43.201.0/24. Now, although you need to make sure that your host can make TCP connections to the outside world, you still want to deny all incoming TCP connections. Because all TCP connections start with a SYN (connection request) packet, if you let all TCP packets through that aren't SYN packets, you are still okay: iptables -A INPUT -p tcp '!' --syn -j ACCEPT Next, you must accept traffic from your nameserver so that your machine can look up names with DNS. Do this for all DNS servers in /etc/resolv.conf. Assuming that the nameserver's address is ns_addr, you can do this with this command: iptables -A INPUT -p udp --source-port 53 -s ns_addr -j ACCEPT As mentioned before, you want to allow SSH and SMTP connections from anywhere: iptables -A INPUT -p tcp --destination-port 22 -j ACCEPT iptables -A INPUT -p tcp --destination-port 25 -j ACCEPT

# ssh # smtp

Finally, you need the following command to enable outgoing passive FTP connections, though it's not terribly critical: iptables -A INPUT -p tcp --source-port 20 --destination-port 1024: -j ACCEPT

The preceding IP table settings work for many situations. For example, they work for any direct connection, especially broadband, where an intruder is much more likely to port-scan your machine. They work for university environments, very similar to regular How Linux Works: Whatwhich Everyare Super-User Should Know broadband connections. And you could also adapt these settings using ISBN:1593270356 by Brian Ward for a firewalling router, using the FORWARD chain instead of INPUT, and source and destination subnets where appropriate. However, if you are using a firewalling router, you No Starch Press © 2004 (347 pages) might find the discussion of NAT in Section 5.14 applicable to your This guide describes the inner workings of amore Linux system beginning withsituation. the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing withisSamba. Remember that theprinters key idea permitting only the things that you find acceptable, not trying to find stuff that is unacceptable. Furthermore, IP firewalling is only one piece of the security picture. See Section 6.7 Table for more of Contents information. How Linux Works—What Every Super-User Should Know Chapter 1

The Basics 5.13.2--IP Tables Reference Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

This section is a quick reference for the most common iptables options.

Chapter 5

- Configuring Your Network Alliptables invocations must have a command option, as listed in Table 5-3.

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Table 5-3: iptables Command Options

Chapter 9 - Compiling Software From Source Code Command Option Description Chapter 10 - Maintaining the Kernel

-Lchain rules (chain isDevices optional). Chapter 11 - Configuring and Lists Manipulating Peripheral Chapter 12 - Printing

-Achain

Chapter 13 - Backups

Appends a rule to chain.

Chapter 14 - Sharing Files with Sambaa -Ichain Inserts

rule in chain (rulenum is optional; the default location is the of the chain).

Chapter 15 - Network File Transfer rulenum beginning Chapter 16 - User Environments

-Dchain rulenum Chapter 17 - Buying HardwareDeletes for Linux rulenum Chapter 18 - Further Directions a

from chain. You can omit the rule number if you specify matching parameter (shown in Table 5-4).

Appendix A - Command Classification

-Fchain rulenum Index

Deletes all rules in chain, leaving only the policy.

List-P of chain Figures

Sets the policy (default rule) of chain to newpolicy.

Bibliography

List of Tables

newpolicy

List of Sidebars

Table 5-4: iptables Packet Specification Options Parameter Option

Meaning

-saddr/mask

Selects source IP address addr with optional netmask mask (for an entire subnet).

-daddr/mask

Selects destination IP address addr with optional netmask mask (for an entire subnet).

-iinterface

Selects input interface (e.g., eth0,ppp0).

-ointerface

Selects output interface (e.g., eth0,ppp0).

-pprotocol

Selectsprotocol (e.g., tcp,udp,icmp).

--source-port port

Selects source port. You may specify a range with port1:port2. This works in conjunction with -p tcp or -p udp.

--destinationportport

Selects destination port. You may specify a range with port1:port2. This works in conjunction with -p tcp or -p udp.

--syn

When using -p tcp, selects SYN (connection request) packets.

When using -A and -I (and -D without a rule number), you must specify the rule to add or delete as a combination of the packet specification options in Table 5-4. In addition, you can insert a literal ! after the option flag to negate its meaning. To finish off your rule, use -jtarget to decide what to do if a packet matches the rule (the most common types of target are ACCEPT and DROP). This section has only described the basics of iptables. There are many advanced features, such as the ability to send a packet to an entirely different destination, to intercept packets at different parts of the

routing process, and to create your own subchains. You can read about them in the iptables(8) manual page. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: WhatTranslation Every Super-User Should Know 5.14Network Address (IP Masquerading) by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) Network Address Translation (NAT) permits sharing a single IP address (for example, from a PPP or This guide describes theentire inner workings a Linux system with the file home systemand and boot broadband connection) with an internal of network. NAT isbeginning very popular with smallprocess officeand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and networks. IPv4 addresses are in short supply, and furthermore, ISPs do not really want to bother with more sharing printers with Samba. routing than they can handle. As mentioned in Section 5.9.1, many small routers support NAT. In Linux, the variant of NAT that most people use is known as IP masquerading.

Table of Contents

How Linux Works—What Every Super-User Should Know

The basic idea behind NAT is that the machine with the Internet connection acts as a proxy between the - The Basics internal network and the rest of the Internet. Consider a network like the one back in Figure 5-1 on page Chapter 2 - Devices,that Disks, and the Kernel 94, and assume theFilesystems, router (gateway) has an eth0 interface to an internal private network and a ppp0 Chapter 3 - How Linux Boots interface for the uplink to the Internet. Chapter 1

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter - Configuring Your Network Every5host on the Internet knows

how to connect to the router, but they know nothing about the internal - Network Services network behind the router. Under NAT, each of the internal hosts has the router as its default Chapter 7 - The Introduction Shell Scripts gateway. systemtoworks roughly as follows: Chapter private6 Chapter 8

- Development Tools

1. A host on the internal private network wishes to make a connection to the outside world, so it sends - Compiling Software From Source Code its connection request packets through the router as normal.

Chapter 9

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

2. The router intercepts the connection request packet rather than passing it out to the Internet (where it would get lost, because the public Internet knows nothing about private networks such as Chapter 13 - Backups 10.1.2.0/24). Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba Chapter - Network Transfer 3. 15The router File determines

the destination of the connection request packet and opens its own

Chapter 16 - User Environments connection to the destination. Chapter 17 - Buying Hardware for Linux

4. 18When the Directions router obtains Chapter - Further

the connection, it fakes a "connection established" message back to the

internal host. Appendix original A - Command Classification Bibliography Index 5.

The router is now the middleman between the internal host and the destination. The destination nothing about the internal host; the connection on the remote host looks like it came from the router. List of Tables knows List of Figures List of Sidebars

This doesn't sound too bad until you think about how it works. Plain old IP routing knows only source and destination IP addresses in the Internet layer. However, if the router dealt only with the Internet layer, each host on the internal network could establish only one connection to a single destination at one time (among other limitations), because there is no information in the Internet layer part of a packet that could distinguish multiple requests from the same host to the same destination. Therefore, NAT must dissect packets to pull out more identifying information. The only suitable stuff is in the transport layer — in particular, the TCP and UDP port numbers. The transport layer is very complex, so you can imagine that there are lots of things that can go wrong when a router goes mucking about inside transport layer information that comes from two hosts (the internal one and the external one) that it knows nothing about. That said, NAT works better in practice than this brief description might suggest. To set up a Linux machine to perform as a NAT router, you must activate all of the following inside the kernel configuration: network packet filtering ("firewall support"), connection tracking, IP tables support, full NAT, and MASQUERADE target support.

Note See Chapter 10 for information on the kernel. Then you need to run iptables commands like the following to make the router perform NAT for its private subnet. The following example commands are for the earlier example: echo 1 > iptables iptables iptables iptables

/proc/sys/net/ipv4/ip_forward -P FORWARD DROP -t nat -A POSTROUTING -o ppp0 -j MASQUERADE -A FORWARD -i eth0 -j ACCEPT -A FORWARD -m state --state ESTABLISHED,RELATED -j ACCEPT

This example applies to an internal Ethernet network on eth0 sharing a PPP Internet connection (ppp0). Change these to suit your network.

When using NAT, remember that it's essentially a hack. In a perfect world, we would all be using IPv6 (the next-generation Internet), and we could get permanent subnets from our ISPs without any pain. In the mean-time, How though, you have What to deal withSuper-User these NATShould limitations: Linux Works: Every Know by Brian Ward

ISBN:1593270356

InternetNo hosts cannot to services inside the private network without special port forwarding Starch Press ©connect 2004 (347 pages) help from the NAT router. Of course, the hosts in the private network have network security This guide describes the inner workings of a Linux system beginning with may the file system and boot process and vulnerabilities, this limitation may be more of a blessing than a tools, drawback. covering so advanced topics such as networking, firewalls, development device management, shell scripts, and sharing printers with Samba.

Because Internet hosts cannot connect to internal hosts, some services need even more complicated packet dissection to work. Table of Contents How Linux Works—What Every Super-User Should Know

NAT- works for TCP, UDP, and some ICMP, but not necessarily all transport layer protocols. The Basics

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

NAT requires much more memory and computing power than normal IP routing, so the computer - How Linux Boots acting as the router cannot be completely underpowered. In addition, there is always some connection Chapter 4 - Essential System Files, Servers, and Utilities overhead and latency. However, modern computers are more than fast enough to handle this, and the Chapter 5 - Configuring Your Network overhead and latency don't really matter unless you're running a big operation. Chapter 3

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 5.15Wireless Ethernet by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) and other portable computing devices has given rise to wireless The proliferation of notebook computers Thisirritatingly guide describes theas inner workings of a Linux beginning with the file system and boot process Ethernet (also known "Wi-Fi") that you dosystem not need to physically plug into a switch or hub.and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and There are two popular consumer versions of the standard: 802.11b (maximum speed 11 Mbps) and sharing printers with Samba. 802.11g (54 Mbps). Table of Contents

In principle, wireless Ethernet isn't much different than any other kind of Ethernet, except that it uses radio waves instead of copper wires or fiber. You can configure a wireless card's network interface with Chapter 1 - The Basics traditional tools, such as ifconfig and dhclient. And wireless Ethernet cards have MAC addresses just Chapter 2 - Devices, Disks, Filesystems, and the Kernel like their wired counterparts. How Linux Works—What Every Super-User Should Know

Chapter 3

- How Linux Boots

Chapter - Essential System Files, Servers, and Utilities With a4 wireless network, you typically want to be

able to send packets out to some wired network. To base station to bridge (or link) a wireless network to a wired Chapter 6 — - Network Services network it's almost like adding more ports to a hub or switch by plugging another hub or switch into one Chapter - Introduction to Shell of the 7ports. A wireless baseScripts station contains both wired and wireless networking hardware; it physically Chapter Tools and can also communicate wirelessly with wireless network devices. (You can plugs 8into- Development the wired network Chapter - Compiling Softwaredo From Code make 9a regular computer theSource work of a wireless base station, but it's hardly worth the trouble.) Chapter 5 - Configuring accomplish this, youYour can Network buy a wireless

Chapter 10 - Maintaining the Kernel

Linux 11 has- Configuring an additional called iwconfig for setting Chapter and tool Manipulating Peripheral Devices

up a few technical details of a wireless network. else has a wireless network next door, you need to differentiate yours from theirs with an Chapter 13Extended - Backups Service Set Identifier (ESSID) string identifier. For example, if someone Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba

To enable iwconfig, your kernel Chapter 15 - Network File Transfer configuration's networking Chapter 16 - User Environments

needs the wireless LAN extensions that you'll find in the kernel support options (see Chapter 10). Running iwconfig with no options yields

output17like this: Hardware for Linux Chapter - Buying Chapter 18 - Further Directions Appendix A - Command Classification lo no wireless extensions. Bibliography Index eth0

no wireless extensions.

List of Figures List of Tables eth1 List of Sidebars

IEEE 802.11-DS ESSID:"some net" Nickname:"HERMES I" Mode:Managed Frequency:2.437GHz Access Point: 00:04:5A:CE:BF:17 Bit Rate:11Mb/s Tx-Power=15 dBm Sensitivity:1/3 RTS thr:off Fragment thr:off Power Management:off Link Quality:44/92 Signal level:-49 dBm Noise level:-93 dBm Rx invalid nwid:0 invalid crypt:0 invalid misc:7255

As you can see, wireless settings are attached to network interfaces. The most important settings are as follows: ESSID A string identifier for the network. Your wireless access point should have this setting. Mode A setting that defines the type of network and the network interface's role in the network. Most wireless networks are managed networks, meaning that there is at least one interface that serves as an access point and oversees the nodes on the network. Your interface can act as a client, the master access point, a secondary access point, or a repeater. However, there are also ad hoc networks that have no access points. Access point The MAC address of your current wireless access point's wireless interface (if you're on a managed network). Encryption key The wireless network card's current Wired Equivalent Privacy (WEP) key. You can manually set these parameters just as you would with ifconfig: iwconfig eth1 essid mynet mode managed

In the preceding example, iwconfig configures the eth1 interface with an ESSID of mynet and a

network topology of managed. The important iwconfig parameters are listed in Table 5-5. See the iwconfig(8) manual page for a complete list of parameters. How Linux Works: What Every Super-User Should Know

Table 5-5: iwconfig Parameters by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

ParameterThis guide Valuedescribes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and Theprinters ESSID string, or any. sharing with Samba.

essid

The MAC address of your access point, or any.

ap Table of Contents

mode Managed, Master,Repeater, How Linux Works—What Every Super-User Should KnowSecondary, Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter freq4

- Essential Systemfrequency Files, Servers, and Utilities A direct specification

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

channel

key

or Auto.

A channel number (each channel has a predetermined frequency); run iwlist interface channel to get a list of available channels. (for example, 2.412G for 2.412 GHz).

Normally, the hexadecimal value of the WEP key, or off to disable WEP.

For wireless plug-in PC cards, Chapter 8 - Development Tools

most distributions support the PC card utilities in /etc/pcmcia, where you When you plug a wireless card into your machine, the PC card daemon described in Section 11.6 runs /etc/pcmcia/wireless.wireless runs Chapter 10 -services Maintaining the Kernel iwconfig based onand theManipulating parameters in wireless.opts, which is a Bourne shell case statement, making Chapter 11 - Configuring Peripheral Devices decisions based on your wireless card's MAC address. The wireless.opts configuration file Chapter 12 - primarily Printing has many sample entries that you should examine. Chapter 13 - Backups will find file From called wireless.opts. Chapter 9 a- configuration Compiling Software Source Code

Chapter 14 - Sharing Files with Samba

To create an entry in this file for a wireless card with MAC address 00:02:2D:B0:EE:E4, you could use the following:

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

*,*,*,00:02:2D:B0:EE:E4) Chapter 18 - Further Directions INFO="My Home Network" Appendix A - Command Classification ESSID="my Bibliography

network" MODE="Managed" RATE="auto" List of Figures KEY="268B645297" List of Tables ;; List of Sidebars Index

You must place this entry in the case statement in wireless.opts before these lines: # NOTE : Remove the following four lines to activate the samples below ... # --------- START SECTION TO REMOVE ----------*,*,*,*) ;; # ---------- END SECTION TO REMOVE ------------

5.15.1A Lecture on Wireless Security Unfortunately, using radio waves as a medium is absurdly insecure. Anyone with any kind of wireless Ethernet device, even something as small as a Sharp Zaurus, can sidle up near your network and waltz all around your packets. Without any additional protective measures, anyone can get access to your network, snoop around your packets, or do something much worse. For example, if your wireless network is connected to the Internet, anyone can use your network for a wide variety of very illegal activities. There are several ways to make it considerably tougher to access your wireless network, and you'd think that most people would use them. Shockingly, the overwhelming majority do not. It's easy to set up a completely insecure wireless network, whereas to make the network more secure you need to enter a whole bunch of numbers into any computer that wants to use it. Who wants to go through all of that trouble when the network works just fine out of the box? Not to mention that it's a continuous hassle, especially when one of your friends comes over with a notebook. Everyone thinks, "Hey, all of this bad stuff can't happen to me." But it can and will if you choose not to have any security. Fortunately, even the weakest kind of wireless security, WEP, drives off virtually all would-be intruders. If nothing else, you should enable WEP on your access points and wireless network interfaces. Yes, this does mean typing in a bunch of numbers, but do you really want to risk being caught in the middle of a legal mess?

You should know that WEP is not terribly secure. Given five to ten million packets, someone snooping on your network can figure out your WEP key with a program such as AirSnort. Of course, sniffing five to ten Howtakes LinuxaWorks: Super-User Should Know million packets while, What but if Every this concerns you, change your keys every now and then (like, say, ISBN:1593270356 by Brian Ward every three million packets). No Starch Press © 2004 (347 pages) guide describes thesensitive inner workings a Linuxyour system beginning with the file system and bootlike process In any case,This never transmit any dataofacross network without serious encryption SSLand or advanced topics such development tools, device scripts, SSH, even ifcovering you are using WEP. Thisasisnetworking, especiallyfirewalls, true if you do not control your management, network, andshell also holdsand sharing printers with Samba. for wired networks. Table of Contents If you have a good

reason to be paranoid about security, WEP isn't going to help you much. You should on your wireless network. Many administrators use a Chapter - The Basics virtual1private network (VPN) to implement an IPSec-based system. How Linux IPSec Works—What Every Should Know require or SSH portSuper-User forwarding for all traffic Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 6: Network Services by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Chapter 5 explained all layers of Internet networks except the application layer. Network applications (clients and servers) interact with the operating system by using a transport layer protocol and interface, Table of Contents such as TCP. This chapter covers basic network servers, including the inetd superserver and SSH How Linux Works—What Every Super-User Should Know servers. In addition, you will see some tools that will help you debug the servers. Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel Unix network servers come in many forms. A server may listen to a port on its own, or it may use a Servers have no common configuration database, and they vary widely in Chapter 4 - Essential System Files, Servers, and Utilities features. Most servers have a configuration file to control their behavior (though with no common format), Chapter 5 - Configuring Your Network and most use the operating system's syslog service for message logging. Chapter 3 - How Linux superserver such asBoots inetd.

Chapter 6

- Network Services

Chapter - Introduction Shell Scripts If you 7understand thetosystem of TCP

and UDP ports described in Section 5.12, you won't run into much - Development Tools with network servers. Let's start out by getting an idea of how network clients talk to network Chapter 9 - Compiling Software From Source Code servers. Chapter trouble8

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 6.1 The Basics of Services by Brian Ward

ISBN:1593270356

Noare Starch Press the © 2004 (347 pages) TCP services among easiest to understand because they are simple, uninterrupted data streams. This guide the inner of a Linux system beginning with an theidea file system and bootcomes process and For example, you candescribes talk directly to aworkings Web server on TCP port 80 to get of how data covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and across the connection. Run the following command to connect to a Web server: sharing printers with Samba.

telnet www.nytimes.com Table of Contents

80

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 3

- How Linux Boots

You should get a response like this: Chapter 2 - Devices, Disks, Filesystems, and the Kernel Trying address... Chapter 4 -some Essential System Files, Servers, and Utilities Connected to www.nytimes.com. Chapter 5 - Configuring Your Network Escape is Chapter 6 -character Network Services

'^]'.

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Now type Chapter 9 - this: Compiling Software From Source Code Chapter 10 - Maintaining the Kernel Chapter GET /11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter - Sharing Files The with Samba Press 14 ENTER twice. server

should send a bunch of HTML text as a response, and then terminate the

Chapter 15 - Network File Transfer connection. Chapter 16 - User Environments

There17 are- Buying two important Chapter Hardware lessons for Linux here: Chapter 18 - Further Directions

The host has a Web Appendix A -remote Command Classification

server process listening on TCP port 80.

Bibliography Index

telnet was the client that initiated the connection.

List of Figurestelnet

is a program originally meant to enable logins to remote hosts. Although the nonKerberostelnet remote login server is completely insecure (as you will learn later), the List of Sidebars telnet client is useful for debugging remote services. telnet does not work with UDP or any other transport layer other than TCP. See Section 6.5.3 for information on netcat, a powerful general-purpose network client. Note

List of Tables

How Linux Works: What Every Super-User Should Know 6.2 Stand-Alone Servers by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 Stand-aloneNo network servers are nopages) different than any other server daemons on your system (such as Thisthat guide describes workings of In a Linux beginning with the file system and boot cron), except they listen the on inner network ports. fact,system you already saw syslogd in Chapter 4,process whichand advanced topics such as networking, firewalls, development tools, device management, shell scripts, and accepts UDPcovering packets on port 514 if it is started with the -r option. sharing printers with Samba.

Here are some other common network servers that you may find running on your system:

Table of Contents

How Linux Works—What Every Super-User Should Know

httpd Web server

Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapterlpd 3 -Print How Linux Boots server (see

Chapter 12)

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapterpostfix, 6 - Networkqmail, Services Chapter 7

sendmail Mail servers

- Introduction to Shell Scripts

Chapter 8

- Development Tools sshd Secure shell daemon (see Section 6.4 )

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapternfsd, 11 - Configuring Manipulating Peripheral Devices mountdand Network filesystem daemons Chapter 12 - Printing Chapter 13 - Backups

smbd, nmbd Windows file-sharing daemons (see Chapter 14)

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Chapterportmap 16 - User Environments Remote procedure Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

call (RPC) portmap service daemon

How Linux Works: What Every Super-User Should Know 6.3 The inetd Daemon by Brian Ward

ISBN:1593270356

No stand-alone Starch Press ©servers 2004 (347 pages) Implementing for every single service is somewhat inefficient, because each server This guide the describes the inner workings a Linux beginning with the file system and and boot process and must know all about network interface API,ofhave itssystem own port configuration system, so on. In many covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and respects, thesharing API for talking to TCP is not much different than the standard I/O system. TCP servers read printers with Samba. from network ports and return output back to those ports — this is similar to the behavior of cat with no arguments in Section 1.2 is similar.

Table of Contents

How Works—What Super-User Should Know TheLinux inetd daemon Every is a superserver that standardizes

network port access and interfaces between regular ports. After you start inetd, it reads the inetd.conf file and then listens on the Chapter 2 - Devices, Disks, Filesystems, and the Kernel network ports defined in that file, attaching a newly started process to every new incoming connection. Chapter 1 - The programs andBasics network Chapter 3

- How Linux Boots

Chapter Essential System Files, Servers, and Utilities Each 4line- in inetd.conf looks something like this: Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

ident

stream

tcp

nowait

nobody

/usr/sbin/identd

identd -i

Chapter 9

Software From Source Code There are- Compiling seven fields here:

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Service name The service name from /etc/services (see Section 5.12).

Chapter 12 - Printing

Chapter 13 - Backups ChapterSocket 14 - Sharing Samba typeFiles Thiswith is usually

stream for TCP and dgram for UDP.

Chapter 15 - Network File Transfer Chapter 16 - User Environments

The transport protocol, ChapterProtocol 17 - Buying Hardware for Linux

such as tcp or udp.

Chapter 18 - Further Directions Appendix A - Command Classification

Datagram server behavior For UDP, this is wait or nowait. Services using any other transport protocol should use nowait.

Bibliography Index

List of Figures List of Tables User The

username that should run the service. Add .group if you want to set a group.

List of Sidebars

Executable The program that inetd should connect to the service. Arguments The arguments for the executable in the preceding field. The first argument should be the name of the program. A# sign in inetd.conf denotes a comment. To deactivate an inetd service, place a # before its entry in/etc/inetd.conf and then run the following command to make inetd re-read its configuration file: kill -HUP `cat /var/run/inetd.pid`

inetd has several built-in services that you might see at the beginning of your inetd.conf, including echo,chargen,discard,daytime, and time. You can use these for testing, but otherwise they aren't important.

6.3.1TCP Wrapper: tcpd, /etc/hosts.allow, /etc/hosts.deny Before lower-level firewalls took off in popularity, many administrators used the TCP wrapper library for host control over network services. In fact, even if you run an IP firewall, you should still use TCP wrappers on any service that does not have its own logging mechanism (and many inetd services do not have such capabilities). Thetcpd program is the TCP wrapper utility for linking inetd with a server. An administrator can modify theinetd.conf file to include tcpd, like this: finger

stream

tcp

nowait

nobody

/usr/sbin/tcpd

/usr/sbin/in.fingerd

When someone makes a connection to the finger port, the following happens: 1. 2.

1. inetd runs tcpd as the name /usr/sbin/in.fingerd. 2. tcpdHow verifies the executable /usr/sbin/in.fingerd. Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

3. tcpd consults /etc/hosts.allow and /etc/hosts.deny to see if the remote machine has No Starch Press © 2004 (347 pages) permission to connect.

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

4. tcpdsharing logs its decision. printers with Samba.

5. If tcpd decides that the remote host is okay, it runs /usr/sbin/in.fingerd. Otherwise, tcpd terminates, dropping the connection.

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1 an - The Basics Here is example

hosts.deny file:

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

ALL: .badguys.example.com - Essential System Files, Servers, and Utilities in.fingerd: nofinger.example.com Chapter 5 - Configuring Your Network portmap: ALL Chapter 6 - Network Services Chapter 4

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

You can interpret this as follows:

ChapterNo 10one - Maintaining the Kernel in the subdomain

.badguys.example.com may connect to any TCP wrapper-enabled program.

Chapter 11 - Configuring and Manipulating Peripheral Devices ChapterThe 12 -host Printing nofinger.example.com

may not run in.fingerd.

Chapter 13 - Backups

may Files access ChapterNo 14one - Sharing withportmap Samba

(see Section 6.6 for more information on this service).

Chapter 15 - Network File Transfer

The TCP library reads Chapter 16 - wrapper User Environments

/etc/hosts.allow before /etc/hosts.deny. If a rule in incoming connection, the TCP wrapper library allows the connection, ignoring /etc/hosts.deny. For example, the following line in /etc/hosts.allow enables portmap Chapter 18 - Further Directions access to the subdomain goodguys.example.com: Appendix A - Command Classification /etc/hosts.allow matches an Chapter 17 - Buying Hardware for Linux

Bibliography Index portmap:

.goodguys.example.com

List of Figures List of Tables List of Sidebars

Note Using domain names in a TCP wrapper configuration has the disadvantage that it uses DNS. Forcing DNS lookups can hinder performance. It's also not extremely secure; it's possible to affect DNS lookups.

6.3.2xinetd Some Linux distributions come with an enhanced version of inetd named xinetd (http://www.xinetd.org/). You can read about the xinetd improvements at the Web site, but to summarize, xinetd offers built-in TCP wrapper support, better logging, and extended access control. If you currently have inetd, should you run xinetd? If you need its features, sure. However, if you only have one local server (for example, FAM for the GNOME desktop), and you firewall the external traffic to this server anyway, there are probably better things you can do with your time. xinetd administrators should also keep careful track of security advisories, because this package has not seen as widespread use as the old inetd. xinetd does not read inetd.conf, but if you understand the fields in inetd.conf, you won't have trouble using xinetd. If you want an alternative to /etc/xinetd.d, you can also use itox to convert yourinetd.conf to a xinetd.conf file that xinetd can read. To add a new service to xinetd, create a file in /etc/xinetd.d with the name of the service. For example, the /etc/xinetd.d/finger file might look like this: service finger { socket_type protocol wait user passenv server

= = = = = =

stream tcp no nobody /usr/sbin/in.fingerd

server_args = } How Linux Works: What Every Super-User Should Know by Brian Ward

To make xinetd recognize the(347 changes, run kill -USR1 on the xinetd process ID. No Starch Press © 2004 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Shell Linux Works: What Every Super-User Should Know 6.4 Secure (SSH) by Brian Ward

ISBN:1593270356

No Starch Press 2004 the (347 pages) The secure shell (SSH) is ©now de facto standard for remote logins to other machines. It replaces old, This guide describes theand innerrlogin. workings of Linux system beginning withexample the file system and boot process and insecure programs like telnet In aaddition to being a good of a stand-alone server covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and (for the purposes of this book, at least), SSH has these features: sharing printers with Samba.

Encrypts your password and all other session data, protecting you from snoopers.

Table of Contents

How Linux Works—What Every Super-User Shouldincluding Know Tunnels other network connections,

those from X Window System clients. Tunneling is the and transporting a network connection using another network connection. The Chapteradvantages 2 - Devices, and the ofDisks, usingFilesystems, SSH to tunnel X Kernel Window System connections are that SSH sets up the display Chapterenvironment 3 - How Linux forBoots you and encrypts the X data inside the tunnel. Chapterprocess 1 - Theof Basics packaging

Chapter 4

- Essential System Files, Servers, and Utilities

ChapterHas 5 -clients Configuring Your Network for almost every Chapter 6

operating system.

- Network Services

keys for host authentication. ChapterUses 7 - Introduction to Shell Scripts Chapter 8

- Development Tools

OpenSSH (http://www.openssh.com/) is a popular free SSH implementation for Unix. The OpenSSH client - Compiling Software From Source Code is ssh and the server is sshd. OpenSSH uses public key cryptography for authentication and less Chapter 10 - Maintaining the Kernel complex ciphers for its session data. SSH does not come without its disadvantages; in particular, you need Chapter 11 - Configuring and Manipulating Peripheral Devices the remote host's public key, and you do not necessarily get it in a secure way (however, you can check it Chapter 12 - Printing manually if you think you're being spoofed). If you would like to know how cryptography works, get your Chapter 13 - Backups hands on Applied Cryptography [Schneier]. Chapter 14 - Sharing Files with Samba Chapter 9

Chapter 15 - Network File Transfer

There are two main SSH protocol versions: 1 and 2. OpenSSH supports both, with version 2 being the default.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

6.4.1Installing OpenSSH

Appendix A - Command Classification Bibliography

You Index

can install a precompiled binary version of OpenSSH, such as an .rpm file in a Red Hat distribution, get the "portable" source code from the OpenSSH Web site to install from source. If you install List of Tables from source code, you need a version of the SSL (Secure Socket Layer) library, preferably OpenSSL. List Figures or ofyou can

List of Sidebars

In either case, you need to know your OpenSSH configuration directory — it's usually /etc or /usr/local/etc. If you install from source code, you can override the default configuration directory by using the --sysconfdir=dir parameter to configure (see Chapter 9 for more information on compiling software from source code).

6.4.2The SSHD Server To run sshd, you need a configuration file and host keys in the configuration directory. The configuration filename is sshd_config. It's easy to confuse this filename with the client's ssh_config setup file, so look out. You shouldn't need to change anything in sshd_config, but it never hurts to check. The file consists of keyword-value pairs, as shown in this fragment: Port 22 #Protocol 2,1 #ListenAddress 0.0.0.0 #ListenAddress :: HostKey /usr/local/etc/ssh_host_key HostKey /usr/local/etc/ssh_host_rsa_key HostKey /usr/local/etc/ssh_host_dsa_key

Lines beginning with # are comments. Many comments in your sshd_config may indicate default values. The sshd_config(5) manual page contains descriptions of all possible values, but these are the most important: HostKeyfile Uses file as a host key (host keys are described shortly). SyslogFacilityname Logs messages with syslog facility name. LogLevellevel Logs messages with syslog level level.

PermitRootLoginvalue Permits the superuser to log in with SSH if value is set to yes; set value to no if you do not want to allow this. How Linux Works: What Every Super-User Should Know

by Brian Ward X11Forwarding value Enables X Window System client tunneling if value is set to yes. ISBN:1593270356 No Starch Press © 2004 (347 pages)

This guide describes the inner a workings of xauth; a Linux system beginning with filework system and boot processIfand XAuthLocation path Provides path for X11 tunneling doesthe not without xauth. covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and xauth isn't in /usr/X11R6/bin, set path to the full path-name for xauth. sharing printers with Samba.

Host Keys

Table of Contents How Linux Works—What Every Super-User Should Know

OpenSSH has three different host key sets: one for protocol version 1, and two for protocol 2. Each set - The Basics has a public key (with a .pub file extension) and a private key (with no extension). Do not let anyone see Chapter 2 - Devices, Disks, Filesystems, and the Kernel your private key, even on your own system. If someone gets your host's private key, SSH provides no Chapter 3 - How Linux Boots protection against password snooping. SSH version 1 has RSA keys only, and SSH version 2 has RSA Chapter 4 - Essential System Files, Servers, and Utilities and DSA keys. RSA and DSA are public key cryptography algorithms. SSH version 2 provides both Chapter 5 - Configuring Your Network because there are always debates over which one is better. Chapter 6 - Network Services Chapter 1

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

The key filenames are as follows: Table 6-1: OpenSSH Key Files

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral ssh_host_rsa_key Private RSA Devices key (version

2)

Chapter 12 - Printing

ssh_host_rsa_key.pub Chapter 13 - Backups

Public RSA key (version 2)

Chapter 14 - Sharing Files with Samba

Private DSA key (version 2)

ssh_host_dsa_key

Chapter 15 - Network File Transfer

ssh_host_dsa_key.pub Chapter 16 - User Environments

Public DSA key (version 2)

Chapter 17 - Buying Hardware for Linux

ssh_host_key

Chapter 18 - Further Directions Appendix A - Command Classification ssh_host_key.pub

Private RSA key (version 1) Public RSA key (version 1)

Bibliography Index Normally,

you do not need to build the keys, because the OpenSSH installation program should do this for this isn't always a given, and you may need to know how to create keys if you plan to use List of Tables like ssh-agent. programs List of Figures you. However, List of Sidebars

To create SSH protocol version 2 keys, use the ssh-keygen program that comes with OpenSSH: ssh-keygen -t rsa -N '' -f ssh_host_rsa_key ssh-keygen -t dsa -N '' -f ssh_host_dsa_key

For the version 1 keys, use this command: ssh-keygen -t rsa1 -N '' -f ssh_host_key The SSH server (and clients) also use another key file, ssh_known_hosts, which contains public keys from other hosts. If you intend to use host-based authentication, the server's ssh_known_hosts file must contain the host keys of all trusted clients.

Starting the SSH Server Runningsshd as root starts the server. You may put this in an init.d script to start at boot time. There is also a way to start sshd from inetd, but this is usually not a good idea, because the server occasionally needs to generate key files, and this process can take a long time. sshd writes its PID to /var/run/sshd.pid, so you can terminate the server at any time with this command: kill `cat /var/run/sshd.pid`

6.4.3The SSH Client

To log in to a remote host, run this command: How Linux Works: What Every Super-User Should Know sshremote_username@host by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

Thisremote_username@ guide describes the innerifworkings of a username Linux systemisbeginning with system andcan bootalso process You may omit your local the same asthe onfile host. You run and advanced topics such as networking, firewalls, development tools, device management, shell scripts, and pipelines to covering and from an ssh command. sharing printers with Samba.

The SSH client configuration file is ssh_config, and it should be in the same place as your file. As with the server configuration file, the client configuration file has key-value pairs, How Every to Super-User Know butLinux you Works—What should not need change Should anything in there.

Table of Contents sshd_config Chapter 1

- The Basics

Chapter 2 - frequent Devices, Disks, Filesystems, and the Kernel The most problem with using SSH clients Chapter 3 - How Linux Boots ssh_known_hosts or .ssh/known_hosts

occurs when an SSH version 1 public key in your local file does not match the key on the remote host. Bad keys

Chapter - Essential System Files, Servers, and Utilities cause4errors or warnings like this: Chapter 5

- Configuring Your Network

Chapter 6

- Network Services @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ - Introduction to Shell Scripts @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @ Chapter 8 - Development Tools @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ Chapter 9 - Compiling Software From Source Code IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY! Chapter 10 - Maintaining the Kernel Someone could be eavesdropping on you right now (man-in-the-middle attack)! Chapter 11 - Configuring and Manipulating Peripheral Devices It is also possible that the RSA host key has just been changed. Chapter 12 - Printing The fingerprint for the RSA key sent by the remote host is Chapter 13 - Backups 38:c2:f6:0d:0d:49:d4:05:55:68:54:2a:2f:83:06:11. Chapter 14 - Sharing Files with Samba Please contact your system administrator. Chapter 15 - Network File Transfer Add correct host key in /home/user/.ssh/known_hosts to get rid of this message. Chapter 16 - User Environments Offending key in /home/user/.ssh/known_hosts:12 Chapter 17 - Buying Hardware for Linux RSA host key for host has changed and you have requested Chapter 18 - Further Directions strict checking. Appendix A - Command Classification Host key verification failed. Bibliography Chapter 7

Index List of Figures

This usually just means that the remote host's administrator changed the keys, but it never hurts to check with the administrator if you don't know. In any case, look at this line of the preceding message:

List of Tables

List of Sidebars

Offending key in /home/user/.ssh/known_hosts:12

This tells you exactly where the bad key is: line 12 of a user's known_hosts file. If you do not suspect foul play, just remove the offending line or replace it with the correct public key.

SSH File Transfer Clients OpenSSH comes with replacement programs for rcp and ftp called scp and sftp. You can use scp to transfer files from a remote machine to your machine, the other way around, or from one host to another. It works much like the cp command. Here are some examples: scpuser@host:file . scpfile user@host:dir scpuser1@host1:file user2@host2:dir

sftp works much like the command-line ftp client, with get and put commands. The remote host must have a sftp-server program, but this shouldn't be a problem if the remote host also uses OpenSSH.

SSH Clients for Non-Unix Platforms There are SSH clients for all popular operating systems. The index at the OpenSSH Web page (http://www.openssh.com/) gives a full list, but you may wonder which one to choose for Windows or the Mac. PuTTY is a good Windows client that includes a secure file-copy program. MacSSH works well for Mac OS 9. Mac OS X is based on Unix and includes OpenSSH.

How Linux Tools Works: What Every Super-User Should Know 6.5 Diagnostic by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 network pages) netstat is No one of the most basic service debugging tools, telling you what ports are open and guide describes the inner of a example, Linux system beginning the file and boot process whether anyThis programs are listening onworkings ports. For if you wantwith to view allsystem open TCP ports, run and this covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and command: sharing printers with Samba.

netstat -t Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Table 6-2- How lists Linux the netstat options. Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter -t 8

- Development Tools Prints TCP port

Chapter 9

- Compiling Software From Source Code

Table56-2: netstatYour Options Chapter - Configuring Network

Option

Description

information

-u 10 - Maintaining Prints UDP port information Chapter the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

Prints listening ports

-l

Chapter 12 - Printing

-a 13 - Backups Prints Chapter

every active port

Chapter 14 - Sharing Files with Samba

Disables name lookups (useful if DNS isn't working)

-n

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Being able to list open and listening ports is good, but our good old friend lsof can go one step further.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

6.5.1lsof

Appendix A - Command Classification Bibliography

Index In Section

4.8.1 you saw how lsof can track open files, but lsof can also list the programs currently to ports. For a complete list, run this command:

List of Figures using or listening List of Tables List of Sidebars

lsof -i

The output should look something like this: COMMAND portmap portmap inetd inetd inetd inetd inetd inetd inetd sshd X

PID USER 520 daemon 520 daemon 522 root 522 root 522 root 522 root 522 root 522 root 522 root 853 root 900 root

FD 3u 4u 4u 5u 6u 7u 8u 9u 11u 3u 1u

TYPE DEVICE SIZE NODE NAME IPv4 150 UDP *:sunrpc IPv4 151 TCP *:sunrpc (LISTEN) IPv4 188 TCP *:discard (LISTEN) IPv4 189 UDP *:discard IPv4 190 TCP *:daytime (LISTEN) IPv4 191 UDP *:daytime IPv4 192 TCP *:time (LISTEN) IPv4 193 UDP *:time IPv4 195 TCP *:auth (LISTEN) IPv4 696 TCP *:ssh (LISTEN) IPv4 791 TCP *:6000 (LISTEN)

If you're looking for one port in particular (that is, if you know that a process is using a particular port and you want to know what that process is), use this version of the command: lsof -i :port

The full syntax is lsof -i protocol@host:port

protocol,@host, and :port are all optional. Specifying any of these parameters filters the lsof output accordingly. As with most other network utilities, host and port can be either names or numbers. How Linux Works: What Every Super-User Should Know

You can disable host-name resolution with the -n option. Finally, lsof -P forces numeric port listings. ISBN:1593270356 by Brian Ward No Starch Press © 2004 (347 pages)

don't have lsof on your system, you can run netstat -p to get the processes Note If you This guide describes the inner workings of a Linux system beginning with the file system and boot process and associated with ports. This a networking, Linux-specific netstat feature, but lsof is still far more covering advanced topics suchisas firewalls, development tools, device management, shell scripts, and sharing printers with Samba. flexible. Table of Contents

6.5.2tcpdump

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

If you need to know what's happening on your network, tcpdump puts your network interface card into - Devices, Disks, Filesystems, and the Kernel promiscuous mode and reports on every packet that crosses the wire. Chapter 3 - How Linux Boots Chapter 2 Chapter 4

System Files, Servers, and Utilities tcpdump- Essential with no arguments produces output resembling the following sample, which includes an ARP - Configuring Your Network request and Web connection:

Chapter 5 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

tcpdump: listening Chapter 8 - Development Toolson

eth0

20:36:25.771304 arp who-has Chapter 9 - Compiling Software From Sourcemikado.example.com Code

tell duplex.example.com mikado.example.com is-at 0:2:2d:b:ee:4e 20:36:25.774796 duplex.example.com.48455 > mikado.example.com.www: S Chapter 11 - Configuring and Manipulating Peripheral Devices 3200063165:3200063165(0) win 5840 Chapter 12 - Printing (DF) 13 - Backups Chapter 20:36:25.779283 mikado.example.com.www > duplex.example.com.48455: S Chapter 14 - Sharing Files with Samba 3494716463:3494716463(0) ack 3200063166 win 5792 (DF) Chapter 16 - User Environments 20:36:25.779409 duplex.example.com.48455 > mikado.example.com.www: . ack 1 win Chapter 17 - Buying Hardware for Linux 5840 (DF) Chapter 18 - Further Directions 20:36:25.779787 duplex.example.com.48455 > mikado.example.com.www: P Appendix A - Command Classification 1:427(426) ack 1 win 5840 (DF) Bibliography 20:36:25.784012 mikado.example.com.www > duplex.example.com.48455: . ack 427 Index win 6432 (DF) List of Figures 20:36:25.845645 mikado.example.com.www > duplex.example.com.48455: P List of Tables 1:773(772) ack 427 win 6432 (DF) List of Sidebars 20:36:25.845732 duplex.example.com.48455 > mikado.example.com.www: . ack 773 win 6948 (DF) 20:36:25.774729 arp reply Chapter 10 - Maintaining the Kernel

9 packets received by filter 0 packets dropped by kernel You can tell tcpdump to be more specific by adding some filtering arguments. You can filter based on source and destination hosts, networks, Ethernet addresses, protocols at many different layers in the network model, and much more. Among the many packet protocols that tcpdump recognizes are ARP, RARP, ICMP, TCP, UDP, IP, IPv6, AppleTalk, and IPX packets. For example, if you want tcpdump to output only TCP packets, run this command: tcpdump tcp

If you want to see W eb packets and UDP packets, use this command: tcpdump udp or port 80 In the preceding examples, tcp,udp, and port 80 are called primitives. The most important primitives are in Table 6-3: Table 6-3: tcpdump Primitives

Primitive

Packet Specification

tcp

How Linux Works: Every Super-User Should Know TCP What packets

udp

by Brian Ward No Starch PressUDP © 2004packets (347 pages)

ISBN:1593270356

guide describes the inner workings of a Linux system beginning with the file system and boot process and portport This TCP and/or UDP packets to/from port port covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

hosthost

sharing printers with Samba.

Packets to or from host Packets to or from network

net Table ofnetwork Contents

How Linux Works—What Every Super-User Should Know Chapter As you1

- The saw inBasics the example, or is an operator. Other operators include and and !; you may use serious work with tcpdump, make sure that you read Chapter 3 - How Linuxespecially Boots the manual page, the section that describes the primitives. Chapter 2 - Devices, Disks, Filesystems, the to Kernel parentheses for grouping. If you'reand going do any Chapter 4

- Essential System Files, Servers, and Utilities

good judgment when Note Chapter 5 - Use Configuring Your Network Chapter 6 Chapter 7 Chapter 8 Chapter 9 Chapter 10

using tcpdump. The output shown earlier in this section includes only layer) and IP (Internet layer) header information, but you can also make theScripts entire packet contents. Even though many network operators make it far too - tcpdump Introductionprint to Shell - easy Development to lookTools at their network packets, it doesn't mean that you should. Don't snoop around on - networks Compiling Software From Source other than the onesCode you own, unless you happen to be in the espionage business and - understand Maintaining the theKernel risks of having sensitive wiretapped data. - packet Network TCP Services (transport

Chapter 11 - Configuring and Manipulating Peripheral Devices

If you 12 find that you Chapter - Printing tcpdump named Chapter 13 - Backups

need to do a lot of packet sniffing, you should probably consider a GUI alternative to Ethereal.

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

6.5.3Netcat

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

If you need more flexibility in connecting to a remote host than a command such as telnet host port allows, use netcat (or nc). Netcat can connect to remote TCP/UDP ports, specify a local port, listen on Appendix A - Command Classification ports, scan ports, redirect standard I/O to and from network connections, and more. Chapter 18 - Further Directions Bibliography Index

To open a TCP connection to a port, run this command:

List of Figures List of Tables

netcat host port

List of Sidebars

netcat does not terminate until the other side of the connection ends the connection. This can confuse you if you redirect standard input to netcat. You can end the connection at any time by pressing CONTROL-C. To listen on a port, run this command: netcat -l -p port

Note There are two versions of netcat. The somewhat quirky original has just one executable name, nc, with a final version number of around 1.10. However, there is a newer GNU version using the namenetcat, though the current version numbers are lower than the original. The new version includes several improvements, not the least of which is a manual page. The netcat utility is very specific in its treatment of the network connection; in particular, it does not like to exit until the network connection has terminated. If this behavior doesn't suit your application (in particular, if you'd like the program and network connection to terminate based on the standard input stream), try the sock program instead.

How Linux Works: What Call Every Super-User 6.6 Remote Procedure (RPC) Should Know by Brian Ward

ISBN:1593270356

Press © 2004 (347 call. pages)The basic idea is that programs call functions on remote programs RPC stands No forStarch remote procedure guide describes the inner of a programs Linux system beginning with code the fileor system and boot process and (identified byThis program numbers), and workings the remote return a result message.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

RPC implementations use transport protocols such as TCP and UDP, and they require a special intermediary service to map program numbers to TCP and UDP ports. The server is called portmap, and Table of Contents it must be running on any machine that wants to use RPC services. How Linux Works—What Every Super-User Should Know Chapter - The If you 1want to Basics know

what RPC services your computer has, run this command:

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

rpcinfo -p localhost

Chapter 6

- Network Services RPC is one of those protocols that just doesn't seem to want to die. The unpleasant Network File System - Introduction to Shell Scripts (NFS) and Network Information Service (NIS) systems use RPC, but they are completely unnecessary on Chapter 8 - Development stand-alone machines.Tools But whenever you think that you've eliminated all need for portmap, something Chapter 9 - Compiling Software From Source Code else comes up, such as File Access Monitor (FAM) support in GNOME. Chapter 7

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 6.7 Network Security by Brian Ward

ISBN:1593270356

No Starch Presspopular © 2004 (347 pages) Because Linux is a very Unix flavor on the PC platform, it attracts more unpleasant characters This guide describes the inner workings of a5.13 Linuxtalked systemabout beginning with thebut file this system boot the process and who try to break into computer systems. Section firewalls, isn'tand really whole covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and story on security. sharing printers with Samba.

Network security attracts extremists. Those who are interested in breaking into systems do so because they really like to, and those who come up with elaborate schemes to protect themselves do so because How Linux Works—What Every Super-User Should Know they really like to swat away people trying to break into their systems.

Table of Contents Chapter 1

- The Basics

Chapter 2 - Devices, Filesystems, and the Most people wouldDisks, rather just not have toKernel deal with

it, but that attitude and a broadband connection will get in no time. Fortunately, you don't need to know very much to keep your system Chapter 4 - Essential System Files, Servers, and Utilities safe. Here are a few basic rules of thumb: Chapter 3 - How Linux Boots your system compromised Chapter 5

- Configuring Your Network

Chapter 6

Network Services Run- as few services as possible Intruders can't break into services that don't exist on your system. - Introduction to Shell Scripts If you know what a service is, and you're not using it at the moment, don't turn it on just in case you Chapter 8 - Development Tools might want it sometime. Chapter 7 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel ChapterBlock 11 - Configuring Peripheral Devices as muchand as Manipulating possible with a firewall Unix

systems have a number of internal services that know about, such as TCP port 6000 for the X Window System server. No other system in Chapterthe 13 world - Backups needs to know about these services, and no other system in the world should know about Chapterthem, 14 - Sharing with Samba it is very difficult to track and regulate the services on your system, either. Files Furthermore, Chapterbecause 15 - Network Filedifferent Transfer kinds of programs listen on ports. You can prevent intruders from discovering many Chapterinternal 16 - User Environments services with effective firewall rules. Refer to Section 5.13.1 for an example firewall. Chapteryou 12 -may Printing not

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Keep on top of the services Appendix A - Command Classification

that you offer to the entire Internet If you run an SSH server or or other services, make sure that you have the ability to stay up to date with the software and get appropriate alerts. See Section 6.7.4 for some online resources.

Postfix Bibliography Index

List of Figures List of Tables

Don't give an account to anyone who doesn't need an account It's much easier to gain superuser access from a local account than it is to break in remotely. In fact, given the huge base of software (and the resulting bugs and design flaws) available on most systems, it's almost laughably easy to gain superuser access to a system after you get to a shell prompt. Don't assume that your friends know how to protect their passwords (or to choose good passwords in the first place).

List of Sidebars

Avoid installing dubious binary packages They can contain Trojan horses. That's the practical end of protecting yourself. You should know a few basics on why it is important to do so. There are three basic kinds of network attacks: Full compromise This means getting superuser access (full control) of a machine. An intruder can accomplish this by trying a service attack, such as a buffer overflow exploit, or by taking over a poorly protected user account, and then trying to exploit a poorly written setuid program. Denial-of-service (DoS) attacks These prevent a machine from carrying out its network services, or they force a computer to malfunction in some other way without any special access. These attacks are harder to prevent, but they are easier to respond to. Virus or worm Linux users are mostly immune to email worms and viruses, simply because their email clients aren't so stupid as to actually run programs that they get in message attachments, and Linux isn't as attractive a target as Windows. However, you can create a Linux virus; it's been done before, and as Linux gains popularity, it will happen with increasing frequency. Avoid binary software distributions, especially from places that you've never heard of. Some network services have been susceptible to worms before, and history is doomed to repeat itself.

6.7.1Where Linux Distributions Stand Not long ago, installing certain Linux distributions on easily accessible networks (such as university networks) practically ensured security compromises. These distributions activated every single service by

default and had no default firewalling. It wasn't just Linux, either — Solaris was remarkably good at leaving the door open, not to mention the hundreds of Windows exploits, and so on. How Linux Works: What Every Super-User Should Know

Linux distributions better now; they do not activate every possible service, and they tend to come with ISBN:1593270356 by Brianare Ward preconfigured firewalls. There is no doubt that the firewalls do most of the work. Programmers delight in No Starch Press © 2004 (347 pages) adding new This network services, especially for GUI applications and support, but security often takes a guide describes the inner workings of a Linux system beginning with the file system and boot process and backseat. Better authentication (such the Kerberos system) would help tremendously, but this covering advanced topics such as as networking, firewalls, development tools, device management, shellhappens scripts, and printersand with most Samba. to be one of sharing the weakest disorganized areas of most applications. A firewall isn't necessarily Table of Contents

the ideal solution, but it does offer a uniform way to block all network traffic. The was the TCP wrapper system, but that only worked for inetd1 servers and applications that specifically included wrapper support. Chapter - The Basics only thing that ever Every cameSuper-User close to this in the past How Linux Works—What Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

In a perfect world, programmers would write invulnerable code, but while you wait for a perfect world, you - How Linux Boots need to know what to look out for. Chapter 4 - Essential System Files, Servers, and Utilities Chapter 3 Chapter 5

- Configuring Your Network

- Network Services 6.7.2Typical Vulnerabilities

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter Tools There8are- Development two important kinds

of vulnerabilities that you need to worry about: direct attacks and clear-text over your machine without being terribly subtle. The most Chapter 10 -type Maintaining theattack Kernel is a buffer overflow exploit, where a careless programmer doesn't check the common of direct Chapter 11of - Configuring and Manipulating Peripheral Devices bounds a buffer array. The attacker fabricates a stack frame inside a huge chunk of data, dumps it to Chapter 12 - Printing the remote server, then hopes that the program overwrites its program data and eventually executes the Chapter 13 - Backups new stack frame. It's a somewhat complicated attack, but easy to replicate. Chapter 9 - Compiling Software From Source Code password sniffing. Direct attacks just try to take

Chapter 14 - Sharing Files with Samba Chapter - Network File Transfer On the15other hand, clear-text

passwords can allow intruders to log in to your machine. From there, they will access locally (which is much easier than making a remote attack), try to Chapter 17machine - Buying Hardware for Linux use the as an intermediary for attacking other hosts, or both. Chapter 16 - User inevitably try toEnvironments gain superuser Chapter 18 - Further Directions

Note you have a service Appendix A - If Command Classification Bibliography Index

that you need to encrypt, but the service offers no native support, you can try Stunnel (http://www.stunnel.org/), an encryption wrapper package much like TCP wrappers. Like tcpd, Stunnel is especially good at wrapping inetd services.

List of Figures

Some servers List of Tables

deactivate List of Sidebarsthe

are chronic targets of attacks because of poor implementation and design. You should following services if you ever come across them:

sendmail I would usually not rail against a specific program, but Sendmail has an exceptionally long history of exploitation. There are two very good alternative mail servers, Postfix (http://www.postfix.org/) and qmail (http://www.qmail.org/). ftpd For whatever reason, all FTP servers seem plagued with vulnerabilities. In addition, most FTP servers use clear-text passwords. If you have to move files from one machine to another, consider an SSH-based solution or an rsync server. telnetd, rlogind, rexecd All of these pass remote session data (including passwords) in cleartext form. Avoid them unless you happen to have a Kerberos-enabled version. fingerd Intruders can get user lists and other information with the finger service.

6.7.3Port Scanning Listing your open ports and firewall configuration with netstat and iptables is a good start for staying on top of unwanted traffic, but you may want to go a step further with Nmap (Network Mapper), a program that scans all of the ports on a machine or network of machines, looking for potential vulnerabilities. Nmap gives you a view from the outside and eliminates guessing which ports are open. Most intruders use Nmap, and you can get it at http://www.insecure.org/. Warning If someone else controls the network that you want to Nmap (or run Nmap from), ask that person if it's all right that you do so. Network administrators watch for port scans and delight in stomping on any machine that runs a scan. Just run nmaphost to run a generic scan on a host. Here's an example scan: Starting nmap 3.30 (http://www.insecure.org/nmap/) at 2003-08-04 16:25 PDT

Interesting ports on host (10.1.2.2): (The 1636 ports scanned but not shown below are in state: closed) Port State Service How Linux Works: What Every Super-User Should Know 9/tcp openWard discard ISBN:1593270356 by Brian 13/tcp No open Starch Press © 2004 daytime (347 pages) 22/tcp ssh Thisopen guide describes the inner workings of a Linux system beginning with the file system and boot process and covering such as networking, firewalls, development tools, device management, shell scripts, and 37/tcp openadvanced topics time printers with Samba. 111/tcp sharing open sunrpc 113/tcp open auth Table of Contents open 6000/tcp X11 How Linux Works—What Every Super-User Should Know Chapter - The Basics Nmap 1run completed

-- 1 IP address (1 host up) scanned in 0.594 seconds

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4 -in Essential System Files, Servers, and Utilities The host this example probably doesn't have

any kind of firewall running, because it has quite a few

Chapter 5 - Configuring Your Network open ports. Chapter 6

- Network Services

Nmap7can do much more —Scripts have Chapter - Introduction to Shell Chapter 8

a look at its manual page and the considerable online resources.

- Development Tools

Chapter 9

- Compiling Software From Source Code 6.7.4Security Resources

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Here are three good security sites:

Chapter 12 - Printing

Chapterhttp://www.sans.org/ 13 - Backups

Offers training, services, a free weekly newsletter of the top current policies, and more.

sample security Chaptervulnerabilities, 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapterhttp://www.cert.org/ 16 - User Environments

A place to look for the most severe problems.

Chapter 17 - Buying Hardware for Linux

http://www.insecure.org/ This is the place to go for Nmap and pointers to all sorts of network exploit testing tools. It's much more open and specific about exploits than many other sites. Appendix A - Command Classification Chapter 18 - Further Directions Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 7: Introduction to Shell Scripts by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

If you can enter commands into the shell, you can write Bourne shell scripts. A script is a series of commands written in a file, and the shell reads the commands from the file just as it would if you typed Table of Contents them into a terminal. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics As with any program on Unix systems, you need to set the executable bit for the script file, but you must - Devices, Disks, Filesystems, and the Kernel also set the read bit. The easiest way to do this is as follows:

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

chmod +x script - Configuring Your Network

Chapter 5 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Thischmod command allows other users to read and execute script. If you don't want that, use the - Development Tools absolute mode 700 instead (and refer back to Section 1.17 for a refresher on permissions). Chapter 9 - Compiling Software From Source Code Chapter 8

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 7.1 ShellHow Script Basics by Brian Ward

ISBN:1593270356

No Starch Press © 2004start (347 pages) All Bourne shell scripts should with the following line, indicating that the /bin/sh program should guide describes innerfile: workings of a Linux system beginning with the file system and boot process and execute the This commands in thethe script

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

#!/bin/sh Table of Contents How Linux Works—What Every Super-User Should Know

Make 1sure that no whitespace Chapter - The Basics

appears at the beginning of the script file. You can list any commands that you want the shell to execute following the #!/bin/sh line. Here is a very simple example: Chapter 2 - Devices, Disks, Filesystems, and the Kernel Chapter 3

- How Linux Boots

#!/bin/sh Chapter 4 - Essential System Files, Servers, and Utilities # Chapter 5

- Configuring Your Network

# Print something, Chapter 6 - Network Services Chapter 7

then run ls

- Introduction to Shell Scripts

echo 8About to run the Chapter - Development Tools ls 9 Chapter

ls command.

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

A# character at the Chapter 12 - Printing anything a line Chapter 13 -on Backups

beginning of a line indicates that the line is a comment; that is, the shell ignores after a #. Use comments to explain parts of your scripts that are not easy to understand.

Chapter 14 - Sharing Files with Samba

After creating a script and setting Chapter 15 - Network File Transfer

its permissions, you can run the script by placing the script file in one of path and then running the script name on the command line. Alternatively, you can run ./script if the script is located in your current working directory. Chapter 17 - Buying Hardware for Linux the directories in your command Chapter 16 - User Environments Chapter 18 - Further Directions

7.1.1Limitations of Shell Scripts

Appendix A - Command Classification Bibliography Index

The Bourne shell manipulates commands and files with relative ease. You already saw the way the shell can redirect output in Section 1.14; this is one of the important elements of shell script programming. List of Tables However, shell scripts are not the be-all and end-all of Unix programming. If you're trying to pick apart List of Sidebars strings or do arithmetic computations, or if you want functions or complex control structures, you're better off using a scripting language like Perl, Python, or awk, or perhaps even a compiled language like C. List of Figures

Be aware of your shell script sizes. Bourne shell scripts aren't meant to be big (though you will undoubtedly encounter some monstrosities in your time).

How Linux Works: What Every Super-User Should Know 7.2 Quoting by Brian Ward

ISBN:1593270356

No Starch 2004 (347 Aliteral is a string thatPress you©want thepages) shell to leave alone and pass to the command line. To see where a This consider guide describes of expands a Linux system with directories the file system process and literal is useful, how the theinner shellworkings normally * to beginning all files and in and the boot current covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and directory, then passes all those items on to the current command line. If you just want a star (*) to be used sharing printers with Samba. by a command, as you would for grep and other programs that use regular expressions, you need special notation to pass a literal *.

Table of Contents

How Linux Works—What Every Super-User Should Know

The easiest way to make the shell leave a string alone is to enclose the entire string in single quotes. with grep and *:

Chapter Basics Here's1 an- The example Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

grep 'r.*t' /etc/passwd - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

All characters located between the two single quotes, including any spaces, make up a single literal. - Development Tools Therefore, the following command does not work, because it asks the grep command to search for the Chapter 9 - Compiling Software From Source Code string r.*t /etc/passwd from the standard input (because there is only one parameter): Chapter 8

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

grep 12 'r.*t /etc/passwd' Chapter - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

Double quotes (") work just like single quotes, except that the shell expands any variables that appear it does not expand variables located between single quotes. You can see the difference byHardware running for theLinux following command and then replacing the double quotes with single quotes Chapter 17 - Buying and running it again. Chapter 18 - Further Directions Chapter 15 - Network File Transfer

within 16 double whereas Chapter - Userquotes, Environments

Appendix A - Command Classification

echo "There Bibliography

is no * in my path: $PATH"

Index List of Figures

One tricky List of Tables

part to using literals with the Bourne shell is passing a literal single quote to a command. One is to place a backslash before the single quote character:

way to do this List of Sidebars

echo I don\'t like contractions inside shell scripts.

The backslash and quote must appear outside any pair of single quotes. Astring such as 'don\'t results in a syntax error. However, oddly, you can enclose the single quote inside double quotes, as the following example shows (the output is identical to that of the preceding command): echo "I don't like contractions inside shell scripts."

How Linux Works: What Every Super-User Should Know 7.3 Special Variables by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) Most shell scripts understand command-line parameters and interact with the commands that they run. To This guide workings of atoLinux system beginning with the fileneed system boothow process and take your scripts fromdescribes simple the listsinner of commands more flexible programs, you toand know to use covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and the special Bourne shell variables. Using special variables is not much different than using any other shell sharing printers with Samba. variable (see Section 1.8 ), but you cannot change the value of certain special variables. Table of Contents

After reading the next few sections, you will understand why shell scripts accumulate many special characters as they are written. If you're trying to understand a shell script and you come across a line that Chapter 1 - The Basics looks completely incomprehensible, pick it apart piece by piece. How Linux Works—What Every Super-User Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

- Essential 7.3.1$1, $2, System ... Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

$1,$2,6 and all variables Chapter - Network Servicesnamed

as positive nonzero integers contain the values of the script parameters,

or arguments. Chapter 7 - Introduction to Shell Scripts Chapter 8

- Development Tools

Let's say name Software of the following script is Chapter 9 -the Compiling From Source Code

named pshow:

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices #!/bin/sh Chapter - Printing echo 12 First argument:

$1 $3

Chapter - Backups echo 13 Third argument:

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Running one two Chapter 16 pshow - User Environments

three produces this output:

Chapter 17 - Buying Hardware for Linux Chapter - Further Directions First18 argument: one Appendix - Command Classification Third Aargument: three Bibliography Index List of Figures The built-in

shell command shift is used with argument variables. This command removes the first and advances the rest of the arguments forward — that is, $2 becomes $1,$3 becomes List of and Sidebars $2, so on. Assume that the name of the following script is shiftex: List of Tables ($1) argument

#!/bin/sh echo Argument: $1 shift echo Argument: $1 shift echo Argument: $1 shift

Runshiftex one two three. This output appears: Argument: one Argument: two Argument: three

7.3.2$# The$# variable holds the number of arguments passed to the script. This variable is especially important when running shift in a loop to pick through arguments; when $# is 0, no arguments remain, so $1 is empty. (See Section 7.6 for a description of loops.)

7.3.3$@ The$@ variable represents all of the script's arguments, and it is very useful for passing all of a script's arguments to one of the commands inside the script. For example, you will learn in Section 12.6 that the arguments to Ghostscript (gs) are complicated. Suppose that you want a shortcut for rasterizing a PostScript file at 150 dpi, using the standard output stream, but also leaving the door open for passing other options to gs. You could write a script like the following that allows for additional command-line

options: #!/bin/shHow Linux Works: What Every Super-User Should Know by Brian-dNOPAUSE Ward gs -q -dBATCH -dSAFER -sOutputFile=- -sDEVICE=pnmraw $@

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Note If a line in your shell script gets too long for your text editor, you can split it up with a backslash example, you can alter the preceding script as follows:

Table of Contents (\). For

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- #!/bin/sh Devices, Disks, Filesystems, and the Kernel

Chapter 3

-dBATCH - gs How -q Linux Boots

Chapter 4

-sOutputFile=-sDEVICE=pnmraw - Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 8

- Development Tools

-dNOPAUSE -dSAFER \

A double-quoted $@ ("$@ ") expands Chapter 7 - Introduction to Shell Scripts

$@

to the parameters separated by spaces.

- Compiling Software From Source Code 7.3.4$0

Chapter 9

Chapter 10 - Maintaining the Kernel

Chapter - Configuring Peripheral The$011variable holdsand theManipulating name of the script,Devices and it is

useful for generating diagnostic messages. Let's say to report an invalid argument that is stored in the $BADPARM variable. You can print Chapter 13 - Backups the diagnostic message with the following line so that the script name appears in the error message: Chapter 12 -script Printing that your needs

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

echo$0: bad option $BADPARM

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

You should send diagnostic error messages to the standard error. Recall from Section 1.14.1 that 2>&1 redirects the standard error to the standard output. For writing to the standard error, you can reverse the Bibliography process with 1>&2. To do this for the preceding example, use this: Appendix A - Command Classification Index

List of Figures

echo $0: List of Tables

bad option $BADPARM 1>&2

List of Sidebars

7.3.5$$ The$$ variable holds the process ID of the shell.

7.3.6$? The$? variable holds the exit code of the last command that the shell executed. Exit codes are critical to mastering shell scripts, and they're discussed next.

How Linux Works: What Every Super-User Should Know 7.4 Exit Codes by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) an exit code for the parent process that started the program. The When a UnixNoprogram finishes, it leaves This guide describes the inner workings a Linux with thecode file system and boot process and exit code is a number and is sometimes calledofan errorsystem code. beginning When the exit is zero (0), this means covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and that the program ran without problems. However, if the program has an error, it usually exits with some sharing printers with Samba. number other than 0. Table Contents Theofexit code of

the last command is held in the $? special variable, so you can check it out for yourself at your shell prompt:

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

$ ls / ->How /dev/null Linux Boots $ echo $? Chapter 4 - Essential System Files, Servers, and Utilities 0 Chapter 5 - Configuring Your Network $ ls /asdfasdf > /dev/null Chapter 6 - Network Services ls: /asdfasdf: No such file or directory Chapter 7 - Introduction to Shell Scripts $ echo $? Chapter 8 - Development Tools 1 Chapter 9 - Compiling Software From Source Code Chapter 3

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

You can see that the successful command returned 0 and the unsuccessful command returned 1.

Chapter 12 - Printing

Chapter 13 - Backups

If you intend to use the exit code of a command, you must use or store the code immediately after running run athird echo $? just after the preceding series of commands, the Chapter - Network Transfer result 15 would be 0 File because the second of the two echo commands completed successfully. Chapter 14 - Sharing Files with Samba the command. For example, if you Chapter 16 - User Environments Chapter - Buying Hardware for Linux When17 writing shell code that aborts

a script abnormally, you should use something like exit 1 to pass an parent process ran the script. You don't necessarily have to use 1; for Appendix A - you Command Classification example, may want to use different numbers for different conditions. Chapter 18 - of Further Directions exit code 1 back to whatever Bibliography

Note A few programs like diff and grep use nonzero exit codes to indicate normal conditions. For returns 1 if it finds something matching its pattern in its input, and 0 if not. In this List of Tablescase, the nonzero exit code is not an error. These commands use other exit codes for errors: List of Sidebars grep and diff use 2 for real problems. If you think a program is using a nonstandard exit code, read its manual page. The exit codes are usually explained in the DIAGNOSTICS section. Index

List of Figuresexample,grep

How Linux Works: What Every Super-User Should Know 7.5 Conditionals by Brian Ward

ISBN:1593270356

Starch © 2004 (347 pages) for conditionals, such as if/then/else and case statements. Here is The Bourne No shell hasPress special constructs Thiswith guidean describes the inner workings of a Linux system with the file system and boot process and a simple script if conditional that checks to see if thebeginning script's first argument is hi:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

#!/bin/sh if of [ Contents $1 = hi Table

]; then

echo 'The first argument wasKnow "hi"' How Linux Works—What Every Super-User Should else 1 Chapter

- The Basics

echo -n 'The first argument was Chapter 2 - Devices, Disks, Filesystems, and the Kernel

not "hi" -- ' echo It was '"'$1'"' Chapter 3 - How Linux Boots fi 4 - Essential System Files, Servers, and Utilities Chapter Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

The words if,then,else, and fi in the preceding script are shell keywords. Everything else is a - Introduction to Shell Scripts command. This is an extremely important point, because one of the commands is [$1 = "hi" ]. The [ Chapter 8 - Development Tools character an actual program a Unix system; it is not special shell syntax. All Unix systems have a Chapter 9 - is Compiling Software Fromon Source Code command called [ that performs tests for shell script conditionals. This program is also known as test — Chapter 10 - Maintaining the Kernel careful examination of [ and test should reveal that they share an inode, or one is a symbolic link to the Chapter 11 - Configuring and Manipulating Peripheral Devices other. 12 - Printing Chapter Chapter 7

Chapter 13 - Backups

Now you can see why the exit codes in Section 7.4 are so important, because this is how the whole process works: Chapter 15 - Network File Transfer 1. 16The shell runs the command after the if keyword and collects the exit code of that command. Chapter - User Environments Chapter 14 - Sharing Files with Samba

Chapter 17 - Buying Hardware for Linux

2. If the exit code is 0, the shell executes whatever commands follow the then keyword, stopping when it reaches an else or fi keyword. Appendix A - Command Classification Chapter 18 - Further Directions Bibliography Index

3. If the exit code is not 0 and there is an else clause, the shell runs the commands after the else keyword.

List of Figures

List of4. Tables The

conditional ends at fi.

List of Sidebars

Note There is a slight problem with the conditional in the preceding example — a very common mistake. $1 could be empty, because the user might not enter a parameter. Without a parameter, the test reads [="hi" ], and the [ command aborts with an error. You can fix it by enclosing the parameter in quotes in one of the two following ways (both are common): if [ "$1" = hi ]; then if [ x"$1" = x"hi" ]; then

It is worth repeating that the stuff following if is always a command. You need a semicolon (;) after the test command — if you skip the semicolon, the shell passes then as a parameter to the test command. (If you don't like the semicolon, you can put the then keyword on a separate line.) Here is an example that uses grep instead of the [ command: #!/bin/sh if grep -q daemon /etc/passwd; then echo The daemon user is in the passwd file. else echo There is a big problem. daemon is not in the passwd file. fi

There is also an elif keyword that lets you string if conditionals together like this: #!/bin/sh if [ $1 = "hi" ]; then echo 'The first argument was "hi"' elif [ $2 = "bye" ]; then echo 'The second argument was "bye"' else

echo -n 'The first argument was not "hi" and the second was not "bye"-- ' echo They were '"'$1'"' and '"'$2'"' fi

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

Don't get toocovering carriedadvanced away with elif, because the case construct that tools, you will seemanagement, in Section shell 7.5.3scripts, is topics such as networking, firewalls, development device and printers with Samba. usually moresharing appropriate. Table of Contents

7.5.1&& and || Logical Constructs

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

There are two quick one-line conditional constructs that you may see from time to time: && ("and") and || - Devices, Disks, Filesystems, and the Kernel ("or"). Chapter 3 - How Linux Boots Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities The&& construct works like this:

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

command1 && command2 Chapter 7 - Introduction to Shell Scripts Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Here, the shell runs command1, and if the exit code is 0, it also runs command2.

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

The|| construct is similar; if the command before a || returns a nonzero exit code, the shell runs the second command.

Chapter 12 - Printing

Chapter 13 - Backups

Chapter 14|| - Sharing Files their with Samba && and often find way into

use in if tests. In both cases, the exit code of the last command run the conditional. In &&, if the first command fails, the shell uses its exit Chapter 16 -the User code for ifEnvironments statement, but if the first command is successful, the shell uses the exit code of the Chapter 17command - Buying Hardware Linux second for the for conditional. For ||, the shell uses the exit code of the first command if Chapter 18 - Further Directions successful, or the exit code of the second if the first is unsuccessful. Chapter 15 - Network Fileshell Transfer determines how the processes

Appendix A - Command Classification Bibliography Here is an

example:

Index List of Figures

#!/bin/sh if [ "$1" = hi ] || [ "$1" = bye ]; then List of Sidebars echo 'The first argument was "'$1'"' fi List of Tables

If your conditionals include the test ([) command (as here), you can use -a and -o instead of && and ||, as described in the next section.

7.5.2Testing Conditions You have already seen how [ works; the exit code is 0 if the test is true and nonzero when the test fails. You also know how to test string equality with [str1 = str2 ]. However, remember that shell scripts are well suited to operations on entire files. An important reason for this is that the most useful [ tests involve file properties. For example, the following line checks whether file is a regular file (not a directory or special file): [ -f file ] In a script, you might see the -f test in a loop similar to this next one, which tests all of the items in the current working directory: for filename in *; do if [ -f $filename ]; then ls -l $filename file $filename else echo $filename is not a regular file. fi done

You can invert a test by placing the ! operator before the test. For example, [!-ffile ] returns true if file is not a regular file. Furthermore, the -a and -o flags are the and and or operators (for example, [How Linux ffile1 -afile2 ]). Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

No Starch Pressoperations © 2004 (347 pages) There are dozens of test that fall into three general categories: file tests, string tests, and This guide describes thecontain inner workings of a Linux system beginning withbut thethe file test(1) system and boot process arithmetic tests. The info pages complete online documentation, manual page isand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and also a fast reference. The following sections outline the main tests (some of the less common tests have sharing printers with Samba. been omitted). Table of Contents

File Tests

How Linux Works—What Every Super-User Should Know Chapter 1

The Basics Most file -tests, like -f, are called unary operations because they require only one argument — the file to - Devices, Disks, Filesystems, and the Kernel test.

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4 -two Essential Systemfile Files, Servers, and Utilities Here are important tests: Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

-e Returns true if a file exists

Chapter 7

- Introduction to Shell Scripts -s Returns true if a file is not empty

Chapter 8

- Development Tools

Chapter 9 operations - Compiling Software Source Several inspect From a file's type,Code meaning

that they can determine whether something is a regular of special device. Those operations are listed in Table 7-1. There are also a Chapter 11 of - Configuring and Manipulating Peripheral Devices number unary operations that check a file's permissions, as listed in Table 7-2 on the next page (see Chapter 12 1.17 - Printing Section for an overview of permissions). Chapter - Maintaining the Kernel file, a 10 directory, or some kind

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

Table 7-1: File Type Operators

Chapter 15 - Network File Transfer Chapter 16 - User Environments Operator

Tests For

Chapter 17 - Buying Hardware for Linux

-f 18 - Further Directions Chapter

Regular file

Appendix A - Command Classification

Directory

-d

Bibliography

Symbolic link

-h Index List of Figures

-b

List of Tables List-c of Sidebars

Block device Character device

-p

Named pipe

-S

Socket

Table 7-2: File Permissions Operators Operator

Returns True if the File Is:

-r

Readable

-w

Writable

-x

Executable

-u

Setuid

-g

Setgid

-k

"Sticky" Note Except for -h,test follows symbolic links. That is, if link is a symbolic link to a regular file, [ -f link ] returns an exit code of true (0).

Finally, there are three binary operators (tests that need two files as arguments) that are used in file tests, but they are not terribly common. Consider this command that includes -nt (newer than): [file1 -nt file2 ] This exits true if file1 has a newer modification date than file2. The -ot (older than) operator does the opposite. And if you need to detect identical hard links, -ef compares two files and returns true if they share inode numbers and devices.

String Tests How Linux Whatstring Every operator Super-User Know true if its operands are equal. The != You have already seenWorks: the binary =, Should which returns ISBN:1593270356 by Brian Ward operator returns true if its operands are not equal. No Starch Press © 2004 (347 pages)

There are two This unary guide string describes operations: the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and -z Returns true if its argument sharing printers with Samba.is empty ([-z "" ] returns 0) -n Returns true if its argument is not empty ([-n "" ] returns 1)

Table of Contents

How Linux Works—What Every Super-User Should Know

Arithmetic Tests - The Basics

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel It's important to recognize that = looks for string equality, not numeric equality. Therefore, [1=1] returns returns false. If you want to work with numbers, use -eq instead — [01-eq 1 Chapter 4 - Essential System Files, Servers, and Utilities ] returns true. Table 7-3 provides the full list of numeric comparison operators. Chapter 3 but - How Linux 0 (true), [01 = Boots 1 ] Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Table 7-3: Arithmetic Comparison Operators

Chapter 8 - Development Tools Operator Returns True Chapter 9

When the First Argument Is . . . the Second

- Compiling Software From Source Code

-eq 10 - Maintaining Equal the to Kernel Chapter Chapter 11 - Configuring and Manipulating Peripheral Devices

-ne

Not equal to

Chapter 12 - Printing

Chapter -lt 13 - Backups Less

than

Chapter 14 - Sharing Files with Samba

Greater than Chapter 15 - Network File Transfer -gt

Chapter -le 16 - User Environments Less than or

equal to

Chapter 17 - Buying Hardware for Linux

-ge 18 - Further Greater than Chapter Directions

or equal to

Appendix A - Command Classification Bibliography Index

7.5.3Matching Strings with case

List of Figures List of Tables

Thecase keyword forms another conditional construct that is exceptionally useful for matching strings. case does not execute any test commands and therefore does not evaluate exit codes. Here is an example that should tell most of the story:

List of Sidebars

#!/bin/sh case $1 in bye) echo Fine, bye. ;; hi|hello) echo Nice to see you. ;; what*) echo Whatever. ;; *) echo 'Huh?' ;; esac The shell executes this as follows: 1. The script matches $1 against each case value demarcated with the) character. 2. If a case value matches $1, the shell executes the commands below the case until encountering ;;. The shell then skips to the esac keyword. 3. The conditional ends with esac. For each case value, you can match a single string (such as bye in the preceding example), multiple strings with | (hi|hello returns true if $1 equals hi or hello), or make use of the * or ? wildcards (what*). If you want to make a case that catches all possible values other than the case values specified, use a single *, as shown by the final case in the preceding example.

Note Each case must end with a double semicolon (;;). You risk a syntax error otherwise. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 7.6 Loops by Brian Ward

ISBN:1593270356

No kinds Starch of Press © 2004 There are two loops in (347 the pages) Bourne shell; for loops and while loops. The for loop is much more This guide describes the inner workings a Linux system beginning with the file system and boot process and common; it is actually a "foreach" loop. Here'sofan example:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

#!/bin/sh forofstr in one Table Contents

two three four; do

echo $str Every Super-User Should Know How Linux Works—What done 1 Chapter

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Here, for, in,do, and done are all shell keywords. The shell executes the code as follows: - Configuring Your Network

Chapter 5

1. 6The shell sets the Chapter - Network Services

variable str to the first of the four space-delimited values following the in

(one).to Shell Scripts Chapter 7keyword - Introduction Chapter 8

- Development Tools

2. 9The shell runs the echo Chapter - Compiling Software From command Source Codebetween

the do and done.

Chapter 10 - Maintaining the Kernel

3. The shell goes back to the for line, setting str to the next value (two), runs the commands betweendo and done, and repeats the process until it is through with the values following the in keyword. Chapter 13 - Backups Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba

Therefore, the output of this script looks like this:

Chapter 15 - Network File Transfer Chapter 16 - User Environments

one 17 - Buying Hardware for Linux Chapter two 18 - Further Directions Chapter three A - Command Classification Appendix four Bibliography Index List of Figures

The Bourne shell's while loop uses exit codes, like the if conditional. This example does ten iterations:

List of Tables

List of Sidebars

#!/bin/sh FILE=/tmp/whiletest.$$; echo firstline > $FILE while tail -10 $FILE | grep -q firstline; do echo -n Number of lines in $FILE:' ' wc -l $FILE | awk '{print $1}' echo newline >> $FILE done rm -f $FILE

Here, the exit code of grep -q firstline is the test. As soon as the exit code is nonzero (in this case, when the string firstline no longer appears in the last ten lines in $FILE), the loop exits. You can break out of a while loop with the break statement. The Bourne shell also has an until loop that works just like while, except that it breaks the loop when it encounters a zero exit code rather than a nonzero exit code. This said, you shouldn't need to use the while and untilloops often. The somewhat obscure example in this section is indicative of the nature of while loops; if you need to use while, you should probably be using a language like awk or Perl instead.

How LinuxSubstitution Works: What Every Super-User Should Know 7.7 Command by Brian Ward

ISBN:1593270356

Starch © 2004a(347 pages) The Bourne No shell canPress redirect command's standard output back to the shell's own command line. That is, guide describes the inner workings of a Linux system command, beginning with system boot process and you can useThis a command's output as an argument to another or the youfilecan storeand the command covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and output in a shell variable. You do this by enclosing a command in backquotes (`). sharing printers with Samba.

Here's an example that stores a command inside a variable, FLAGS: Table of Contents How Linux Works—What Every Super-User Should Know

#!/bin/sh - The Basics FLAGS=`grep ^flags /proc/cpuinfo | sed 's/.*://' | head -1` Chapter 2 - Devices, Disks, Filesystems, and the Kernel echo Your processor supports: Chapter 3 - How Linux Boots for f in $FLAGS; do Chapter 4 - Essential System Files, Servers, and Utilities case $f in Chapter 5 - Configuring Your Network fpu) MSG="floating point unit" Chapter 6 - Network Services ;; Chapter 7 - Introduction to Shell Scripts 3dnow) MSG="3DNOW graphics extensions" Chapter 8 - Development Tools ;; Chapter 9 - Compiling Software From Source Code mtrr) MSG="memory type range register" Chapter 10 - Maintaining the Kernel ;; Chapter 11 - Configuring and Manipulating Peripheral Devices *) MSG="unknown" Chapter 12 - Printing ;; Chapter 13 - Backups esac Chapter 14 - Sharing Files with Samba echo $f: $MSG Chapter 15 - Network File Transfer done Chapter 16 - User Environments Chapter 1

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

The second line contains the command substitution, in bold type. This example is somewhat complicated, because it demonstrates that you can use both single quotes and pipelines inside the command Bibliography substitution backquotes. The result of the grep command is sent to the sed command (more about sed Index later), which removes anything matching the expression .*:, and the result of sed is then passed to List of Figures head. Appendix A - Command Classification

List of Tables

List Sidebars It'softoo easy

to go overboard with command substitution. For example, don't use `ls` in a script, because using the shell to expand * is faster. Also, if you want to invoke a command on several filenames that you get as a result of a find command, you may want to consider using a pipeline to xargs rather than command substitution (see Section 7.10.4).

How Linux Works: What Every Super-User Should Know 7.8 Temporary File Management by Brian Ward

ISBN:1593270356

NoisStarch Press © to 2004 (347 pages) Sometimes it necessary create a temporary file to collect output for use by a later command. When guide describes the inner workings of afilename Linux system beginning with the file no system and boot process making suchThis a file, you must make sure that the is unique enough that other programs willand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and accidentally sharing write toprinters the temporary file. with Samba.

You should know how to use the mktemp command to create temporary filenames. Here is a script that shows you what device interrupts have occurred in the last two seconds:

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

#!/bin/sh - Devices, Disks, Filesystems, and the Kernel TMPFILE1=`mktemp /tmp/im1.XXXXXX` Chapter 3 - How Linux Boots TMPFILE2=`mktemp /tmp/im2.XXXXXX` Chapter 4 - Essential System Files, Servers, and Utilities Chapter 2

Chapter 5

- Configuring Your Network

cat /proc/interrupts > $TMPFILE1 - Network Services sleep 2 Chapter 7 - Introduction to Shell Scripts cat /proc/interrupts > $TMPFILE2 Chapter 8 - Development Tools diff $TMPFILE1 $TMPFILE2 Chapter 9 - Compiling Software From Source Code rm -f $TMPFILE1 $TMPFILE2 Chapter 10 - Maintaining the Kernel Chapter 6

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

The argument to mktemp is a template. mktemp converts the XXXXXX to a unique set of characters and creates an empty file with that name (without the XXXXXX, the command fails). Notice that this script uses Chapter 14 - Sharing Files with Samba variable names to store the filenames, so that you only have to change one line if you want to change a Chapter 15 - Network File Transfer filename. Chapter 13 - Backups

Chapter 16 - User Environments

Chapter 17 - Not Buying for Linux all Hardware Unix flavors come

Note

with mktemp. If you're having portability problems, you might want use the$$ special variable to construct a temporary filename based on the process ID.

Chapter 18 - Further Directions

Appendix A - Command Classification Bibliography Another problem

is that scripts that employ temporary files are vulnerable to signals that abort the script leave temporary files behind. In the preceding example, pressing CONTROL-C before the second cat List of Figures leaves a temporary file in /tmp. You want to avoid this if possible. Use the trap command to command List of Tables create a signal handler to catch the signal that CONTROL-C generates. The handler removes the List of Sidebars temporary files: Index and

#!/bin/sh TMPFILE1=`mktemp /tmp/im1.XXXXXX` TMPFILE2=`mktemp /tmp/im2.XXXXXX` trap "rm -f $TMPFILE1 $TMPFILE2; exit 1" INT ...

Notice that you must use exit in the handler to explicitly end script execution. Otherwise, the shell continues running as usual after running the signal handler.

Linux Works: What Every Super-User Should Know 7.9 HereHow Documents by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 pages) Sometimes you wantPress to print a large section of text or feed a lot of text to another command. Rather than This guidecommands, describes the you innercan workings of athe Linux system beginning with the file system and boot process and using several echo employ shell's here document feature.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

The following is a script that shows how here documents work: Table of Contents

#!/bin/sh DATE=`date` - The Basics cat /lib/libreadline.so.2 (0x40019000) libncurses.so.3.4 => /lib/libncurses.so.3.4 (0x40045000) libdl.so.2 => /lib/libdl.so.2 (0x4008a000) libc.so.6 => /lib/libc.so.6 (0x4008d000) /lib/ld-linux.so.2 => /lib/ld-linux.so.2 (0x40000000) Executables alone do not know the locations of their shared libraries; they know only the names of the libraries, and perhaps a little hint. A small program named ld.so (the runtime dynamic linker/loader) finds and loads shared libraries for a program at runtime. The preceding ldd output shows the library names on

the left — that's what the executable knows. The right side shows where ld.so finds the library.

How ld.soHow Finds Libraries LinuxShared Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

The first place that the dynamic linker should normally look for shared libraries is an executable's No Starch Press © 2004 (347 pages) preconfigured runtime library search path (if one exists). You will see how create this path shortly. This guide describes the inner workings of a Linux system beginning withto the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Next, the dynamic linker looks in a system cache, /etc/ld.so.cache, to see if the library is in a standard location. This is a fast cache of the names of library files found in directories listed in the cache configuration Table of Contentsfile /etc/ld.so.conf. Each line in this file is a directory that you want to include in the cache. list of directories is usually short, containing something like this: How LinuxThe Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 - Devices, Disks, Filesystems, and the Kernel /usr/X11R6/lib Chapter 3 - How Linux Boots /usr/lib/libc5-compat Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6 - Network Services The standard library directories

/lib and /usr/lib are implicit — you don't need to include them in

Chapter 7 - Introduction to Shell Scripts /etc/ld.so.conf. Chapter 8

- Development Tools

If you 9alter ld.so.conf orFrom make a change Chapter - Compiling Software Source Code /etc/ld.so.cache file by hand Chapter 10 - Maintaining the Kernel

to one of the shared library directories, you must rebuild the with the following command:

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing ldconfig -v Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter - Network File Transfer The-v15option provides detailed

information on libraries that ldconfig adds to the cache and any

Chapter 16 -that UseritEnvironments changes detects. Chapter 17 - Buying Hardware for Linux

There18 is -one more place that Chapter Further Directions

ld.so looks for shared libraries: the environment variable this variable, let's look at the runtime library search path.

LD_LIBRARY_PATH. Before discussing Appendix A - Command Classification Bibliography

Linking Programs Against Shared Libraries

Index

List of Figures

Don't get into List of Tables

the habit of adding stuff to /etc/ld.so.conf. You should know what shared libraries are cache, and if you put every bizarre little shared library directory into the cache, you risk conflicts and an extremely disorganized system. W hen you compile software that needs an obscure library path, give your executable a built-in runtime library search path.

in of the system List Sidebars

Let's say that you have a shared library named libweird.so.1 in /opt/bizarresoft/lib that you need to link myprog against. Link the program as follows: cc -o myprog myprog.o -Wl,-rpath=/opt/obscure/lib -L/opt/obscure/lib -lweird The-Wl,-rpath option tells the linker to include a following directory into the executable's runtime library search path. However, even if you use -Wl,-rpath, you still need the -L flag.

Problems with Shared Libraries Shared libraries provide remarkable flexibility, not to mention some really incredible hacks, but it's also possible to abuse them to the point where your system is an utter and complete mess. Three particularly bad things can happen: Missing libraries Terrible performance Mismatched libraries The number one cause of all shared library problems is an environment variable named LD_LIBRARY_PATH. Setting this variable to a colon-delimited set of directory names makes ld.so search the given directories before anything else when looking for a shared library. This is a cheap way to make programs work when you move a library around, if you don't have the program's source code, or if you're just too lazy to recompile the executables. Unfortunately, you get what you pay for. Never set LD_LIBRARY_PATH in shell startup files or when compiling software. When the dynamic runtime linker encounters this variable, it must often search through the entire contents of each specified directory more times than you would care to know. This causes a big performance hit, but more importantly, you can

get conflicts and mismatched libraries because the runtime linker looks in these directories for every program. How Linux Works: What Every Super-User Should Know

If you must use LD_LIBRARY_PATH to run some crummy program for which you don't have the ISBN:1593270356 source (or by Brian Ward an application that you'd rather not compile, like Mozilla or some other beast), use a wrapper script. Let's No Starch Press © 2004 (347 pages) say that yourThis executable is /opt/crummy/bin/crummy.bin and it needs some shared libraries in guide describes the inner workings of a Linux system beginning with the file system and boot process and /opt/crummy/lib. Write atopics wrapper script called crummy that looks like this: covering advanced such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

#!/bin/sh Table of Contents LD_LIBRARY_PATH=/opt/crummy/lib How Linux Works—What Every Super-User Should Know export LD_LIBRARY_PATH Chapter - The Basics exec 1/opt/crummy/bin/crummy.bin

$@

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4 -LD_LIBRARY_PATH Essential System Files, prevents Servers, and Utilities Avoiding most shared

library problems. But one other significant problem developers is that a library's application programming interface (API) may Chapter 6 slightly - Network Services change from one minor version to another, breaking installed software. The best solutions here are Chapter 7 - Introduction Scripts preventive: either usetoaShell system like Encap (see Section 9.4) to install shared libraries with -Wl,-rpath to Chapter Development Tools or simply use the static versions of obscure libraries. create8a -runtime link path, Chapter 5 - Configuring Your up Network that occasionally comes with

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

8.1.5Make

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

A program with more Chapter 13 - Backups

than one source code file or requiring strange compiler options is too cumbersome to been around for years, and the traditional Unix compile management utility that eases these pains is called make. You need to know a little about make if you're running a Unix Chapter 15 - Network File Transfer system, system utilities sometimes rely on make to operate. However, this chapter is only the tip Chapter 16 because - User Environments of the 17 iceberg. The classic Chapter - Buying Hardware forguide Linux for compiled languages and make is The UNIX Programming Environment [Kernighan and Pike]. Chapter 18 - Further Directions compile hand. Files Thiswith problem Chapter 14 by - Sharing Samba has

Appendix A - Command Classification

make is a big system, and there are entire books on the subject (such as Managing Projects with make [Oram]), but it's not very difficult to get an idea of how it works. When you see a file named Makefile or Index makefile, you know that you're dealing with make. (Try running make to see if you can build anything.) Bibliography

List of Figures List of Tables

The basic idea behind make is the target, a goal that you want to achieve. A target can be a file (a .o file, an executable, and so on) or a label. In addition, some targets depend on other targets — for instance, you need a complete set of .o files before you can link your executable. The targets on which another target depends are called dependencies.

List of Sidebars

To build a target, make follows a rule, such as a rule for how to go from a .c source file to a .o object file. make already knows several rules, but you can customize these existing rules and create your own. The following is a very simple Makefile that builds a program called myprog from aux.c and main.c: OBJS=aux.o main.o # object files all: myprog myprog: $(OBJS) $(CC) -o myprog $(OBJS)

The first line of the Makefile is just a macro definition; it sets the OBJS variable to two object filenames. This will be important later. For now, take note of how you define the macro and also how you reference it later ($(OBJS)). The# in the next line denotes a comment. The next item in the Makefile contains its first target, all. The first target is always the default, the target thatmake wants to build when you run make by itself on the command line. The rule for building a target comes after the colon. For all, this Makefile says that you need to satisfy something called myprog. This is the first dependency in the file; all depends on myprog. Note that myprog can be an actual file or the target of another rule. In this case, it is both (it is the rule for all and the target of OBJS).

To build myprog, this Makefile uses the macro $(OBJS) in the dependencies. The macro expands to aux.o and main.o, so myprog depends on these two files (they must be actual files, because there aren't any targets with names What anywhere the Makefile). How those Linux Works: Everyin Super-User Should Know by Brian Ward

ISBN:1593270356

This Makefile that you(347 have two C source files named aux.c and main.c in the same directory. Noassumes Starch Press © 2004 pages) Runningmake on the Makefile yields the following output, showing the commands that make is running: This guide describes the inner workings of a Linux system beginning with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

cc -c -o aux.o aux.c cc -c -o main.o main.c Table cc of -oContents myprog aux.o main.o

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 does - Devices, Disks, Filesystems, the aux.c Kernel So how make know how to goand from

to aux.o? After all, aux.c is not in the Makefile. The How Linux is- that makeBoots follows its built-in rules. It knows to look for a .c file when you want a .o file, and Chapter 4 - Essential System Servers, furthermore, it knows howFiles, to run cc-cand onUtilities that .c file to get to its goal of creating a .o file. Chapter 3 answer Chapter 5

- Configuring Your Network

The final of getting Chapter 6 -step Network Servicesto

myprog is a little tricky, but the idea is clear enough. Once you have the two the C compiler according to the following line (where $(CC) expands

object7files in $(OBJS), youScripts can run Chapter - Introduction to Shell Chapter to the 8compiler - Development name):Tools Chapter 9

- Compiling Software From Source Code

Chapter 10 -$(CC) Maintaining Kernel -o the myprog

$(OBJS)

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Pay special attention

to the whitespace before $(CC). This is a tab. You must put a tab before any real by its own. W atch out for this:

Chapter 14 - Sharing command, and it Files mustwith be Samba on a line Chapter 15 - Network File Transfer Chapter 16 - User Environments

Makefile:7: *** missing separator. Stop.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification

An error like this means that the Makefile is broken. The tab is the separator, and if there is no separator or there's some other interference, you will see this error.

Bibliography Index

List of Figures

Staying up to Date

List of Tables

List of Sidebars One last make

fundamental is that targets should be up to date with their dependencies. If you type make twice in a row for the preceding example, the first command builds myprog, but the second command yields this output: make: Nothing to be done for 'all'. For this second time through, make looked at its rules and noticed that myprog already exists. To be more specific,make did not build myprog again because none of the dependencies had changed since the last time it built myprog. You can experiment with this as follows: 1. Runtouch aux.c. 2. Runmake again. This time, make figures out that aux.c is newer than the aux.o already in the directory, so it must compile aux.o again. 3. myprog depends on aux.o, and now aux.o is newer than the preexisting myprog, so make must create myprog again. This type of chain reaction is very typical.

Command-Line Options You can get a great deal of mileage from make if you know how its command line options work. The most common make option is specifying a single target on the command line. For the preceding Makefile, you can run make aux.o if you want only the aux.o file. You can also define a macro on the command line. Let's say that you want to use a different compiler called my_bad_cc. Try this: make CC=my_bad_cc

Here, make uses your definition of CC instead of its default compiler, cc. Command-line macros come in handy when you're testing out preprocessor definitions and libraries, especially with the CFLAGS and LDFLAGS macros explained How Linux Works:later. What Every Super-User Should Know by Brian Ward

ISBN:1593270356

You don't even need Press a Makefile to pages) run make. If built-in make rules match a target, you can just ask make to No Starch © 2004 (347 try to createThis the guide target. For example, you have source a very simple blah.c, try describes the inner if workings of a the Linux systemto beginning with the program file systemcalled and boot process and make blah.covering The make advanced run tries topicsthe such following as networking, command: firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

cc blah.o -o blah

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1 -of The Basics This use make works Chapter special2 Chapter 3

only for the most elementary C programs; if your program needs a library or - Devices, Disks, Filesystems, and the Kernel include directory, you're probably better off writing a Makefile. - How Linux Boots

Chapter 4 make - Essential System Files, Servers, and Utilities Running without a Makefile is actually most

useful when you aren't dealing with a C program, but or yacc. It can be a real pain to figure out how the compiler or utility Chapter works,6 so- Network why notServices let make try to figure it out for you? Even if make fails to create the target, it will Chapter 7 -still Introduction Scripts probably give youtoaShell pretty good hint as to how you might use the tool. Chapter 5 - Configuring Your Network with something like Fortran, lex,

Chapter 8

- Development Tools

Two more make options stand fromCode the Chapter 9 - Compiling Software Fromout Source Chapter-n 10Prints - Maintaining the Kernel the commands

rest: necessary for a build, but prevents make from actually running any

Chaptercommands 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter-f 13 file - Backups Tells

make to read from file instead of Makefile or makefile

Chapter 14 - Sharing Files with Samba

Standard Macros and Variables

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter for Linuxand make 17 has- Buying many Hardware special macros Chapter 18 -so Further Directions variable, this book uses

variables. It's difficult to tell the difference between a macro and a the term macro to mean something that usually doesn't change after make

Appendix A - Command Classification starts building targets. Bibliography

As you Index

saw earlier, you can set macros at the start of your Makefile. The following list includes the most

common macros: List of Figures List of Tables

C compiler options. When creating object code from a .c file, make passes this as an argument to the compiler.

List of Sidebars CFLAGS

LDFLAGS Like CFLAGS, but for the linker when creating an executable from object code. LDLIBS If you use LDFLAGS but do not want to combine the library name options with the search path, put the library name options in this file. CC The C compiler. The default is cc. CPPFLAGS C preprocessor options. When make runs the C preprocessor in some way, it passes this macro's expansion on as an argument. CXXFLAGS GNU make uses this for C++ compiler flags. Like C++ source code extensions (and nearly everything else associated with C++), this isn't standard and probably won't work with other make variants unless you define your own rule. Amakevariable changes as you build targets. Because you don't ever set variables by hand, the following list includes the $. $@ When inside a rule, this expands to the current target. $* Expands to the basename of the current target. For example, if you're building blah.o, this expands to blah. The most comprehensive list of the make variables on Linux is the make info page. Note Keep in mind that GNU make has many extensions, built-in rules, and features that other variants do not have. This is fine as long as you're running Linux, but if you step off onto a Sun or BSD machine and expect the same stuff to work, you might be in for a surprise.

Conventional Targets Most Makefiles Howcontain Linux Works: several What standard Every Super-User targets thatShould perform Know auxiliary tasks related to compiles. by Brian Ward

ISBN:1593270356

Theclean targetPress is ubiquitous; a make clean usually instructs make to remove all of the object files No Starch © 2004 (347 pages) and executables so that you can a fresh startsystem or pack up thewith software. Here isand anboot example This guide describes the inner make workings of a Linux beginning the file system processrule and for the myprog covering advanced Makefile: topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

clean:

Table of Contents

rm -f $(OBJS) myprog

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

ChapterA2Makefile - Devices, Disks, Filesystems, and the Kernel created with the GNU autoconf

system always has a distclean target to remove part of the original distribution, including the Makefile. You will see more of this Chapterin4Section - Essential System Files, rare Servers, and Utilities 9.2.3. On very occasions, you may find that a developer opts not to remove the Chapterexecutable 5 - Configuring Your Network with this target, preferring something like realclean instead. Chaptereverything 3 - How Linux thatBoots wasn't

Chapter 6

- Network Services

Chapterinstall 7 - Introduction Shell Scripts copiestofiles and compiled

programs to what the Makefile thinks is the proper place on the so you should always run a make -n install first to see what will Chapterhappen 9 - Compiling Source Code withoutSoftware actuallyFrom running any commands. Chaptersystem. 8 - Development This can Tools be dangerous, Chapter 10 - Maintaining the Kernel

developers testPeripheral or check targets ChapterSome 11 - Configuring andprovide Manipulating Devices

to make sure that everything works after you

a build. Chapterperform 12 - Printing Chapter 13 - Backups

creates Chapterdepend 14 - Sharing Files dependencies with Samba

by calling the compiler with a special option (-M) to examine the source code. This is an unusual-looking target because it often changes the Makefile itself. This is no Chapter 15 - Network File Transfer common practice, but if you come across some instructions telling you to use this rule, make Chapterlonger 16 - User Environments youHardware do it. for Linux Chaptersure 17 -that Buying Chapter 18 - Further Directions

all is often the first target in the Makefile; you will often see references to this target instead of an actual executable. Bibliography Appendix A - Command Classification Index

Organizing a Makefile

List of Figures List of Tables

Even though there are many different Makefile styles, there are still some general rules of thumb to which most programmers adhere.

List of Sidebars

In the first part of the Makefile (inside the macro definitions), you should see libraries and includes grouped according to package: X_INCLUDES=-I/usr/X11R6/include X_LIB=-L/usr/X11R6/lib -lX11 -Xt PNG_INCLUDES=-I/usr/local/include PNG_LIB=-L/usr/local/lib -lpng Each type of compiler and linker flag often gets a macro like the following: CFLAGS=$(CFLAGS) $(X_INCLUDES) $(PNG_INCLUDES) LDFLAGS=$(LDFLAGS) $(X_LIB) $(PNG_LIB) Object files are usually grouped according to executables. Let's say that you have a package that creates executables called boring and trite. Each has its own .c source file and requires the code in util.c. You might see something like this: UTIL_OBJS=util.o BORING_OBJS=$(UTIL_OBJS) boring.o TRITE_OBJS=$(UTIL_OBJS) trite.o PROGS=boring trite The rest of the Makefile might look like this:

all: $(PROGS) How Linux Works: What Every Super-User Should Know boring: $(BORING_OBJS) by Brian-o Ward $(CC) $@ $(BORING_OBJS) $(LDFLAGS)

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and trite: $(TRITE_OBJS) covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and $(CC) -o $@ $(TRITE_OBJS) $(LDFLAGS) sharing printers with Samba. Table Contents Youofcould combine

the two executable targets into one rule, but this is usually not good practice because Makefile, delete an executable, or group Chapter 1 - Thedifferently. Basics executables Furthermore, the dependencies would be incorrect — if you had just one rule for Chapter 2 -and Devices, Disks, Filesystems, the Kernel boring trite, trite would and depend on boring.c, and boring would depend on trite.c, and Chapter - How Linux Boots make 3would always try to rebuild both programs whenever you changed one of the two source files. How Works—What Super-User Should Know youLinux would not easilyEvery be able to move a rule to another

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 - If Configuring Networka Note you needYour to define Chapter 7

special rule for an object file, put the rule for the object file just above the the executable. If several executables use the same object file, put the object - rule Introduction Scripts above to allShell of the executable rules.

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 6

- rule Network thatServices builds

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 8.2 Debuggers by Brian Ward

ISBN:1593270356

Nodebugger Starch Press 2004 (347 pages) The standard on© Linux systems is gdb, with DDD as a graphical user frontend. To enable full guide describes you the inner a Linux system beginning with the file system and boot process debugging inThis your programs, mustworkings run theofcompiler with the -g option to write a symbol table and and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and other debugging information into the executable. To start gdb on an executable named program, run this sharing printers with Samba. command: Table of Contents

gdb program How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

You should get a (gdb) prompt. To run Chapter 4 - Essential System Files, Servers, andprogram Utilities

with the command-line arguments options, type this at

the(gdb) prompt: Your Network Chapter 5 - Configuring Chapter 6

- Network Services

Chapter 7 - Introduction to Shell Scripts runoptions Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining If the program works,the it Kernel should

start, run, and exit as normal. However, if there's a problem, gdb stops, throws you back to the (gdb) prompt. Because the Chapter - Printing source12code fragment often gives you a hint about the problem, you often want to print the value of a Chapter 13 - variable Backups that the trouble may be related to (print also works for arrays and C structures): particular Chapter - Configuring and the Manipulating Peripheral Devices prints 11 a stack trace and failed source code, and

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

printvariable

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter - Further Directions If you 18 want to make gdb stop

the program at any point in the original source code, use the breakpoint file is a source code file, and line_num is the line number in that

Appendix - Command Classification feature.A In the following command, Bibliography

file where gdb should stop:

Index

List of Figures

break file:line_num List of Tables List of Sidebars

To tell gdb to continue executing the program, use this command: continue

To clear a breakpoint, type this: clearfile:line_num

This section provides only the briefest introduction to the debugger. gdb comes with a very extensive manual that you can read online, print, or buy as Debugging with GDB [Stallman/Pesch/Shebs]. Note If you're interested in rooting out memory problems and running profiling test, try Valgrind (http://valgrind.kde.org/).

How Linux Works: What Every Super-User Should Know 8.3 Lex and Yacc by Brian Ward

ISBN:1593270356

No Starchlex Press © 2004 (347when pages) compiling programs that read configuration files or commands. You may encounter and yacc This guide describes the inner workings of a Linux system beginning with the file system and boot process and advanced topics such as networking, firewalls, development tools,The device management, shell and Lex is acovering tokenizer that transforms text into numbered tags with labels. Linux version of lexscripts, is sharing printers with Samba. namedflex. You may need a -ll or -lfl linker flag in conjunction with lex. Table of Contents Yacc is a parser

that attempts to read tokens according to a grammar. The GNU parser is bison; to may need the -ly linker flag.

How Linux Every Super-User Should Know get Works—What yacc compatibility, run bison -y. You Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 8.4 Scripting Languages by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) A long time No ago, the average Unix systems manager didn't have to worry much about scripting languages This guide describes theawk. inner Shell workings of a Linux system beginning with7)the file system andan boot process and other than the Bourne shell and scripts (discussed in Chapter continue to be important advanced topics such as networking, firewalls, development tools, device management, shell scripts, and part of Unix,covering but as stated earlier, awk has faded somewhat from the scripting arena. However, many sharing printers with Samba. powerful successors have arrived, and many systems programs have actually switched from C to scripting languages (such as the sensible version of the whois program). Let's look at some scripting basics.

Table of Contents

How Linux Works—What Every Super-User Should Know

The very first thing that you need to know about any scripting language is that the first line of a script looks Basics similar to- aThe Bourne shell script. For example, a Perl script starts out like this:

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

#!/usr/bin/perl - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

In Unix, any executable text file that starts with #! is a script. The pathname following this prefix is the - Introduction to Shell Scripts scripting language interpreter executable. When Unix tries to run an executable file that starts with #!, it Chapter 8 - Development Tools runs the program following the #!, and then sends the script file to the new program's standard input. Chapter 9 - Compiling Software From Source Code Therefore, even this is a script: Chapter 7

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

#!/bin/tail Chapter 12 - Printing+2 This 13 program Chapter - Backups

prints this line...

and this line, Chapter 14 - Sharing Filestoo. with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments

The first of aHardware shell script often Chapter 17 -line Buying for Linux

contains one of the most common basic script problems — an invalid path to the scripting language interpreter. Let's say that you named the previous script myscript. Now, Chapter 18 - Further Directions what if tail were actually in /usr/bin on your system (not /bin)? When you tried to run myscript, Appendix A - Command Classification you would get this error: Bibliography Index

myscript: List of Figures

No such file or directory

List of Tables List of Sidebars

Most Unix error messages aren't confusing, misleading, or otherwise incomplete, but this one certainly qualifies on all three counts. First of all, myscriptdoes exist — you can see it right in front of your eyes with ls. Is there a problem with your filesystem? No. The system really meant to say that it couldn't find /bin/tail, but it just had a small communication breakdown. The worst case occurs when a script is in some system binary directory. You can locate the script with a utility like which or find, and you think that the program is in your path, yet you get that error message. The only real clue you have is the error message: "No such file or directory." If the script were actually missing from your path, the error message would be "command not found." Another script "gotcha" is that you shouldn't expect any more than one argument in the script's first line to work. That is, the +2 in the preceding example may work, but if you add another argument, the system mightdecide to treat the +2and the new argument as one big argument, spaces and all. This can vary from system to system; don't test your patience on something as insignificant as this.

8.4.1Perl The most important third-party Unix scripting language today is Perl — Larry Wall's Practical Extraction and Report Language. This tool has been called the "Swiss Army Chainsaw" of programming tools, and it is capable of an incredible variety of tasks, from networking to database access. It excels at text processing, conversion, and file manipulation. It's hard to describe what Perl code looks like; it's kind of like an imperative-style mix of C, Bourne shell, sed,awk, LISP, and others. It can be a little hairy (using every single special character on your keyboard), but it is as fast and powerful as it is ugly. If you want to be on top of your Unix system, you need to know a little bit of this language. Have a look at Learning Perl [Schwartz] for a tutorial-style introduction; the larger reference is Programming Perl [Wall]. Getting a grasp of Perl is well worth it, not just because you will be able to do remarkable things with text files, but also because many of the concepts (such as associative arrays) carry over to other scripting languages. Nearly all Unix and Linux systems in the world have Perl installed somewhere. Most administrators maintain it as /usr/bin/perl, even if they insist on keeping all other third-party software away from

/usr. There is extensive online documentation in the manual pages; the perl(1) page has an index of the other pages. How Linux Works: What Every Super-User Should Know

If you're having trouble by Brian Wardwith a Perl script, here are some suggestions:

ISBN:1593270356

No Starch Press © 2004 (347 pages)

Look at it to see if you can tell when the script was written. It might require a newer version of Perl This guide describes the inner workings of a Linux system beginning with the file system and boot process and than youcovering have. advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

If it's an old script, you may have to put backslashes in front of the @ characters in strings and comments. Table of Contents How Linux Works—What Every Super-User Should Know

It might require a module that you do not have (in particular, a database module).

Chapter 1

- The Basics

Chapter Devices, Disks, the Kernel When2all- else fails, run Filesystems, perl -w and script to turn Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

on warning mode.

- Configuring Your Network 8.4.2Python

Chapter 5 Chapter 6

- Network Services

Python newer scripting Chapter 7 is- a Introduction to Shell language Scripts

with a fairly strong following, enough to make it the implementation as GNU Mailman. It offers many of the same system features as Perl, but it has a 9powerful interactive and aCode somewhat more organized object model. Chapter - Compiling Softwaremode From Source language packagesTools such Chapter 8 - for Development

Chapter 10 - Maintaining the Kernel

Python's is python, butPeripheral there's no telling Chapter 11 -executable Configuring and Manipulating Devices a Python Chapter 12 - program, Printing

where it is on your system. Therefore, when you get you may have to modify the first line in the script to match your Python installation.

Chapter 13 - Backups

Although it was written for slightly older versions, Python Essential Reference [Beazley] is a good reference with a small tutorial at the beginning to get you started. Chapter 15 - Network File Transfer Chapter 14 - Sharing Files with Samba Chapter 16 - User Environments

8.4.3Other Scripting Languages

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification There are some other scripting

languages that you might encounter:

Bibliography Index

PHP This is a powerful hypertext processing language often found in dynamic Web scripts. Some people use PHP for stand-alone scripts. The PHP Web site is at http://www.php.net/.

List of Figures List of Tables

List of Sidebars

Tcl Tcl (tool command language) is a simple scripting language usually associated with the Tk graphical user interface toolkit and Expect, an automation utility. Although Tcl does not enjoy the wide-spread use that it once did, you should not discount its power. Many veteran developers prefer Tcl, especially for its embedded capabilities. Refer to http://www.tcl.tk/ for more information on Tcl. m4 This is a macro processing language. Ruby Object-oriented fanatics enjoy programming in this language (http://www.ruby-lang.org/ ). Matlab This is a commercial matrix and mathematical programming language and library. There is a very similar open source project called octave. Mathematica, Maple These are more commercial mathematical programming languages with libraries.

8.5 Java How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

No Starch Press © programmers 2004 (347 pages) love Java, Unix systems programmers avoid it, and you may not Although some application describes the inner workings of a Linux beginning theitfile system boot process even need itThis on guide your system. However, you should still system have an idea ofwith how works on and a typical Linuxand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and system. sharing printers with Samba.

There are two kinds of Java compilers: native compilers for producing machine code for your system (like a C compiler), and bytecode compilers for use by a bytecode interpreter (usually called a virtual machine, How Linux Works—What Every Super-User Should Know even though it's more of an abstract machine). You will invariably encounter bytecode on Linux.

Table of Contents Chapter 1

- The Basics

Chapter 2 - files Devices, Filesystems, the runtime Kernel Bytecode endDisks, in .class. Theand Java Chapter - How Linux Boots to run 3Java bytecode. To

environment (JRE) contains all of the programs you need run a bytecode file, use this command:

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

javafile.class

Chapter 8

Development Tools You may- also encounter bytecode files that end in .jar, which are collections of archived .class files. Chapter 9 - Compiling Software From Source Code To run a .jar file, use this syntax instead: Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

java 12 -jar file.jar Chapter - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

Sometimes you need to set the JAVA_HOME environment variable to your Java installation prefix. If you're really unlucky, you may need to use CLASSPATH to include any directories containing classes that your program expects. This is a colon-delimited set of directories like the regular PATH variable for executables. Chapter 17 - Buying Hardware for Linux Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 18 - Further Directions

If you need to compile a .java file into bytecode, you need the Java Development Kit (JDK). You can run thejavac compiler from JDK to create some .class files:

Appendix A - Command Classification Bibliography Index

javac file.java List of Figures List of Tables List of Sidebars

JDK also comes with jar, a program that can create and pick apart .jar files. It works like tar.

How Linux Works: What Super-User Should Know 8.6 Assembly Code andEvery How a Compiler Works by Brian Ward

ISBN:1593270356

Nouse Starch Press © 2004 advanced (347 pages) features, you should have an idea of how the compiler operates. If you want to a compiler's Thissummary: guide describes the inner workings of a Linux system beginning with the file system and boot process and Here is a brief

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

sharing printers Samba.code file and builds an internal representation of the code inside the 1. The compiler readswith a source file. If there's a problem with the source code, the compiler states the error and exits. Table of Contents

2. The compilerEvery analyzes the internal representation How Linux Works—What Super-User Should Know

and generates assembly code for the target

Chapter 1processor. - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

3. Anassembler converts the assembly code into an object file.

Chapter 4

- Essential System Files, Servers, and Utilities 4. The linker gathers object files and libraries into an executable.

Chapter 5

- Configuring Your Network

Chapter 6 - be Network Servicesinterested You may specifically

in steps 2 and 3 of this process. Assembly code is one step away from processor runs; it is a textual representation of the processor Chapter 8 - Development Tools instructions. Here is an excerpt of a program in x86 assembly code: Chapter 7 binary - Introduction to Shell the raw machine codeScripts that the Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

.L5:

Chapter 11 - Configuring and Manipulating Peripheral Devices

movl -8(%ebp),%eax imull -16(%ebp),%eax - Backups movl -4(%ebp),%edx - Sharing Files with Samba addl %eax,%edx - Network File Transfer movl %edx,-12(%ebp) - User Environments incl -16(%ebp) - Buying Hardware for Linux jmp .L3 - Further Directions .p2align 4,,7

Chapter 12 - Printing Chapter 13 Chapter 14 Chapter 15 Chapter 16 Chapter 17 Chapter 18

Appendix A - Command Classification Bibliography Index List of Figures

Each line of assembly code usually represents a single instruction. To manually generate assembly code file, use the compiler's -S option:

List of Tables from a C source List of Sidebars

cc -S -o prog.Sprog.c

Here, prog.c is the C source file and prog.S is the assembly code output. You can turn an assembly code file into an object file with the assembler, as: as -o prog.oprog.S

For more information about x86 assembly code, see The Art of Assembly Language [Hyde]. RISC assembly code is a little more comprehensible; see MIPS RISC Architecture [Kane]. If you are interested in how to design and implement a compiler, two good books are Compilers: Principles, Techniques, and Tools [Aho 1986] and Modern Compiler Implementation in ML [Appel].

How Linux Works: What Every Super-User Should Know Chapter 9: Compiling Software From Source Code by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Most nonproprietary third-party Unix software packages come as source code that the administrator can compile and install. One reason for this tradition is that Unix has so many different flavors and Table of Contents architectures that it would be difficult to distribute binaries for all possible platform combinations. How Linux Works—What Every Super-User Should Know Widespread source code distribution throughout the Unix community encouraged users to contribute bug Chapter 1 - The Basics fixes and new features to the software, and eventually this gave rise to the term "open source." Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

How Linux Boots You can -get everything you see on a Linux system comes as source code — this means everything from - Essential System Files, Servers, and Utilities the kernel and C library to the Web browsers. This means it is possible to update and augment your entire Chapter 5 - Configuring Your Network system by (re-)installing parts of your system from the source code. However, you probably shouldn't Chapter 6 - Network Services update your machine by installing everything from source code unless you really enjoy the process. Linux Chapter 7 - Introduction to Shell means Scripts to update core parts of the system (such as the programs in /bin). distributions provide easier Chapter 4

Chapter 8

- Development Tools

Chapter - Compiling Software From Code Don't 9expect your distribution to Source provide everything

for you. When you install binary packages from a over configuration options, including where the software goes. Some Chapter 11 - Configuring and Manipulating Peripheral Devices packages are not available as binaries, and furthermore, binary packages will not necessarily match the Chapter - Printingon your system (see Section 8.1.4). shared12libraries Chapter 10 - Maintaining distribution, you havethenoKernel control

Chapter 13 - Backups

You should understand everything Chapter 14 - Sharing Files with Samba from source code File usually involves Chapter 15 - Network Transfer

in Chapter 8 before proceeding with this chapter. Installing a package the following steps:

Chapter 16 - User Environments

1. Unpacking the source code archive.

Chapter 17 - Buying Hardware for Linux Chapter - Further Directions 2. 18Configuring the package. Appendix A - Command Classification

3. Runningmake Bibliography Index

Runningmake List of4. Figures List of Tables List of Sidebars

to build the programs. install to install the package.

How Linux Source Works: WhatPackages Every Super-User Should Know 9.1 Unpacking by Brian Ward

ISBN:1593270356

Starchcode Press distribution © 2004 (347 pages) A package'sNo source usually comes as a .tar.gz or .tar.bz2 file, and you should Thisas guide describesin the inner workings unpack the file described Section 1.18. of a Linux system beginning with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Before you unpack, though, verify the contents of the archive with tar tvf, because some packages don't create their own subdirectories in the directory where you extract the archive. Output like the Table of Contents following means that the package is probably okay to unpack: How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

package-1.23/Makefile.in - Devices, Disks, Filesystems, and the Kernel package-1.23/README Chapter 3 - How Linux Boots package-1.23/main.c Chapter 4 - Essential System Files, Servers, and Utilities package-1.23/bar.c Chapter 5 - Configuring Your Network ... Chapter 6 - Network Services Chapter 2

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

However, you might see that not all of the files are in a common directory (like package-1.23 in the - Compiling Software From Source Code preceding example):

Chapter 9

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Makefile Chapter 12 - Printing README Chapter 13 - Backups main.c Chapter 14 - Sharing Files with Samba ... 15 - Network File Transfer Chapter Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

Extracting an archive like Chapter 18 - Further Directions

this one can leave a big mess in your current directory. To avoid this, create a new directory and cd there before extracting the contents of the archive. Appendix A - Command Classification Bibliography

Watch out for a test listing with absolute pathnames like this:

Index

List of Figures

/etc/passwd List of Tables /etc/inetd.conf List of Sidebars

You likely won't come across anything like this, but if you do, remove the archive from your system, because it probably contains a Trojan horse or some other malicious code.

9.1.1Where to Start After you extract the contents of a source archive and have a bunch of files in front of you, try to get a feel for the package. In particular, look for these files: README and INSTALL. Always look at any README files first. They often contain a description of the package, a small manual, installation hints, and other useful information. Many packages also come with INSTALL files that contain instructions on how to compile and install the package. Check for special compiler options and definitions. Apart from the README and INSTALL files, you will find other package files that fall into roughly three categories: Files relating to the make system, such as Makefile,Makefile.in, and configure. Some packages come with a Makefile that you may need to modify. However, most modern packages use GNU autoconf and come with a configure script to generate a Makefile from Makefile.in based on your system settings and configuration options. Source code files ending in .c,.h, or .cc. C source code files may appear just about anywhere in a package directory. C++ source code files usually have .cc,.C, or .cxx suffixes. Object files ending in .o or binaries. Normally there aren't any object files in source code distributions. However, you may find object files in rare cases when the package maintainer is not allowed to release certain source code, and you may need to do something special to use the object files. In most cases, object (or binary executable) files in a source distribution mean that the package wasn't put together too well, and you should run make clean to make sure that you get a fresh compile.

Linux Works: What Every Super-User Should Know 9.2 GNUHow Autoconf by Brian Ward

ISBN:1593270356

Press © 2004 (347 pages) Even thoughNoCStarch source code is usually fairly portable, there are still differences on each platform that make guide describes inner workings a Linux system beginning with the file to system and boot process it impossibleThis to compile most the packages with aofsingle Makefile. An early solution this problem was toand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and provide individual Makefiles for every operating system, or to provide a Makefile that was easy to modify. sharing printers with Samba. This approach somehow evolved into scripts that generate Makefiles based on an analysis of the system used to build the package.

Table of Contents

How Linux Works—What Every Super-User Should Know

GNU autoconf is now the most popular system for automatic file generation. Packages using this system configure,Makefile.in, and config.h.in. To generate a Makefile, run Chapter 2 - Devices, Disks, Filesystems, Kernel configure to check your system and for the prerequisites: Chapter - The Basics come 1with files named Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

./configure - Configuring Your Network

Chapter 5 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

You should get a lot of diagnostic output like this:

checking build system Chapter 10 - Maintaining the Kernel

type... i586-pc-linux-gnu checking host system type... i586-pc-linux-gnu Chapter 11 - Configuring and Manipulating Peripheral Devices checking for a BSD-compatible install... /bin/install -c Chapter 12 - Printing checking whether build environment is sane... yes Chapter 13 - Backups ... 14 - Sharing Files with Samba Chapter ... 15 - Network File Transfer Chapter Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

configure creates a cache file (config.cache) so that it does not need to run certain tests more than once. In addition, configure consults config.cache on subsequent runs (this may come up if your system requires special options).

Note Appendix A - Command Classification Bibliography Index

List of Figures

If all goes well, configure creates one or more Makefiles and config.h:

List of Tables

List of Sidebars

configure: creating ./config.status config.status: creating Makefile ... ... config.status: creating config.h

Note If you're looking for a package to test, get the coreutils package from the GNU FTP site (ftp://ftp.gnu.org/pub/gnu/coreutils/ ). Coreutils includes common system programs like ls and cat. Now you can type make to compile the package. A successful configure step doesn't necessarily mean that the make step will work, but the chances are pretty good (see Section 9.6 for troubleshooting failed configures and compiles). After the build completes, you might want to try running a program from the package, just to see if it works. To install the program, run this command: make install

9.2.1configure Script Options Theconfigure script that comes with autoconf-enabled packages has several useful options. The most important of these is the installation directory. By default, the install target uses a prefix of /usr/local — that is, binary programs go in /usr/local/bin, libraries go in /usr/local/lib, and so on. If you want to use a prefix other than /usr/local, run configure with this option:

./configure --prefix=new_prefix How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

For example, you specify --prefix=/tmp/test, a make install puts binaries in /tmp/test/bin, NoifStarch Press © 2004 (347 pages) libraries in /tmp/test/lib, and so on. This guide describes the inner workings of a Linux system beginning with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

Most versions of configure sharing printers with have Samba.a --help option that lists other configuration options. Unfortunately, the list is usually so long that it's sometimes hard to figure out what might be important. Here are some other Table of options: Contents How Linux Works—What Every Super-User Should Know --bindir=directory Installs executables in directory. Chapter 1

- The Basics

Chapter--sbindir=directory 2 - Devices, Disks, Filesystems, Installs and the system Kernelexecutables Chapter 3

in Chapter--libdir=directory 4 - Essential System Files, Installs Servers, libraries and Utilities Chapter 5

in directory.

- How Linux Boots

directory.

- Configuring Your Network

Prevents the package from building shared libraries. Depending on the library, this can save hassles later on (see Section 9.4.1). Chapter 7 - Introduction to Shell Scripts Chapter--disable-shared 6 - Network Services Chapter 8

- Development Tools

--with-package=directory Tells configure that package is in directory. This is handy - Compiling Software From Source Code when a necessary library is in a nonstandard location. Unfortunately not all configure scripts Chapter 10 - Maintaining the Kernel recognize this type of option, and furthermore, Chapter 11 - Configuring and Manipulating Peripheral Devices it can be difficult to determine the exact syntax. Chapter 9

Chapter 12 - Printing

You can create separate build directories if you want to experiment with some of these options. To do this, create a new directory anywhere on the system, and from that directory, run the configure script in the Chapter 14 - Sharing Files with Samba original package source code directory. You will find that configure then makes a symbolic link farm in Chapter 15 - Network File Transfer your new build directory, where all of the links point back to the source tree in the original package Chapter 16 - User Environments directory. Some developers actually prefer that you build packages this way. Chapter 13 - Backups

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

9.2.2Environment Variables

Appendix A - Command Classification Bibliography Index You

can influence configure with environment variables that the configure script puts into make most important variables are CPPFLAGS,CFLAGS, and LDFLAGS. Be aware that List of Tables configure can be very picky about environment variables. For example, you should always use List of Sidebarsinstead of CFLAGS for header file directories, because configure often runs the preprocessor CPPFLAGS independently of the compiler. List of FiguresThe variables.

In bash, the easiest way to send an environment variable to configure is by placing the variable assignment in front of ./configure on the command line. For example, to define a DEBUG macro for the preprocessor, use this command: CPPFLAGS=-DDEBUG ./configure Environment variables are especially handy when configure doesn't know where to look for third-party include files and libraries. For example, to make the preprocessor search in include_dir, run this command: CPPFLAGS=-Iinclude_dir ./configure

As shown in Section 8.1.5, to make the linker look in lib_dir, use this command: LDFLAGS=-Llib_dir ./configure If lib_dir has shared libraries (see Section 8.1.4), the previous command probably won't set the runtime dynamic linker path. In that case, use the -rpath linker option in addition to -L : LDFLAGS="-Llib_dir -Wl,-rpath=lib_dir" ./configure Be careful when setting variables. A small slip can trip up the compiler and cause configure to fail. Let's say that you forget the - in -I, as in this example:

CPPFLAGS=Iinclude_dir ./configure How Linux Works: What Every Super-User Should Know by error Brian Ward This yields an like this:

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

checking covering for C advanced compiler output... configure: error: compilershell scripts, and topicsdefault such as networking, firewalls, development tools, deviceCmanagement, sharing printers with Samba. cannot create executables See `config.log' for more details. Table of Contents How Linux Works—What Every Super-User Should Know

Digging through config.log yields this: - The Basics

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

configure:2161: checking Chapter 3 - How Linux Boots

for C compiler default output >&5 Chapter - Configuring Your Network gcc: 5Iinclude_dir: No such file or directory configure:2164: gccFiles,Iinclude_dir Chapter 4 - Essential System Servers, and Utilitiesconftest.c Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

9.2.3Autoconf Targets - Compiling Software From Source Code

Chapter 9

Chapter 10 - Maintaining the Kernel

In addition to the standard all and Peripheral install, an autoconf-generated Chapter 11 - Configuring and Manipulating Devices

Makefile has these targets:

Chapter 12 - Printing

clean Chaptermake 13 - Backups

As described in Section 8.1.5,make clean removes all object files, executables, and

Chapterlibraries. 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments

make distclean This is similar to make clean, but it removes all automatically generated files, including Makefiles, config.h,config.log, and so on. The idea is that the source tree should look Chapter 18 - Further Directions like a newly unpacked distribution after running make distclean. Chapter 17 - Buying Hardware for Linux Appendix A - Command Classification Bibliography Index

make check Some packages come with a battery of tests to verify that the compiled programs work the command make check runs the tests.

List of Figures properly; List of Tables List of Sidebars

make install-strip This is like make install, but it strips the symbol table and other debugging information from executables and libraries when installing. Stripped binaries require much less space.

9.2.4Autoconf Log Files If something goes wrong during the configure process and the cause isn't obvious, you can examine config.log to find the problem. Unfortunately, config.log is often a gigantic file, making it difficult to locate the exact source of the problem. The best approach is to go to the very end of config.log (for example, by pressing G in less), and then page back up until you see the problem. However, there is still a lot of stuff at the end, because configure dumps its entire environment there, including output variables, cache variables, and other definitions. You can also try running a search for the error message, starting from the end of the file. For example, let's say that configure fails, terminating with this message: See 'config.log' for more details.

Search backward for the string "for more details" (or "config.log," or anything that looks reasonably unique); it's a pretty good bet that the error is nearby.

Linux Works: What Every Super-User Should Know 9.3 OtherHow Systems by Brian Ward

ISBN:1593270356

Starch 2004 (347 pages) for platform-specific configuration, you should expect that the If a packageNo does notPress use©GNU autoconf This guide the inner workings of a Linux system beginning with the file system and boot process and package uses one of describes these three systems:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

A customizable Makefile and/or config.h. At one time, administrators had to configure nearly all third-party Unix software by editing Makefiles. GNU autoconf has made this practice nearly extinct, Table of Contents but you still may come across custom configuration in older packages or very Linux-specific How Linux Works—What Every Super-User Should Know packages. Chapter 1

- The Basics

ChapterImakefiles. 2 - Devices, Disks,XFilesystems, and the Kernel Many W indow System applications Chapter 3

use imake to create Makefiles from Imakefiles.

- How Linux Boots

Chapter"Anybody's 4 - Essential SystemSome Files, Servers, and Utilities guess." developers just have Chapter 5

- Configuring Your Network

Chapter 8

- Development Tools

to be different.

In addition, many Services packages, Chapter 6 - Network

including those using the three types listed above, now rely on the pkgconfig program for compiler and linker options. You will see how these work in Section 9.3.3. Chapter 7 - Introduction to Shell Scripts Chapter 9

- Compiling Software From Source Code 9.3.1Custom Makefiles

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

When you need to customize a Makefile, make a copy of the original Makefile (to Makefile.dist, for example) before changing anything. This ensures that you can always refer to a pristine original when you Chapter 13 - Backups delete or alter a line that you shouldn't have touched. Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba

Chapter 15 -custom Network Makefile File Transfer A typical might

look like this:

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

# CC=gcc CFLAGS=-g Appendix A - Command Classification # use -O to enable optimizer Bibliography # CFLAGS=-O Chapter 18 - Further Directions

Index

List of Figures

DESTDIR=/usr/local BINDIR=$(DESTDIR)/bin List of Sidebars MANDIR=$(DESTDIR)/man/man1 List of Tables

# # # # # #

To enable X11 support, use -DHAS_X11 X11FLAGS=-DHAS_X11 XINC=-I/usr/X11R6/include XLIB=-L/usr/X11R6/lib -lX11 -lXt Don't edit below this line

As you learned in Chapter 8,# is a comment in a Makefile. Custom Makefiles often include macros that are commented out; and uncommenting those macros allows you to override defaults and add extra features. TheXINC and XLIB macros in the preceding example illustrate use of a third-party library. Macros like DESTDIR are analogous to the --prefix parameter in the GNU autoconf system. Don't expect all Makefiles to have such a mechanism, though. Finally, some particularly old configuration files ask you to specify whether your system is a BSD-like or SVR4 (System V Release 4) system. At one time, most Unix flavors were derived from one or the other. Linux leans more toward SVR4, but depending on the nature of the package, there are many BSD-isms on Linux that you might need to take into account.

9.3.2Imake Many X Window System applications use imake to create Makefiles from Imakefiles. The Imake system attempts to produce valid Makefiles from Imakefile template files with the help of predefined default values for the C compiler, options, and so on. The imake program uses the C preprocessor for its dirty work. Imake is standard on any platform that has an X Window System installation (usually located in /usr/X11R6). Imake's ubiquity is its only advantage. The system's disadvantages are that it's not very

flexible (it usually requires installing packages with a /usr/X11R6 prefix) and it's not very smart (it doesn't dig around in your system and verify that things actually work as advertised). How Linux Works: What Every Super-User Should Know

To build andbyinstall a package that comes with an Imakefile, do the following: ISBN:1593270356 Brian Ward No Starch © 2004 pages) 1. Runxmkmf or Press xmkmf -a(347 (use -a if there are subdirectories) to create the valid Makefile. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced the topics such as networking, firewalls, development tools, device management, shell scripts, and 2. Runmake to compile package. sharing printers with Samba.

3. Runmake install to install the executables and libraries. Table of Contents

4. Run make install.man toShould installKnow the manual How Linux Works—What Every Super-User Chapter 1

pages.

- The Basics

X Resource Files - Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

Many 4packages that haveFiles, Imakefiles use application Chapter - Essential System Servers, also and Utilities configuration data. AYour program window missing Chapter 5 - Configuring Network Chapter 6

default ("app-defaults") files to store default an app-defaults file may look "plain" or extremely bad.

- Network Services

App-defaults files are usually in /usr/X11R6/lib/X11/app-defaults. Some packages give you an - Introduction to Shell Scripts option for installing their app-defaults file in a place other than the default. Unfortunately, most do not, and Chapter 8 - Development Tools you might have to resort to this ugly trick in order to install the package in a nonstandard location: Chapter 9 - Compiling Software From Source Code 1. 10Identify the programs Chapter - Maintaining the Kernelto be installed with make -n install. Chapter 7

Chapter 11 - Configuring and Manipulating Peripheral Devices

2. 12Identify the Chapter - Printing

app-defaults file (it usually ends with .ad). Your make -ninstall from the previous tell you the name of the installed file, though in the make -n install output the appdefaults filename does not have the .ad extension. Chapter 14 - Sharing Files withnormally Samba step should Chapter 13 - Backups

Chapter 15 - Network File Transfer

3. Install the program by hand.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

4. Install the app-defaults file without a .ad extension.

Chapter 18 - Further Directions

Appendix A - Command 5. Rename theClassification program with

a .bin extension.

Bibliography Index 6.

Write a wrapper script like the following and name it program without the .bin extension is where you installed the app-defaults file, and List of Tables prog_path/program.bin is the binary program): List of Figures (app_defaults_path List of Sidebars

#!/bin/sh XUSERFILESEARCHPATH=app_defaults_path/%N%S:$XUSERFILESEARCHPATH export XUSERFILESEARCHPATH exec prog_path/program.bin

9.3.3pkg-config The number of third-party libraries has risen dramatically in recent years. Because keeping all add-on libraries in a common location can be messy, you may wish to install each with a separate prefix. However, doing so can lead to problems when building packages that require these third-party libraries. For example, if you want to compile OpenSSH, you need the OpenSSL library. How do you tell the OpenSSH configuration process the nonstandard location of the OpenSSL header files and libraries? Many libraries now use the pkg-config program not only to advertise the locations of their include files and libraries, but also to specify the exact flags that you need to compile and link a program. The syntax is as follows: pkg-config options package1 package2 ...

For example, to find the include files for OpenSSL, you can run this command: pkg-config --cflags openssl The output should be something like this: -I/opt/openssl/include

If you want the linker flags, use --ldflags instead. This should yield a library location and the names of How Linux Works: What Every Super-User Should Know the individual libraries, as in this example for OpenSSL: ISBN:1593270356 by Brian Ward No Starch Press © 2004 (347 pages)

-L/opt/openssl/lib -lssl -lcrypto -ldl This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

To see all libraries that pkg-config knows about, run this command: Table of Contents How Linux Works—What Every Super-User Should Know pkg-config --list-all Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter - How Linuxthe Boots If you 3look behind scenes,

you will find that pkg-config finds package information by reading here is openssl.pc, from the OpenSSL socket library:

Chapter 4 - Essential Files, Servers, and Utilities configuration files System that end with .pc. For example, Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

prefix=/opt/openssl - Introduction to Shell Scripts exec_prefix=${prefix} Chapter 8 - Development Tools libdir=${exec_prefix}/lib Chapter 9 - Compiling Software From Source Code includedir=${prefix}/include Chapter 7

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Name: OpenSSL Description: Secure Sockets Layer and cryptography libraries and tools Chapter 13 - Backups Version: 0.9.7b Chapter 14 - Sharing Files with Samba Requires: Chapter 15 - Network File Transfer Libs: -L${libdir} -lssl -lcrypto -ldl Chapter 16 - User Environments Cflags: -I${includedir} Chapter 12 - Printing

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A -change Command Classification You can this file if you

like — for example, you may wish to add -Wl,-rpath=${libdir} to the to set a runtime dynamic linker path. However, the bigger question is how pkg-config finds Index the.pc files in the first place. What happens is that pkg-config looks in the lib/pkgconfig directory List of of itsFigures installation prefix. A pkg-config installed with a /usr/local prefix looks in List of Tables /usr/local/lib/pkgconfig. Bibliography library flags

List of Sidebars

Unfortunately,pkg-config does not read any .pc files outside of its installation prefix by default. The previous OpenSSL example .pc file would reside at /opt/openssl/lib/pkgconfig/openssl.pc, almost certainly out of the reach of any stock pkg-config installation. There are two basic ways to show pkg-config the .pc files that are located outside of the pkg-config installation prefix: Make symbolic links (or copies) from the actual .pc files to the central pkgconfig directory. Set your PKG_CONFIG_PATH environment variable to include any extra pkgconfig directories. This strategy does not work well on a system-wide basis.

How Linux Works: What Every Super-User Should Know 9.4 Installation Practice by Brian Ward

ISBN:1593270356

2004 (347 pages) is good, but knowing when and where to install your own KnowinghowNotoStarch build Press and ©install software describes inner workings of a Linux system the filesoftware system and processon and packages is This whatguide proves to bethe useful. Linux distributions try tobeginning cram inwith as much asboot possible covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and installation. You should always ask yourself if you should install a package by yourself instead. sharing printers with Samba.

Here are the advantages of doing it yourself:

Table of Contents

How Linux Everypackage Super-User Should Know YouWorks—What can customize defaults. Chapter 1

- The Basics

software survives operating ChapterCustom 2 - Devices, Disks,usually Filesystems, and the Kernel Chapter 3

installing a package, you often get a ChapterWhen 4 - Essential System Files, Servers, and Utilities Chapter 5

system upgrades.

- How Linux Boots

much clearer picture of how to use the package.

- Configuring Your Network

You -always get the latest releases. Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

It's easier to back up a custom package.

ChapterIt's 9 easier - Compiling Software self-installed From Source Code to distribute packages

across a network.

Chapter 10 - Maintaining the Kernel Chapter - Configuring and Manipulating Peripheral Devices These11are the disadvantages: Chapter 12 - Printing

takes time. ChapterIt 13 - Backups Chapter 14 - Sharing Files with Samba

you don't actually use ChapterIf 15 - Network File Transfer

the package, you're wasting your time.

Chapter 16 - User Environments

There is a potential for misconfiguring packages.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Consider the C library and the coreutils package (ls,cat, and so on) — there really is no point in building these by yourself unless you have some real obsession with the build process. On the other hand, if you Bibliography have a vital interest in network servers such as Apache, the best way to get complete control is to install Index the servers yourself. Appendix A - Command Classification

List of Figures List of Tables

9.4.1Where to Install

List of Sidebars

The default prefix in GNU autoconf and many other packages is /usr/local, the traditional directory for locally installed software. Operating system upgrades ignore /usr/local, so you won't lose anything installed there during an operating system upgrade. For small local software installations, /usr/local is fine. However, if you have a lot of custom software installed, this can turn into a terrible mess. Thousands of odd little files can make their way into the /usr/local hierarchy, and you may have no idea where the files came from. There are several schemes that help manage software packages. I like the Encap system (http://www.encap.org/ ) because it requires no extra software.

Encap Encap abuses symbolic links, but that's a small price to pay for the features you get: You can identify everything in /usr/local by package name. You can keep old versions of a software package intact, so you can always downgrade, run the old version, and or use the old version as a model. It is easy to remove old versions and entire packages. You can easily transport packages to another partition or another machine. Encap requires very little extra configuration. The main idea behind Encap is that you encapsulate a package installation before making it available in /usr/local. To start, you must have a common installation root (most administrators use /usr/local/encap or /opt; this book uses /opt because it's shorter). Let's say that you are installing bogon-3.2.3. Here's what you would do with Encap: 1. Configure, build, and install the package with an installation prefix that reflects the package and

1. version. For example, the package uses GNU autoconf, so run this command: How Linux Works: What Every Super-User Should Know ./configure --prefix=/opt/bogon/bogon-3.2.3 by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

2. Go toThis /opt/bogon guide describes and themake inner workings a symbolic of a link Linux tosystem the install beginning you with just the made file system from default: and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

cd /opt/bogon ln -s /opt/bogon/bogon-3.2.3 default Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

3. If there are binary programs in /opt/bogon/default/bin, run this command:

-s /opt/bogon/default/bin/* Chapter 4ln - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

/usr/local/bin

4. If -there are binary programs in /opt/bogon/default/sbin, run this command: Introduction to Shell Scripts

Chapter 7 Chapter 8

- Development Tools

Chapter 9ln - Compiling -s /opt/bogon/default/sbin/* Software From Source Code

/usr/local/sbin

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

5. 12Run the appropriate Chapter - Printing pages (the Chapter 13 - Backups

variant of the following command for each section in which there are manual example works for man section 1):

Chapter 14 - Sharing Files with Samba Chapter 15 File Transfer ln- Network -s /opt/bogon/default/man/man1/*

/usr/local/man/man1

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter Now the 18 -bogon Furtherpackage Directions binaries Appendix A - Command Classification Furthermore, you can now do the

and manual pages are available in /usr/local via symbolic links. following:

Bibliography Index

If you ever need to know the originating package of an item in /usr/local/bin, you need only run on the link to see where it points.

ls -l List of Figures List of Tables

To remove a package, you can remove the symbolic links and its directory in /opt. For example, to remove the bogon symbolic links in /usr/local/bin, run this:

List of Sidebars

cd /opt/bogon/default/bin for file in *; do rm -f /usr/local/bin/$file done

Should You Compile Shared Libraries? Shared libraries (see Section 8.1.4) cause trouble with custom installations, primarily because a shared library upgrade can break a large number of programs at once. For this reason, you should never make links to shared libraries in /usr/local/lib when using Encap. Leave shared libraries in their installed location. Even with this precaution, you still have these problems: It's hard to tell if you can actually delete an old shared library, because some program may depend on the library. It's difficult to link programs against the shared library. You must use the -Wl,-rpath=path linker option. When linking against a shared library, you should specify a path that includes a version number. For example, use /opt/bogon/bogon-3.2.3/lib instead of /opt/bogon/default. You risk library version mismatches otherwise. In fact, shared libraries can cause so many problems that you should always think twice before installing them. If the library is fairly small (such as libpng and libtiff), there's no problem in opting for static libraries over shared libraries. Use this configure option to disable shared libraries for packages that use GNU autoconf:

./configure --disable-shared How Linux Works: What Every Super-User Should Know

Encap, pkg-config, by Brian Ward and Shared Libraries

ISBN:1593270356

No Starch Press © 2004 (347 pages)

You can't getThis away with staticthe libraries for everything. libraries assystem GNOME components guide describes inner workings of a LinuxEnormous system beginning withsuch the file and boot process and demand shared libraries. In the worst you need to slug it out withtools, LDFLAGS Makefile and covering advanced topics such cases, as networking, firewalls, development device management, shell scripts, and printers with Samba. environmentsharing variables. Happily, many larger libraries also use pkg-config, described in Section 9.3.3. Youofcan make Table Contents

Encap work with pkg-config if you put in a little extra effort. To set it up, you need to searches for .pc files. Let's say that you're trying to install 1the- The shared libraries from bogon-3.2.3 with Encap: Chapter Basics know which lib/pkgconfig directory pkg-config How Linux Works—What Every Super-User Should Know Chapter - Devices, Disks, Filesystems, and the 1. 2Configure, compile, and install theKernel package Chapter 3

as usual.

- How Linux Boots

Chapter - Essential System Files, Servers, and Utilities 2. 4Carry out the Encap steps discussed earlier.

In particular, you need the default symbolic link to

Chapter 5point - Configuring Your Network to bogon-3.2.3. Chapter 6

- Network Services

3. 7Go to /opt/bogon/default/lib/pkgconfig. Chapter - Introduction to Shell Scripts Chapter 8

You should see a file named bogon.pc.

- Development Tools

4. 9Edit bogon.pc. LookFrom for this line: Chapter - Compiling Software Source Code Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Libs: -L${libdir} -lbogon Chapter 12 - Printing Chapter 13 - Backups

Change that line toSamba reflect Chapter 14 - Sharing Files with

a runtime link path:

Chapter 15 - Network File Transfer Chapter 16 - User Environments Libs: -Wl,-rpath=${libdir}

-L${libdir} -lbogon

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classificationabout 5. Now tell pkg-config Bibliography example,pcpath

the package. If pcpath is where pkg-config keeps its .pc files (for could be /usr/local/lib/pkgconfig), create a symbolic link:

Index List of Figures

ln -s /opt/bogon/default/lib/pkgconfig pcpath

List of Tables

List of Sidebars

6. Testpkg-config on bogon: pkg-config --libs bogon

The output should include -Wl,-rpath.

How Linux Works: What Every Super-User Should Know 9.5 Applying a Patch by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 Every now and then, Press you might getpages) a patch that you need to apply against source code to fix bugs or add This guide describes theterm innerdiff workings system for beginning the filethe system andprogram boot process and features. You may also see the used of asaaLinux synonym patch,with because diff covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and produces thesharing patch.printers with Samba.

The beginning of a patch looks something like this:

Table of Contents

How Linux Works—What Every Super-User Should Know

--- src/file.c.orig 2003-07-17 14:29:12.000000000 +0100 - The Basics +++ src/file.c 2003-09-18 10:22:17.000000000 +0100 Chapter 2 - Devices, Disks, Filesystems, and the Kernel @@ -2,16 +2,12 @@ Chapter 3 - How Linux Boots Chapter 1

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Patches usually contain alterations to more than one file. Search the patch for three dashes in a row (---) - Network Services if you want to see the files that have alterations.

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools You should always look at the beginning of a patch to determine the required working directory. Notice that Chapter 9 - Compiling Software From Code the preceding example refers to Source src/file.c. Therefore, you should change to the directory that contains Chapter 10 Maintaining the Kernel src before applying the patch, not to the src directory itself. Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 -the Printing To apply patch,

run the patch command:

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

patch -p0 < patch_file

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

If everything goes well, patch exits without a fuss, leaving you with an updated set of files. However, watch out if patch asks you this question:

Chapter 18 - Further Directions

Appendix A - Command Classification Bibliography

File Index

to patch:

List of Figures List of Tables

This usually means that you are not in the correct directory. However, it could also indicate that your source code does not match the source code in the patch. In this case, you're probably out of luck — even if you could identify some of the files to patch, others would not be properly updated, leaving you with source code that you cannot compile.

List of Sidebars

In rare cases, you might come across a patch that refers to a package version like this: --- package-3.42/src/file.c.orig 2003-07-17 14:29:12.000000000 +0100 +++ package-3.42/src/file.c 2003-09-18 10:22:17.000000000 +0100

If you have a slightly different version number (or you just renamed the directory), you can tell patch to strip leading path components. Let's say that you were in the directory that contains src (as before). To makepatch ignore the package-3.42/ part of the path (that is, to strip one leading path component), use -p1: patch -p1 < patch_file

How Linux Works: What Every Super-User Know 9.6 Troubleshooting Compiles andShould Installations by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 pages) If you understand thePress difference between compiler errors, compiler warnings, linker errors, and shared This guide describes the inner workings of ayou Linux systemnot beginning withmuch the filetrouble system fixing and boot process library problems as described in Chapter 8, then should have too many of and the covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and glitches thatsharing arise when building software. This section covers some other common problems. printers with Samba.

Before getting into specifics, you should learn to read make output. You first need to know the difference between an error and an ignored error. The following is a real error that you need to investigate:

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

make: *** [target] Error 1 - Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

However,- Network some Makefiles suspect that an error condition may occur but know that these errors are Services harmless. You can usually disregard any messages like this: Chapter 7 - Introduction to Shell Scripts Chapter 6 Chapter 8

make:9 Chapter

- Development Tools

*** [target] 1 (ignored) - Compiling SoftwareError From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

Furthermore, GNU Chapter 12 - Printing

make often calls itself many times in large packages, with each instance of make in the with [N], where N is a number. You can often find the error quickly by looking at themake thatFiles comes directly after the compiler error message. Here is an example: Chapter 14 -error Sharing with Samba error message marked Chapter 13 - Backups

Chapter 15 - Network File Transfer Chapter 16 - Usererror Environments [compiler message

involving file.c] 1 Chapter 18 - Further Directions make[3]: Leaving directory '/home/src/package-5.0/src' Appendix A - Command Classification make[2]: *** [all] Error 2 Bibliography make[2]: Leaving directory '/home/src/package-5.0/src' Index make[1]: *** [all-recursive] Error 1 List of Figures Leaving directory '/home/src/package-5.0/' make[1]: List of Tables make: *** [all] Error 2 Chapter 17 - Buying for Linux make[3]: *** Hardware [file.o] Error

List of Sidebars

The first three lines practically give it away — the trouble centers around file.c located in /home/src/package-5.0/src. Unfortunately, there is so much extra output that it can be difficult to spot the important details. Learning how to filter out the subsequent make errors goes a long way toward digging out the real cause.

9.6.1Specific Errors Problem: Compiler error message: src.c:22: conflicting types for 'item' /usr/include/file.h:47: previous declaration of 'item'

Explanation and Fix: The programmer made an erroneous redeclaration of item on line 22 of src.c. You can usually fix this by removing the offending line (with a comment, an #ifdef, or whatever works). Problem: Compiler error message: src.c:37: `time_t' undeclared (first use this function) ... src.c:37: parse error before `...'

Explanation and Fix: The programmer forgot a critical header file. The manual pages are the best way to find the missing header file. First, look at the offending line (in this case, it's line 37 in src.c). It's probably a variable declaration like the following: time_t v1;

Search forward for v1 in the program for its use around a function call. For example: How Linux Works: What Every Super-User Should Know

v1 = time(NULL);

by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

describes workings a Linux system with the file system and boot process and Now run manThis2 guide time or manthe3 inner time to lookoffor system andbeginning library calls named time(). In this case, covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and the section 2sharing manual page has what you need: printers with Samba.

SYNOPSIS Table of Contents #include Every How Linux Works—What Super-User Should Know Chapter 1 Chapter 2

- The Basics

time_t - Devices, time(time_t Disks, Filesystems, *t); and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

This means that time() requires Chapter 5 - Configuring Your Network

time.h. Place #include at the beginning of src.c and

try again. Chapter 6 - Network Services Chapter 7

- Introduction to Shell Scripts

Problem:- Compiler (preprocessor) error message: Development Tools

Chapter 8 Chapter 9

- Compiling Software From Source Code

src.c:4: pkg.h: No such Chapter 10 - Maintaining the Kernel

file or directory

(long11 list of errors follows) Chapter - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

Explanation and Fix: compiler Chapter 14 - Sharing Files The with Samba

ran the C preprocessor on src.c, but could not find the pkg.h include file. The source code likely depends on a library that you need to install, or you may just need to provide Chapter 15 - Network File Transfer the compiler with the nonstandard include path (see Section 9.2.2 if the package uses GNU autoconf). In Chapter 16 - User Environments most cases, you Hardware just needfortoLinux add a -I include path option to the C preprocessor flags (CPPFLAGS). Keep Chapter 17 - Buying in mind you may also need a -L linker flag to go along with the include files. Chapter 18 that - Further Directions Appendix A - Command Classification

If you are Bibliography

using a graphics application and see Xm and Mrm in the error message, you are missing the Motif LessTif is a free replacement for Motif; if it is not on your system, you can get it at http://www.lesstif.org/ . List of Figures library. Index

List of Tables

If it doesn't look as though you're missing a library, there's also an outside chance that you are attempting a compile for an operating system that this source code does not support. Check the Makefile and README files for details about platforms.

List of Sidebars

Problem:make error message: make:prog: Command not found

Explanation and Fix: To build the package, you need prog on your system. If prog is something like cc, gcc, or ld, you don't have the development utilities installed on your system. On the other hand, if you think prog is already installed on your system, try altering the Makefile to specify the full pathname of prog. In rare cases, make builds prog and then uses prog immediately, assuming that the current directory (.) is in your command path. If your $PATH does not include the current directory, you can edit the Makefile and change prog to ./prog. Alternatively, you could append . to your path temporarily. Problem:Undefined symbols that start with SM_ and ICE_. Explanation and Fix: Some packages that link against X Window System libraries also need the -lSM and -lICE linker flags.

How Linux Works: What Every Super-User Should Know Chapter 10: Maintaining the Kernel by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

As mentioned in Section 2.2 , the kernel is the core of the operating system. In some respects, the Linux kernel is no different than any other software package. You can configure, build, and install the kernel Table of Contents because it comes as source code. However, the procedure for doing so is substantially different than for How Linux Works—What Every Super-User Should Know any other software package because the kernel runs like no other package. Chapter 1

- The Basics

Chapter 2

Disks, Filesystems, and the Kernel There are- Devices, four basic topics pertaining to kernel management:

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Configuring and compiling a new kernel Your end goal here is to build an image file, ready for the - Configuring Your Network boot loader. Chapter 6 - Network Services Chapter 5 Chapter 7

- Introduction to Shell Scripts

ChapterManipulating 8 - Development Tools loadable

kernel modules You don't have to build the kernel as one massive chunk of and kernel services as you need them.

Chaptercode. 9 - Compiling Software let From Source Kernel modules you loadCode drivers Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices ChapterConfiguring 12 - Printing

a boot loader such as GRUB or LILO Your kernel is useless if you can't load it into

Chaptermemory. 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Learning miscellaneous utilities and procedures There are many facilities that tweak runtime parameters and kernel features. You have already seen some examples of these in Chapterkernel 17 - Buying Hardware for extend Linux previous chapters, including the /proc filesystem and the iptables command. Chapter 18 - Further Directions Chapter 16 - User Environments

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: Every Your Super-User Should Know 10.1Do You Need toWhat Build Own Kernel? by Brian Ward

ISBN:1593270356

No Starch Press into © 2004 pages) Before running head-first a (347 kernel build, you need to ask yourself if it is worth it. Administrators who guide describes thethe inner workingsgoals of a Linux system beginning with the file system and boot process and compile theirThis own kernels have following in mind:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Installing the latest drivers Table of Contents Using the latest

kernel features (especially with respect to networking and filesystems)

How Linux Works—What Every Super-User Should Know ChapterHaving 1 - The Basics fun Chapter 2

- Devices, Disks, Filesystems, and the Kernel

However, if you need a driver Chapter 3 - How Linux Boots

or feature, and your distribution offers a straightforward upgrade, you might

opt for4 that instead, for several reasons: Chapter - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

You -can make mistakes in configuring your own kernel, and your distribution probably offers a wellNetwork Services rounded kernel. Chapter 7 - Introduction to Shell Scripts Chapter 6 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Compiling a new kernel takes a long time.

ChapterIt's 10far - Maintaining Kernelup too easy the to mess

the boot loader, making your system unable to boot.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter - Printing Even 12 if you choose

not to build your own kernel, though, you should still learn how boot loaders and

Chapter 13 -work. Backups modules Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: Super-User Should Know 10.2What You NeedWhat to Every Build a Kernel by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) includes documentation explaining what you need to compile a As with any No package, the kernel source This guide describes inner workings a Linux are system beginning important with the filefor system and boot process and functional kernel. These threethe aspects of yourofsystem particularly building a kernel:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

A C compiler (gcc). Most distributions put the C compiler in a development tools package. Make sure that your C compiler agrees with the recommendations in the kernel source code, specifically the Table of Contents README file. Kernel developers have not been eager to adopt the latest versions of gcc. Some How Linux Works—What Every Super-Usercompiler Should Know distributions have a separate named kgcc for compiling the kernel. Chapter 1

- The Basics

ChapterDisk 2 -space. Devices,ADisks, and tree the Kernel new Filesystems, kernel source can easily

unpack to more than 100MB even before building any

Chapterobject 3 - How Linux Boots files. Chapter 4

- Essential System Files, Servers, and Utilities

ChapterA5relatively - Configuring Network fast Your computer with Chapter 6

plenty of memory. Otherwise, the compile will take some time.

- Network Services

Your first is to get Chapter 7 - step Introduction to the Shellsource Scripts

code.

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux What Every Super-User Should Know 10.3Getting theWorks: Source Code by Brian Ward

ISBN:1593270356

Starch Press (347 pages) Linux kernelNo versions have© 2004 three components. Suppose you have kernel release 2.6.3. Here's what the This guide describes the inner workings of a Linux system beginning with the file system and boot process and numbers mean:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

2 is the major release number. Table of 6 Contents is the minor

release number.

How Linux Works—What Every Super-User Should Know Chapter3 1is the - Thepatchlevel. Basics

Kernels with the same major and minor numbers but with different patchlevels

Chapterbelong 2 - Devices, Disks, Filesystems, to a release series. and the Kernel Chapter 3

- How Linux Boots

There4are- Essential two different kerneland releases: Chapter Systemkinds Files, of Servers, Utilities Chapter 5

- Configuring Your Network

Production releases have minor version numbers that are even (for example, 1.2.x, 2.0.x , 2.2.x, 2.4.x, - Network Services 2.6.x, and so on).toThese versions are meant to be as stable as possible. W ithin a single production Chapter 7 - Introduction Shell Scripts series, there Chapterrelease 8 - Development Toolsare no radical feature or interface changes. Chapter 6

Chapter 9

- Compiling Software From Source Code

Development releases have minor version numbers that are odd (such as 2.5.). Don't use a developer release if you aren't willing to take risks. Kernel developers intentionally break code, introduce new Chapter 11 - Configuring and Manipulating Peripheral Devices features, and may inadvertently make the kernel unstable in a development series. Stay away from Chapter 12 - Printing development releases unless you know exactly what you're doing. Chapter 13 - Backups Chapter 10 - Maintaining the Kernel

Chapter 14 - Sharing Files with Samba

You can get the latest Linux kernel source code at http://www.kernel.org/. The releases have names like linux-version.tar.bz2 for bzip2 compression or linux-version.tar.gz for GNU Zip Chapter 16 - User Environments compression. Bzip2 archives are smaller. Chapter 15 - Network File Transfer

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

In addition to the full releases available in the kernel archives, you will also find patches containing just the changes between two consecutive kernel patchlevel releases. Unless you are obsessed with upgrading Bibliography your kernel with every single release, you probably won't be able to do much with a patch. Appendix A - Command Classification Index

List of Figures

10.3.1Unpacking the Source Archive

List of Tables

List of Sidebars

You can unpack kernels with zcat/bzip2 and tar. To get started, go to /usr/src and make your permissions less restrictive if necessary: cd /usr/src umask 022

Then run one of these commands to extract the source files, depending on whether you are using bzip2 or GNU Zip: bzip2 -dc linux-version.tar.bz2 | tar xvf zcat linux-version.tar.gz | tar xvf -

Warning If your kernel release is 2.4.18 or lower, the kernel unpacks into a directory named linux rather than linux-version. Rename any existing linux directory before unpacking one of these kernels (the new name does not matter, as long as it is different than the old one).

10.3.2A Look Around the Kernel Source If you've never seen the Linux kernel source code before, it helps to take a look around first. The top-level directory includes several subdirectories and files, including these: README This file is a general introduction to the Linux kernel source and what you need to get started. This document explains the version of the C compiler that you need to compile the kernel. Documentation This directory contains a wealth of documents. Most of the documents here are in plain-text format, and they may describe anything from user-level programs to low-level programming interfaces. One of the most important files in this directory is Changes, which describes recent

changes to the kernel and identifies utility programs you may need to upgrade to get full functionality. How Linux Works: What Every Super-User Should Know include You'll find the kernel header files in this directory. If you feel comfortable with your kernel, ISBN:1593270356 by Brian Ward you can use the header files in include/linux as your system /usr/include/linux header file No Starch Press © 2004 (347 pages) set. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

arch This directory contains architecture-specific kernel build files and targets. After a kernel build on a PC system, the final kernel image is in arch/i386/boot/bzImage.

Table of Contents

How Linux Works—What Every Super-User Should Know The Basics 10.3.3-Distribution Kernels

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter - How Linuxcome Boots Linux 3distributions Chapter tend to4 Chapter 5

with generic kernels intended to run on almost any processor type. These kernels - Essential Systemthan Files,custom Servers,kernels, and Utilities be a little larger and they rely heavily on loadable modules. - Configuring Your Network

However, many ofServices the Linux Chapter 6 - Network

kernels that come with the various Linux distributions omit complete source furthermore, distribution kernels often differ from the official standard at kernel.org. For example, Red Hat adds another component to the patchlevel to Chapter 8 -kernels Development Tools distinguish their kernels (forFrom example, If you wish to install a distribution kernel from source Chapter 9 - Compiling Software Source 2.4.20-20). Code code, 10 you- Maintaining need to use distribution's kernel source package. In Red Hat Linux, the package name is Chapter thethe Kernel kernel-source-version.rpm. Chapter 11 - Configuring and Manipulating Peripheral Devices code in default installations, Chapter 7 their - Introduction to Shell Scriptsand

Chapter 12 - Printing

If your13distribution Chapter - Backups

has a /usr/src/linux directory, this does not mean that you have the entire kernel have the header files. The kernel source takes up dozens of megabytes; run du -s /usr/src/linux for a quick check on what you have. Chapter 15 - Network File Transfer source. possible only Chapter 14It- is Sharing Files that with you Samba Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 10.4Configuring and Compiling the Kernel by Brian Ward

ISBN:1593270356

Starch Press 2004 (347 that pages)you want to have in your kernel before you build it. Your goal is to You need toNo configure the©options This guide .config describes the inner workings of asource Linux system beginning with the system of and process and have an appropriate file in your kernel distribution. Here's anfile excerpt a boot typical covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and .config file: sharing printers with Samba.

# CONFIG_HIGHMEM64G Table of Contents

is not set

# CONFIG_MATH_EMULATION isShould not Know set How Linux Works—What Every Super-User CONFIG_MTRR=y Chapter 1 - The Basics CONFIG_HAVE_DEC_LOCK=y Chapter 2 - Devices, Disks, Filesystems, and the Kernel Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 7

- Introduction to Shell Scripts

This file easy toYour writeNetwork with a Chapter 5 isn't - Configuring

text editor, so there are several configuration utilities that generate the file for you. An easy, standard way to set up a kernel is to run this command: Chapter 6 - Network Services

make 8menuconfig Chapter - Development Tools Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

After some initial setup, make menuconfig runs a Chapter 11 - Configuring and Manipulating Peripheral Devices

text-based menu interface that is shown in Figure 10center of the screen contains the options at the current configuration level. You can navigate menu with the up- and down-arrow keys. An arrow next to an item (--->) indicates a Chapter 13 -the Backups submenu. Chapter 14 - Sharing Files with Samba

1. The12box in the Chapter - Printing

Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Figure 10-1: Themake menuconfig kernel configuration menu. The bottom of the menu contains three actions that you can navigate to with the left- and right-arrow keys. Pressing ENTER while one of the menu items is highlighted performs whichever of the three following actions is also highlighted: Select If the current menu item leads to a submenu, the configuration system activates the submenu. Exit Exits the current submenu. If you are at the top-level menu, the configuration system asks whether you would like to save the current configuration. You can activate the Exit option by pressing ESC. Help Shows any online help for the current item. You can also get at the help by pressing the ? key. To get a general feel for how configuration options work, go into the Processor type and features submenu. You will see options such as these: [ ] Math emulation [*] MTRR (Memory Type Range Register) support < > /dev/cpu/microcode - Intel IA32 CPU microcode support

You can alter an item's configuration value by moving to the item and pressing the SPACEBAR. The square brackets ([]) provide a simple on/off toggle: [*] indicates that the feature is on. [ ] indicates that the feature is off.

You may not configure on/off features as kernel modules. Active features go directly into the main kernel image. How Linux Works: What Every Super-User Should Know

By contrast, by anBrian itemWard with angle brackets () denotes a feature that you may compile as a module. You ISBN:1593270356 can use the No SPACEBAR to toggle between these values: Starch Press © 2004 (347 pages) indicates This guide that describes the feature the inner is on. workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing that printers Samba. indicates thewith feature is configured as a module.

< Contents > indicates Table of

that the feature is off.

How Linux Works—What Every Super-User Should Know

An item Chapter 1 that - Theincludes Basics

regular parentheses like these, (), is a multiple-choice option or a number that you list, or enter a number.

can customize. Press to see Chapter 2 - Devices, Disks,ENTER Filesystems, andthe the option Kernel Chapter 3

- How Linux Boots

Chapter 4

Should You - Essential System Files,When Servers, and Utilities

Chapter 5

- Configuring Your Network

Compile a Driver as a Module?

There aren't many absolute Chapter 6 - Network Services

rules for deciding which features to compile as modules and which features to compile as part of Chapter 7 - Introduction to Shell Scripts the main kernel image, but here are a few guidelines and rules that can help Chapter 8 -you: Development Tools Chapter 9

- Compiling Software From Source Code

Always compile your root filesystem type directly into the kernel, not as a module. Your system won't boot otherwise.

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

Most administrators prefer to compile crucial disk support (such as SCSI host adapter drivers) directly into the kernel. There is a way to get around this with an initial RAM disk, but that is more Chapter 14 - Sharing Files with Samba an ugly hack than anything else. Chapter 13 - Backups

Chapter 15 - Network File Transfer

Chapter 16 Most - User administrators Environments

also compile network interface card drivers directly into the kernel. This isn't though.

Chapter 17 as - Buying Hardware Linux crucial as diskforsupport, Chapter 18 - Further Directions

Appendix A Compile - Command obscure Classification filesystems Bibliographyin

as modules. You may need them at some point, but there is no point wasting memory in the meantime.

Index List of Figures List of Tables

When you are List of Sidebars

through with configuration and decide to exit, the menu system will ask if you would like to save the current configuration. If you choose Yes, the system backs up your previous .config file as .config.old and writes a new .config file.

10.4.1Configuration Options Most of the configuration options are fairly self-explanatory. For example, in the menu shown in Figure 101 on page 205, the items under Device Drivers> SCSI device support > SCSI low-level drivers correspond to device drivers for SCSI host controllers. Some configuration options depend on other options, and until you activate the dependency options you cannot reach configuration options that have dependencies. For example, to reach the SCSI low-level drivers submenu, you must first activate SCSI device support in the previous menu. These dependencies are not always obvious; you may need to do a little bit of experimentation to find what you're looking for. If you're really stumped on a dependency, go to the source. Look at arch/i386/Kconfig, the master file for all options and online help for the kernel configuration. The following sections outline the most significant kernel options that reside within the important top-level menus. Keep in mind that these options change with time; you may see items not listed here, or the items may be in a different place in the kernel that you decide to build.

Code Maturity Level Options Inside this menu item you will find an option named Prompt fordevelopment and/or incomplete code/drivers. To see the newest (but perhaps unstable) drivers and features when perusing the rest of the kernel configuration menus, select this option.

General Setup This section has three settings that you should turn on: Support for paging of anonymous memory Enables swap disk and file support

System V IPC Enables interprocess communication How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

Sysctl support Enables kernel parameter changes through /proc No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

If you do notcovering build your kernel withsuch theas support listedfirewalls, here, many majortools, packages utilities will work, advanced topics networking, development device and management, shellnot scripts, and printers with Samba. including thesharing X Window System. In addition to these Table of Contents

options, the General Setup menu in kernel 2.6.0 and newer versions have an option process save the current .config file in the kernel image.1 If-you enable this option, you will also have the opportunity to enable a second option that allows Chapter The Basics you to2turn on access the embedded .config file via /proc/config.gz. These options increase your Chapter - Devices, Disks,toFilesystems, and the Kernel kernel size slightly, but they can come in extremely handy later on when you need to upgrade your kernel Chapter 3 - How Linux Boots but can't what Files, configuration options Chapter 4 -remember Essential System Servers, and Utilitiesyou selected. named .config support to make build How LinuxKernel Works—What Every Super-User Shouldthe Know

Chapter 5

- Configuring Your Network

Loadable Module Support - Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

You have some control over Chapter 8 - Development Tools

the kernel's module loader. In general, you should always activate the kernel support option, as well as activating the kernel module loader10option, Automatic kernel module loading, sometimes called the autoloader. Chapter - Maintaining the Kernel module withSoftware the Enable loadable module Chapter 9 system - Compiling From Source Code

Chapter 11 - Configuring and Manipulating Peripheral Devices

The only in the Chapter 12 -item Printing

kernel module support menu that you should be wary of is versioning support (at the Kernels compiled with this option enabled may try to load modules built for a different kernel Files version, and this can cause trouble if you don't know exactly what you're doing. Chapter 14 - Sharing with Samba moment, is experimental). Chapter 13 - this Backups Chapter 15 - Network File Transfer

Processor Type and Features

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

The Linux kernel Directions includes Chapter 18 - Further

a number of optimizations and other enhancements that are specific to certain processors. You can choose your processor with the Processor family option. Be careful — a kernel built Appendix A - Command Classification for a "primitive" CPU supports advanced processors, but a kernel tailored to an advanced CPU will likely Bibliography not work on an older (or different brand of) CPU. Index List of Figures

Other significant options in the processor category include:

List of Tables

List of Sidebars

High memory support This is for machines with more than 2GB of physical memory. Symmetric multi-processing support This is for machines with more than one processor. MTRR support This permits optimizations that may improve certain kinds of graphics performance.

Power Management Options There are two types of power management in PC hardware: the older APM (Advanced Power Management) and the newer ACPI (Advanced Configuration and Power Interface). You can configure a kernel with both varieties. Appropriate power management support is essential on notebooks to preserve battery life, and it is a good idea for desktops so that your machine doesn't generate too much heat and use too much electricity. Power management features enable interesting tricks with fans, processor speeds, and more. There's a lot to explore, but you may need additional software such as apmd or acpid to take advantage of the kernel features.

Bus Options You shouldn't need to change the bus options for most systems. Unless you have an extremely old or odd system, include PCI support (and if you'd like to list and diagnose devices on the PCI bus, install lspci, which is a part of the pci-utils package). You should enable the Support for hot-pluggable devices option so that your system can take appropriate action when you attach and detach removable devices. Newer kernels include base PCMCIA (PC Card/CardBus) drivers as configuration options in this menu — in previous systems, PCMCIA support was completely separate from the main kernel distribution. You still need the PCMCIA utilities if you intend to use PC cards, and at the moment, you can still leave out PCMCIA kernel support here and get it from these utilities, but this may change in the future.

Executable File Formats How Linux Works: What Every Super-User Should Know

To start a process from an executable file on the disk, the kernel needs to know how to load the ISBN:1593270356 by Brian Ward executable file, how to initialize the process in memory, and where to start running the process. An No Starch Press © 2004 (347 pages) executable's file format determines these characteristics. Most binaries on a modern Linux system are ELF This guide describes the inner workings of a Linux system beginning with the file system and boot process and (Executablecovering and Linkable Format) files. probably do notdevelopment need to support the ancient "a.out" advanced topics such asYou networking, firewalls, tools, device management, shell scripts, and executable format sharing (you printers may withnot Samba. even have the shared libraries to support these binaries), but it does not take too much memory to include support, and you can build it as a module. Table of Contents

Device Drivers

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 7

- Introduction to Shell Scripts

Configuring device drivers is a long process due Chapter 2 - Devices, Disks, Filesystems, and the Kernel

to the wide variety of devices that Linux supports. Unfortunately, it's during this stage that you can get bogged down with all of the options and end up Chapter 3 - How Linux Boots building kernel that is far tooServers, large because you included drivers for devices that you will never have. If Chapter 4 a - Essential System Files, and Utilities you're5in -doubt aboutYour whether you are going to use any particular driver (other than a disk driver), build it Chapter Configuring Network as a module so that it does not unnecessarily take up kernel memory. Chapter 6 - Network Services The following sections describe the driver configuration options inside the Device drivers menu. - Development Tools

Chapter 8 Chapter 9

- Compiling Software From Source Code

Plug and Play Support

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

You must enable Plug and Play support if you want any reasonably modern built-in hardware in your computer to work. You may also need plug-and-play support in order to use network cards, internal Chapter 13 - Backups modems, and sound cards. Chapter 14 - Sharing Files with Samba Chapter 12 - Printing

Chapter 15 - Network File Transfer

Block Devices

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

TheBlock devices section of the kernel configuration contains miscellaneous random-access storage devices, such as floppy disks and RAM disks. These devices normally hold filesystems that you directly Appendix A - Command Classification attach to your current system with the mount command. The interesting drivers here include the following: Bibliography Chapter 18 - Further Directions

Index

Normal List of Figures

floppy disk support A driver for the PC floppy disk drive.

List of Tables List of Sidebars

Loopback device support A simple driver that maps a file into a block device. This driver is very useful because it allows you to mount a filesystem on a disk image. Network block device support A driver that allows you to use a network server as a block device. RAM disk support A driver that designates a chunk of physical memory as disk space. Initial RAM disk (initrd) support A driver that provides a special kind of RAM disk that a boot loader gives to the kernel as the initial / partition during the very first stages of init. Many distributions use an initial RAM disk for SCSI drivers and other modules that may not be in their stock kernels. Parallel port IDE device support A driver for certain older portable disk devices.

ATA (IDE) Support You should always compile ATA (IDE) support directly into your kernel unless you know exactly what you're doing. There are several kinds of IDE drivers that you can enable here: Disk support A driver required if you want hard drives to work. Needless to say, you should compile this driver directly into the kernel. CD-ROM support A driver for ATAPI CD-ROM and DVD-ROM drives. Floppy support A driver for various removable-media drives with an ATAPI interface. SCSI emulation A driver for ATAPI CD-R and CD-RW drives. Older Linux CD-burning software worked exclusively with SCSI drivers; if your CD-burning software is up to date, you do not need this

driver. How Linux Works: What Every Super-User Should Know

Various chipsets Drivers for various specific chipsets. If your motherboard's IDE chipset isISBN:1593270356 listed, you by Brian Ward might be able to squeak out a little more performance with one of these drivers. No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

SCSI Support covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Even if you have no SCSI devices, you may still need SCSI support because many Linux device drivers workofthrough Table Contentsemulated SCSI devices. For example, if you want to use USB mass storage, you need SCSI disk support. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

These are the media drivers: - Devices, Disks, Filesystems, and the Kernel

Chapter 2

ChapterSCSI 3 - How diskLinux support Boots

Covers all fixed and removable-media disk-like storage devices, except CD-ROM

Chapterdrives. 4 - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

tape support ChapterSCSI 6 - Network Services Chapter 7

- Introduction to Shell Scripts

Chapter 9

- Compiling Software From Source Code

CD-ROM support ChapterSCSI 8 - Development Tools

SCSI generic support Allows applications talk to a SCSI device at a low level. You need SCSI support and for a wide range of devices, including CD burners, changer devices on tape drives, Chaptergeneric 11 - Configuring Manipulating Peripheral Devices scanners, and more. ChapterSCSI 12 - Printing Chapter 10 - Maintaining the Kernel

Chapter 13 - Backups

A look inside the SCSI low-level drivers submenu reveals drivers for many kinds of SCSI host controllers. Some of the drivers are named after the SCSI chipset on the host controller, so you may have to look Chapter 15 - Network File Transfer carefully at your hardware to find a match. The low-level driver list also includes support for some parallel Chapter 16 - User Environments port devices, such as Zip drives. Chapter 17 - Buying Hardware for Linux Chapter 14 - Sharing Files with Samba

Chapter 18 - Further Directions

Note If your kernel and root partition are on a SCSI disk, compile SCSI support (including the disk and host controller drivers) directly into the kernel rather than as modules. This makes booting much Bibliography easier, because you do not need to worry about loading SCSI modules from a disk that the Index kernel does not yet know how to access. Appendix A - Command Classification

List of Figures List of Tables

Networking Support

List of Sidebars

You need networking support for almost any system, even if you do not have an external network connection. Many applications use local network interface features. Your first order of business is to pick the networking devices that you need. For most Ethernet devices, look under Ethernet (10 or 100Mbit). There are many devices to choose from. If you're not too sure what you need, don't be afraid to configure several drivers as modules. In addition, if you plan to dial up to the Internet or use certain DSL connections, you need PPP support, along with asynchronous (serial port) or PPP over Ethernet (PPPoE) support. If you're not sure about PPP options, configure them as modules. The configuration options inside the Networking options submenu represent the trickiest part of the kernel network configuration. You need to select all of the options and protocols that you intend to use. The essential options for many packages include the following: TCP/IP networking Unix domain sockets Packet socket (for features such as promiscuous mode) Not so obvious is Network packet filtering, which is required for any kind of firewall or NAT (Network Address Translation, or "IP masquerading") support. Just selecting this option is not enough because, in general, your kernel needs all of the connection tracking, NAT, and masquerade options if you want to use NAT. Therefore, you must enter the Netfilter Configuration submenu and choose more options there, such as these: Connection tracking for NAT (be sure to include any protocols you need to track). IP tables support for firewalling and NAT. Once you enable IP tables, you get several more options, including various match options for filtering. You don't have to worry about most of these, except for Connection state and Connection tracking, both of which you need for NAT. That's not the end of the things you need for NAT — look out for and enable Full NAT and MASQUERADE target support.

Packet filtering and REJECT target support for firewalls.

Input Device How Linux Support Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

You need several configuration options No Starch Press © 2004 (347 pages) to support your keyboard and mouse. There are two levels of support. TheThis basic drivers support theworkings PS/2 keyboard. for PS/2 guide describes the inner of a Linux Also, systemlook beginning with Mouse. the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and printers with Samba. Charactersharing Devices and Parallel Port Support Table of Contents Among the most

important character devices are Virtual terminals (/dev/tty0,/dev/tty1, and so also need to put the console on the virtual terminal.

How Works—What Every Super-User Know you on).Linux Unless you have a special typeShould of server, Chapter 1

- The Basics

Chapter 2 -some Devices, Disks, Filesystems, andup theon: Kernel Here are other things to check Chapter 3

- How Linux Boots

ChapterSerial 4 - Essential Files,PC Servers, Utilities driversSystem Standard serialand ports use Chapterneed 5 - Configuring Your Network this support if you plan

or emulate 8250/16550 UART chips. You almost certainly to use a modem.

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

PTY support ChapterUnix98 8 - Development Tools

Some programs now expect to see the dynamic Unix98 /dev/pts/* pseudolike /dev/ttyp*.

devices ratherFrom thanSource old static Chapterterminal 9 - Compiling Software Code names Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Enhanced real time clock support This makes /dev/rtc available to programs like hwclock. You enable this option for any modern machine. Chaptershould 13 - Backups Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba Chapter/dev/agpart 15 - Network FileThis Transfer is for

direct-rendered graphics (GLX and DRI) on AGP graphics cards.

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux ChapterParallel 18 - Further printer Directions support

This gives you /dev/lp* devices. To get this option, you must go back to enable Parallel port support. You also need PC-style hardware for any

Appendix - Command theA main kernelClassification menu and Bibliography standard

PC.

Index List of Note FiguresThere List of Tablesignore

is a section for Mice in the character device configuration, but you can probably safely it, because the drivers there are for very old bus mice.

List of Sidebars

Sound There are two parts to sound configuration: API support and drivers. The current sound system is called Advanced Linux Sound Architecture (ALSA), but you should also include the emulation support for the old OSS (Open Sound System), because many programs still use the OSS interface. The driver configuration for sound devices is very similar to that for network devices — many of the sound drivers carry the names of the sound chipset.

USB Support When configuring USB, choose an interface driver first: UHCI and OHCI are USB 1.1 interfaces. Even if you have a USB 2.0 motherboard, you need one of these. If you don't know which one your motherboard supports, pick both (modules are okay); the kernel will sort it out. EHCI is a USB 2.0 interface. You also want to enable the USB device filesystem option that can maintain USB device information in /proc/bus/usb. Configuring the kernel to support USB devices is fairly straightforward, but there are two gotchas: TheMass storage support option requires that you also enable SCSI and SCSI disk support. TheInterface device support (HID) option requires that you enable the input drivers described earlier. To get USB mouse and keyboard support, you need to enable HID input layer support in the USB support menu. Don't use the boot protocol drivers unless you know exactly what you're doing.

Filesystems You can add support for many different filesystems to your Linux kernel configuration. However, make

sure that you compile your primary filesystem directly into the kernel. For example, if your root partition uses ext2, don't modularize ext2 support. Otherwise, your system will not be able to mount the root filesystem and therefore will not boot. How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

These are the No most Starchimportant Press © 2004filesystems: (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and advanced topics as networking, firewalls, tools, device management, shell scripts, and Secondcovering extended (ext2) Thesuch Linux standard for manydevelopment years. sharing printers with Samba.

Third extended Table of Contents

(ext3) A journaled version of ext2; now the standard for many distributions.

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Reiserfs A high-performance journaled filesystem. - Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

ChapterDOS/FAT/NT 4 - Essential System Files,and Servers, and Utilities MS-DOSWindows-compatible

filesystems. To get MS-DOS filesystem support, Configuring Your Network you -need to enable FAT. VFAT is the extended filesystem introduced with Windows 95. You need Chapter 6 - Network Services VFAT if you plan to read images from the flash memory cards in digital cameras and similar devices. Chapter 5 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

ChapterISO9660 9 - Compiling A standard Software CD-ROM From Source filesystem. Code Chaptercan 10 -also Maintaining Kernel add thethe Microsoft

The Linux driver includes the Rock Ridge extensions. You Joliet extensions.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

newer ChapterUDF 13 - A Backups

CD-ROM and DVD filesystem.

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Minix A filesystem that was the Linux standard a long time ago (it even predates Linux). It never hurts to include Minix filesystem support as a module.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Pseudo filesystems These

are system interfaces, not storage mechanisms. The /proc filesystem is the best-known pseudo-filesystems, and one that you should always configure. You should also include the /dev/pts filesystem and the virtual memory filesystem.

Bibliography one of Index

List of Figures List of Tables

Network List of Sidebars

filesystems These are used for sharing files with machines over the network.

There are also a couple important filesystem-related options: Kernel automounter support Enables automatic filesystem mounting and unmounting. This is a popular solution for managing network filesystem access. Partition types Allows Linux to read partitioning schemes other than the regular PC partition tables, including BSD disklabels and Solaris x86 partitions. This wraps up the important kernel configuration options. You shouldn't really have to worry about the other options (such as the Profiling support used for kernel development); let's turn our focus to compiling the kernel.

10.4.2Compiling the Kernel and Modules After you save your kernel configuration, you're ready to build the kernel. To get a list of make targets, you can run this command: make help Your main goals are to compile the bzImage compressed kernel image and the kernel modules. Because these two are the default targets, you only need to run the following to build everything: make

The compile takes some time. As it runs along, you see messages like this:

CC

init/version.o How Linux Works: What Every Super-User Should Know

If you see a by message containing [M], it means that make is compiling a module: Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

CC [M]

This net/sctp/protocol.o guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

The following output appears when make builds bzImage: Table of Contents How Linux Works—What Every Super-User Should Know

Kernel: arch/i386/boot/bzImage is ready

Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots As the preceding message indicates, the build process creates your kernel image as creates a file named System.map that contains kernel Chapter 5 - Configuring Your Network symbols and locations. You may have to wait a little while after the "Kernel ready" message appears, Chapter 6 make - Network Services because may still need to compile some kernel modules. Don't interrupt the build; make sure that Chapter 7 - Introduction to Shell Scripts you wait until you get your prompt back before installing the kernel. Chapter 4 - Essential System Files, Servers, and Utilities arch/i386/boot/bzImage. The process also

Chapter 8

- Development Tools

Chapter 9 - In Compiling Code Note kernel Software versionsFrom priorSource to 2.6, you

had to run the following commands for a complete kernel

Chapter 10 - build: Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

make dep make bzImage

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments

Failed Compiles

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Recent kernels are very self-contained; there are only two primary things that can go wrong during the build process:

Appendix A - Command Classification Bibliography Index

If you get a parse error or some other sort of coherent compiler error, the compiler on your machine doesn't match the recommended compiler in the README file. Kernel code is very particular List of Tables about the compiler, especially due to all of the assembly code involved. List of Figures probably List of Sidebars

If the compiler dies unexpectedly midway through the build process, your hardware may be at fault. Compiling a kernel stresses a machine much more than almost any other task. Bad memory and overclocked or overheated processors are the main culprits. If you need to see each command in the build process to track down a problem, use this command: make V=1

10.4.3Installing Modules Before you install and boot from your new kernel, you should put the new kernel modules in /lib/modules with this command: make modules_install Your new modules should appear in /lib/modules/version, where version is your kernel version. If you fail to install the modules before booting your kernel, the kernel module utilities will not automatically recognize the new modules, and you may end up missing a few drivers. The module installation builds a module dependency list in /lib/modules/version/modules.dep. If this stage fails, it's likely that your module utilities are out of date. As of this writing, the module utilities are in a package named module-init-tools.

10.4.4Kernel Parameters Sometimes you need to send extra parameters to the kernel at boot time in order to get devices or services working. For example, one of the most elementary kernel parameters is root=partition,

which sets the initial root partition to partition. You can enter a kernel parameter kernel image name. How Linux Works: Whatafter Everythe Super-User Should KnowFor example, at a LILO prompt where your kernel label by is Linux, you can type this: ISBN:1593270356 Brian Ward No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Linux root=/dev/hda3 covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Documentation/kernel-parameters.txt contains a list of all kernel parameters. Most of them are addition to root=partition, here are the most important parameters:

Table of ContentsIn for hardware.

How Linux Works—What Every Super-User Should Know

init=path This starts path as the first process on the system in place of /sbin/init. For - The Basics example, you can use init=/bin/sh to get out of a tight spot if your init does not work properly. Chapter 2 - Devices, Disks, Filesystems, and the Kernel Chapter 1 Chapter 3

- How Linux Boots

mem=size This specifies that the machine has size memory; the kernel should not autodetect the - Essential System Files, Servers, and Utilities memory size. For example, to specify 512MB of memory, you would use mem=512M.

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6

- Network Services rootfstype=type This specifies that the root filesystem's type is type.

Chapter 7

- Introduction to Shell Scripts

Chapter 8 - Development Tools A number as a boot parameter Chapter 9

indicates the init runlevel. You can use -s or S for single-user mode.

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How LinuxYour Works: What Every Super-User Should Know 10.5Installing Kernel with a Boot Loader by Brian Ward

ISBN:1593270356

Starch Pressimages © 2004 (347 pages) Boot loadersNoload kernel into memory and hand control of the CPU over to the newly loaded This guide the inner workings of a tell Linux system with the system and boot process and kernel. To make yourdescribes new kernel work, you must the boot beginning loader about thefile kernel.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

If you have never worked with a boot loader before, you need to know how a PC boots from the hard disk. On a normal Microsoft-based system, the boot process works like this:

Table of Contents

1. After performing power-on self Know test (POST), How Linux Works—What Everythe Super-User Should

the BIOS loads sector 1 of the hard disk into runs whatever landed in that memory. On most Windows-based systems, this sector is the Master Boot Record (MBR). Chapter 2called - Devices, Disks, Filesystems, and the Kernel and Chapter 1memory - The Basics Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

2. The MBR extracts the partition table from the disk and identifies the "active" partition.

Chapter 5

- Configuring Your Network 3. The MBR loads and runs yet another boot sector from the active partition, setting the operating - Network Services system in motion.

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8 - Development Tools On a Linux system, you can

install the kernel boot loader on the active partition or you can replace the the MBR with a boot loader such as GRUB or LILO, it is Chapter 10 - Maintaining the Kernel important to remember that the active partition has little meaning — these boot loaders address partitions Chapter Configuring and Manipulating Peripheral Devices based11 on- their own configuration systems. Chapter 9 - Compiling Code MBR with the boot Software loader. IfFrom youSource decide to replace

Chapter 12 - Printing

From 13 a practical Chapter - Backupspoint

of view, your decision to overwrite the MBR (and thus circumvent the active If your machine runs Linux, you probably want GRUB or LILO as your default15boot loader. if you have a dual-boot machine, you still want to use GRUB or LILO, because Chapter - Network FileEven Transfer both boot are capable of loading boot sectors from other operating systems. Chapter 16 - loaders User Environments partition) difference. Chapter 14 -makes Sharing little Files with Samba

Chapter 17 - Buying Hardware for Linux

The important point is that Chapter 18 - Further Directions

you know exactly where your boot loader resides. Let's say that your disk is /dev/hda and you have a Linux root partition at /dev/hda3. If you replace the MBR by writing GRUB to Appendix A - Command Classification /dev/hda, you need to remember that the active partition is now irrelevant; GRUB uses its own Bibliography configuration system to access partitions. However, if you decide to write the boot loader to /dev/hda3 Index instead, keeping the old MBR, your system will get to that boot loader only if /dev/hda3 is the active List of Figures partition. List of Tables List of Sidebars

Note If you need to replace the MBR on a hard disk, run the DOS command FDISK /MBR.

When configuring a boot loader, be sure that you know the location of the root partition and any kernel parameters.

10.5.1Which Boot Loader? Because there are two popular Linux boot loaders, you may wonder which one you should choose: LILO Linux Loader. This was one of the very first Linux boot loaders. Its disadvantages are that it is not terribly flexible and that you must run lilo to install a new boot block every time you install a new kernel. However, LILO is fairly self-contained. GRUB Grand Unified Boot Loader. This is a newer boot system gaining in popularity, and it does not need a reconfiguration for every new kernel because it can read many kinds of filesystems. This feature is especially handy for situations where you might need to boot from an old kernel. Initially, GRUB is slightly trickier to configure than LILO, but it is much easier to deal with once installed, because you do not need to replace the boot sector for every new kernel. I recommend GRUB.

10.5.2GRUB With GRUB, you need only install the boot loader code on your machine once; after that, you can modify a GRUB menu file for any new kernel that you want to boot on a permanent basis. The GRUB boot files are in /boot/grub. GRUB loads the various stage files into memory during the boot process. If you already have GRUB on your machine, you just need to modify the /boot/grub/menu.lst file when you add a new kernel image under a new name. (If you install a new kernel image with the same name as the old kernel, you do not need to modify the menu file.) Some distributions preinstall GRUB but have a different name for menu.lst . You may need to dig

around in /boot to find the correct filename. In any case, the menu file looks like this: default 0How Linux Works: What Every Super-User Should Know by Brian Ward timeout 10

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and title Linux advanced topics such as networking, firewalls, development tools, device management, shell scripts, and kernel covering (hd0,0)/boot/vmlinuz root=/dev/hda1 sharing printers with Samba.

title backup kernel (hd0,0)/boot/vmlinuz.0 root=/dev/hda1

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel The parameters in the menu file are as follows:

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities default The title entry that GRUB should boot by default. 0 is the first entry, 1 is the second, and - Configuring Your Network so on.

Chapter 5 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chaptertimeout 8 - Development Tools How long GRUB Chapter 9

should wait before loading the default image.

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

A label for kernel. Chaptertitle 11 - Configuring andaManipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

kernel The kernel image and parameters, possibly including the root device.

Chapter 14 - Sharing Files with Samba

Chapter 15 - Network Transfer In GRUB, (hd0) File is the first hard

disk on your system, usually /dev/hda. GRUB assigns disk mappings in on your system, so if you have /dev/hda and /dev/hdc devices but no Chapter 17 - Buying Hardware Linux (hd0)to /dev/hda and (hd1) to /dev/hdc. The first number in the /dev/hdb, GRUB wouldfor assign Chapter 18 Further Directions GRUB name is for the disk, and the second is for the partition (if there is a partition). Check the Appendix A - Command Classification /boot/grub/device.map file for your system's hard drive mapping. Chapter 16 - that User they Environments the order appear

Bibliography Index The

kernel images in the preceding example are on the root partition of the primary master ATA hard disk. kernel images: a regular kernel at /boot/vmlinuz and a backup at /boot/vmlinuz.0.

List of Figures There are two List of Tables

Root Device Confusion

List of Sidebars

You may find it odd that the root partition is actually specified twice in the kernel line in the preceding example (you can see (hd0,0) and /dev/hda1). This is easy to explain: the (hd0,0) is where GRUB expects to find the kernel image, and root=/dev/hda1 is a Linux kernel parameter that tells the kernel what it should mount as the root partition. These two locations are usually, but not always, the same. However, the GRUB and Linux device names are completely different, and so you need them in two places in the configuration file. Unfortunately, you may see this alternate syntax in menu.lst: root (hd0,0) kernel /boot/vmlinuz.0 root=/dev/hda1 This is confusing, because GRUB does not pass its root parameter (hd0,0) to the Linux kernel. Omitting the GRUB root parameter can prevent some head scratching.

Booting Other Operating Systems There are all sorts of other things you can do with GRUB, like load splash screens and change the title (useinfo grub to see all of the options). However, the only other essential thing you should know is how to make a dual-boot system. Here is a definition for a DOS or Windows system on /dev/hda3: title dos rootnoverify (hd0,2) makeactive chainloader +1

Remember how the PC boot loaders usually work, by first loading whatever is on the first sector of the disk, then loading the first sector of the active partition. How Linux Works: What Every Super-User Should Know

Installing by GRUB Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

To put GRUB onguide yourdescribes systemthe forinner the first time,ofyou must make sure that you a menu.lst file. The This workings a Linux system beginning with the have file system and boot process and GRUB installation coveringprocess advanceddoes topicsnot such create as networking, menu.lst; firewalls, you development must cometools, up with device thismanagement, file on yourshell own. scripts, If youand sharing printers withsystem, Samba. but you must type a series of commands resembling entries in don't, you can still boot your menu.lst to do so, as follows: Table of Contents How Linux Works—What Every Super-User Should Know

kernel (hd0,0)/boot/vmlinuz root=/dev/hda1 boot - The Basics

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 - the Configuring Network To install GRUB Your software, run Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

this command to put the boot sector on your disk:

grub-install device - Development Tools

Chapter 8 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

Here, device is your boot device, such as /dev/hda. However, if you have aspecial /boot partition, you need to do something like this: Chapter 12 - Printing Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 13 - Backups

grub-install --root-directory=/boot Chapter 14 - Sharing Files with Samba

device

Chapter 15 - Network File Transfer Chapter 16 - User Environments

After running grub-install, review Chapter 17 - Buying Hardware for Linux

your /boot/grub/device.map file to make sure that the devices relevant to booting the kernel are in the map file and agree with your menu.lst file. Chapter 18 - Further Directions Appendix A - Command Classification Bibliography

10.5.3LILO

Index

List of Figures

To load your kernel with LILO, you must settle on a permanent location for your kernel image and install a new boot block for every change you make to the kernel configuration.

List of Tables

List of Sidebars

Let's say that you want to boot /vmlinuz as your kernel with a root partition of /dev/hda1. Furthermore, you want to install the boot loader on /dev/hda (replacing the MBR). Do the following: 1. Move the new image into place at /boot/vmlinuz. 2. Create the LILO configuration file, /etc/lilo.conf. An elementary configuration might look like this: boot=/dev/hda root=/dev/hda1 install=/boot/boot.b map=/boot/map vga=normal delay=20 image=/boot/vmlinuz label=Linux read-only 3. Runlilo -t -v to test the configuration without changing the system. 4. Runlilo to install the boot loader code at /dev/hda. You can add more images and boot sectors to the LILO configuration. For example, if you saved your previous kernel as /boot/vmlinuz.0, you could add this to your lilo.conf to make the old image available as backup at the LILO prompt: image=/boot/vmlinuz.0 label=backup read-only

You can use the other keyword for foreign operating systems. The following addition to lilo.conf How Linux Works: Every Super-User Know offers a Windows partition on What /dev/hda3 as dos atShould the LILO prompt: by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

other=/dev/hda3 This guide describes the inner workings of a Linux system beginning with the file system and boot process and label=dos covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

LILO Parameters

Table of Contents

How Linux Works—What Every Super-User Should Know

Some1of -the Chapter Themost Basicsimportant

lilo.conf parameters are listed here:

Chapterboot=bootdev 2 - Devices, Disks, Filesystems, andboot the Kernel Writes the new sector Chapter 3

to the bootdev device.

- How Linux Boots

Chapterroot=rootdev 4 - Essential System Files, Servers, as andthe Utilities Uses rootdev kernel's Chapter 5

default root partition.

- Configuring Your Network

Chapterread-only 6 - Network Mounts Services

the root partition initially as read-only. You should include this for normal boot root partition in read-write mode later).

Chaptersituations 7 - Introduction (init to remounts Shell Scripts the Chapter 8

- Development Tools

options Chapterappend="options" 9 - Compiling Software Includes From Source Code Chapter 10 - Maintaining the Kernel

as kernel boot parameters.

Displays the LILO Peripheral prompt for num Chapterdelay=num 11 - Configuring and Manipulating Devices kernel Chapterdefault 12 - Printing

tenths of a second at boot time before booting the

image.

Chapter 13 - Backups

map=map_file Stores the kernel's location in map_file. Don't delete this file.

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

install=file Specifies that file is the actual boot loader code that lilo writes to the boot sector.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

image=file Defines a bootable kernel image with file. You should always use the label parameter directly following this definition to name the image.

Chapter 18 - Further Directions

Appendix A - Command Classification Bibliography label=name

Uses name to label the current boot entry.

Index

Defines another partition that contains a boot sector; analogous to image for operating systems. Use label to define a label for the boot sector.

List of Figures other=partition List of Tables other

List of Sidebars

linear Remaps the boot sector load references when the BIOS disk geometry is different than the geometry that the Linux kernel sees. This is usually not necessary, because most modern BIOS code can recognize very large disks.

10.5.4Initial RAM Disks Aninitial RAM disk is a temporary root partition that the kernel should mount before doing anything else. Red Hat Linux uses initial RAM disks to support SCSI host controller drivers and other drivers that are compiled as modules. Note You do not need an initial RAM disk if you compile all the drivers necessary to mount your root filesystem directly into your kernel. The overwhelming majority of systems do not need an initial RAM disk. To install an initial RAM disk on a Red Hat Linux system, follow these steps: 1. Build your kernel and install the modules. Do not run any boot loader configuration or reboot just yet. 2. Run this command to create a RAM disk image (where version is your kernel version): mkinitrd /boot/initrd-version version 3. If your boot loader is LILO, add this line to your new kernel's section in lilo.conf and run lilo: initrd=/boot/initrd-version 4. For GRUB, add the following to the appropriate kernel section:

4. initrd /boot/initrd-version How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux What Every Super-User Should Know 10.6Testing theWorks: Kernel by Brian Ward

ISBN:1593270356

No Starch © 2004 (347 When you boot your Press new kernel forpages) the first time, you should take a careful look at the kernel diagnostic guide describes theof inner workings of a shows Linux system beginning with the fileare system andwhat boot they process messages toThis make sure that all your hardware up and that the drivers doing areand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and supposed tosharing do. Unfortunately, kernel messages tend to fly by so quickly that you can't see them. You can printers with Samba. run dmesg to see the most recent messages, but to see everything, you need to look at your log files. Table Contents Mostof/etc/syslog.conf

files send kernel messages to a file such as /var/log/kernel.log. If you /etc/syslog.conf:

How Linux Works—What Every Should Know don't see it anywhere, addSuper-User a line like this to your Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

kern.* - How Linux Boots

Chapter 3

/var/log/kernel.log

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Then run this command:

kill 8-HUP '/var/run/syslogd.pid' Chapter - Development Tools Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

You may to make checklist for your new kernel Chapter 11 - wish Configuring andaManipulating Peripheral Devices should. an Chapter 12Here's - Printing

to make sure that your system still operates as it

example:

Chapter 13 - Backups

Do the network interface and network firewalls work?

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Are all of your disk partitions still visible?

Chapter 16 - User Environments

ChapterDoes 17 - Buying Hardware Linux the kernel see for your serial,

parallel, and USB ports?

Chapter 18 - Further Directions

Does all of yourClassification external hardware Appendix A - Command Bibliography Index

Does the X Window System work?

List of Figures List of Tables List of Sidebars

work?

How Linux Works: What Every Super-User Should Know 10.7Boot Floppies by Brian Ward

ISBN:1593270356

Starch © 2004 (347 a pages) You can alsoNoboot thePress kernel from floppy disk. Creating a boot floppy can be useful when recovering a guide the kernel. inner workings of a Linux system beginning with the file system and boot process and Linux systemThis that hasdescribes no active

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

To create a boot floppy, put a freshly formatted floppy disk in the drive, go to the kernel source directory, and run this command:

Table of Contents

How Linux Works—What Every Super-User Should Know

make bzdisk - The Basics

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Of course, this only works if the size of your bzImage is smaller than the floppy disk capacity.

Chapter 5 - also Configuring Your You may need to runNetwork rdev

to set the floppy's default root device. For example, if your root partition is

Chapter 6 - Network /dev/hda1, use Services this command: Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

rdev /dev/fd0 /dev/hda1 - Compiling Software From Source Code

Chapter 9

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

Again, boot floppies are primarily useful during a system recovery when there is no active kernel. For testing new kernels, it's far better just to use an advanced boot loader such as GRUB.

Chapter 12 - Printing

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Know 10.8Working with Loadable KernelShould Modules by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) Loadable modules are little pieces of kernel code that you can load and unload into the kernel memory the inner workings of a Linux system beginning with the file system and boot process and space while This the guide kerneldescribes is running.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Themake modules_install command (discussed in the "Installing Modules " section) installs the kernel module object files in /lib/modules/ver-sion, where version is your kernel version number. Module Table of Contents object filenames end with .ko in kernel versions 2.6.0 and later, and .o in older releases. How Linux Works—What Every Super-User Should Know Chapter 1 - The Basics All distributions use

modules in some capacity. If you would like to see the modules currently loaded on

Chapter 2 - Devices, Disks, Filesystems, and the Kernel your system, run this command: Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

lsmod

Chapter 7

- Introduction to Shell Scripts The output should look something like this:

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Module Size Chapter 10 - Maintaining the Kernel

Used by es1370 24768 0 (autoclean) Chapter 11 - Configuring and Manipulating Peripheral Devices appletalk 19696 13 (autoclean) Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

This output includes es1370 (a sound card driver) and appletalk (a network protocol driver). autoclean means that the kernel may try to automatically unload the module if it is not used for some Chapter 16 - User Environments time. Chapter 17 - Buying Hardware for Linux Chapter 15 - Network File Transfer

Chapter 18 - Further Directions

To load a module, use the modprobe command:

Appendix A - Command Classification Bibliography

modprobemodule Index List of Figures List of Tables List of Sidebars

To remove a single module, use the -r option:

modprobe -r module

As mentioned earlier, you can find module dependencies in /lib/modules/version/modules.dep. Dependencies don't arrive on your system by magic; you must build an explicit list (the kernel module install process usually does this for you). You may need to create module dependencies by hand for all installed kernel versions after installing a module that doesn't come with the kernel. You can do this by running this command: depmod -a

However, this doesn't always work, because depmod may try to read the symbol function memory address locations in the currently running kernel. This won't work if you're trying to build dependencies for kernels other than the one you're running. To zero in on a particular kernel version, find a System.map file that corresponds to that kernel, and then run this command: depmod -a -F System.map version

As mentioned earlier, though, you do not need to run depmod under normal circumstances, because make modules_install runs it for you.

HINT If you can't find the module that corresponds to a particular feature, go to the feature in the kernel configuration menu and press ? to get the help screen. This usually displays the module name.

10.8.1Kernel Module Loader

It's inconvenient to manually load a module every time you need to use a particular feature or driver. For example, if you compiled a certain filesystem as a module, it would be too much work to run a modprobe before a mount that referenced the filesystem. How command Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

The Linux kernel provides automatic No Starch Press ©an 2004 (347 pages) module loader that can load most modules without additional modprobe or insmod commands. Toworkings use theofloader, the Kernel loader option in the and This guide describes the inner a Linuxenable system beginning withmodule the file system and boot process kernel configuration. A kernel withsuch the as module loader runs modprobe loaddevice modules that it wants. covering advanced topics networking, firewalls, developmentto tools, management, shell scripts, and sharing printers with Samba.

There are limits to what the module loader can do without additional configuration. In general, it can load most Table of modules Contents that do not involve specific devices. For example, the module loader can load IP tables modules, and it can Every load Super-User filesystemShould modules as long as you specify the filesystem type with a mount How Linux Works—What Know command. Chapter 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

The module loader cannot Chapter 3 - How Linux Boots

guess your hardware. For instance, the module loader will not try to figure out you need to provide extra hints with the

what kind of Ethernet card is in your system. Therefore, Chapter 4 - Essential System Files, Servers, and Utilities modprobe.conf file. - Configuring Your Network

Chapter 5 Chapter 6

- Network Services

Introduction to Shell Scripts 10.8.2--modprobe Configuration Development Tools

Chapter 7 Chapter 8

Chapter 9 - Compiling Software From/etc/modprobe.conf Source Code Themodprobe program reads

for important device information. Most entries are

Chapter 10such - Maintaining aliases as this: the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

alias eth0 tulip

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Here, the kernel loads the tulip module if you configure the eth0 network interface. In other cases, you may need to specify drivers by their major device numbers, such as this entry for an Adaptec host Chapter 17 - Buying Hardware for Linux controller: Chapter 16 - User Environments Chapter 18 - Further Directions

Appendix A - Command Classification

alias block-major-8 Bibliography

aic7xxx

Index List of Figures

Wildcards are also possible in modprobe.conf aliases. For example, if all of your Ethernet interface cards use the tulip driver, you can use this line to catch all interfaces: List of Sidebars List of Tables

alias eth* tulip

Note The module utilities discussed here are the ones that go with kernel version 2.6.0. These programs are part of the module-init-utils package. Earlier kernel versions used the modutils package. The most significant difference between the two sets of utilities is that the new package reads modprobe.conf instead of modules.conf. The syntax in both files is very similar.

Chaining Modules and the Install Keyword You can chain modules together with the install keyword. For example, if SCSI disk support isn't compiled directly into the kernel, you can force it, as in this example for /dev/sda on the Adaptec host controller from the preceding section: alias block-major-8 my_scsi_modules install my_scsi_modules /sbin/modprobe sd_mod; /sbin/modprobe aic7xxx This works as follows: 1. A process (or the kernel) tries to access /dev/sda. Assume that this device is not yet mapped to an actual device. 2. The kernel sees that /dev/sda isn't mapped to its device, which has a block major number of 8. Therefore, the kernel runs this command: modprobe block-major-8 3.

3. modprobe searches though /etc/modprobe.conf for block-major-8 and finds the alias line. How Linux Works: What Every Super-User Should Know

4. Thealias line says to look for my_scsi_modules, so modprobe runs itself, this time asISBN:1593270356 follows: by Brian Ward No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and modprobe my_scsi_modules covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

5. The new modprobe sees install my_scsi_modules in modprobe.conf, and then runs the that follow in the file. In this case, these commands are two additional modprobe How Linuxcommands. Works—What Every Super-User Should Know

Table of Contents command(s) Chapter 1

- The Basics

You can command that you in an Chapter 2 -include Devices,any Disks, Filesystems, and thelike Kernel want to try adding Chapter 3 experiment, - How Linux Boots

install line. If you need to debug something or just an echo command.

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 6

- module. Network Services

Chapter 7

- Introduction to Shell Scripts

is a Your remove keyword Note Chapter 5 - There Configuring Network

that works like install but runs its command when you remove a

Module- Development Options Tools

Chapter 8 Chapter 9

- Compiling Software From Source Code

Kernel10modules can the take various Chapter - Maintaining Kernel

parameters with the options keyword, as shown in this example for a SoundBlaster 16: Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter - Backups alias13 snd-card-0

snd-sb16

Chapter 14 - Sharing Files with Samba options snd-sb16 port=0x220 Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

irq=5 dma8=1 dma16=5 mpu_port=0x330

How Linux Works: What Every Super-User Should Know Chapter 11: Configuring and Manipulating Peripheral by Brian Ward No Starch Press Devices This guide describes the inner workings of a Linux system beginning with the file system and boot process and

ISBN:1593270356

© 2004 (347 pages)

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

This chaptersharing coversprinters various peripheral devices that may be attached to your computer. Although compiling with Samba. and installing the low-level drivers for your kernel are the first steps in getting any device including peripherals working, you may also need additional utilities or servers to do anything useful with the device. Table of Contents How Linux Works—What Every Super-User Should Know

A great deal of the work involved when configuring peripherals is digging through kernel log messages to - The Basics see exactly how the kernel assigns a device and whether the kernel recognizes the device correctly in the Chapter 2 - Devices, Disks, Filesystems, and the Kernel first place. Therefore, this chapter contains a great number of example kernel messages that you can use Chapter 3 - How Linux Boots as a guide for your own installation. Chapter 4 - Essential System Files, Servers, and Utilities Chapter 1

Chapter 5

- Configuring Your Network

- Network Services 11.1Floppy Drives

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter - Development Tools When8working with a PC floppy

drive, you must remember that it is one of the most unreliable pieces of mount the first floppy drive using the device /dev/fd0, but Chapter 10 be - Maintaining the because Kernel this can dangerous, the kernel will not like any hardware errors. Using the mtools programs is Chapter - Configuring Manipulating Peripheral Devices a good11alternative toand mounting the filesystem directly. Chapter 9 - that Compiling Software Code hardware you can find From on a Source PC. You can

Chapter 12 - Printing

The mtools programs Chapter 13 - Backups

look like their MS-DOS counterpart commands with an m at the beginning. For a directory listing.

example, canFiles usewith mdir for Chapter 14 - you Sharing Samba Chapter 15 - Network File Transfer

To copy file from a floppy Chapter 16 a - User Environments

disk to the current directory, run this command:

Chapter 17 - Buying Hardware for Linux Chapter - Further Directions mcopy18 a:file . Appendix A - Command Classification Bibliography

Copying Index

files from the local system to the disk is similar:

List of Figures List of Tables mcopy file

a:

List of Sidebars

You can also format a floppy with an MS-DOS filesystem using the mformat command: mformat a:

For more options and commands, refer to the mtools(3) manual page.

11.1.1Floppy Images Sometimes it's more convenient to copy the entire image of a floppy disk to a file on your hard disk than it is to deal with individual floppy disk operations. You can perform the extraction with dd: dd if=/dev/fd0 of=image_file bs=512

You might be able to make the extraction go a little faster by changing the bs parameter to 32k. After you have the image file, it's convenient to mount the image file on your system with a loopback block device. This example mounts an image of an MS-DOS filesystem: mount -t vfat -oloop=/dev/loop0 image_file mount_point

Warning Remember to unmount the image file after you finish, especially if you plan to alter the filesystem in the image.

11.1.2Low-Level Formatting a Floppy Disk

If you absolutely need to write to a floppy disk, but you keep getting I/O errors, you can try to format a disk with the superformat program (which is part of the fdutils package) or with fdformat. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 11.2CD How Writers by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347with pages) Linux CD burning programs work ATAPI devices and generic SCSI devices, such as /dev/hdc and inner workings CD of a recording Linux system beginning with the file system and boot process and /dev/sg0. This The guide mostdescribes popularthe command-line utility for Linux is named cdrecord.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Most CD burners on the market are ATAPI devices. At one time, Linux supported these devices with an IDE-to-SCSI emulation driver called ide-scsi. However, with Linux kernel version 2.6, this is no longer Table of Contents necessary, and the ide-scsi driver may not work well in newer kernel releases. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

11.2.1-Verifying the Hardware Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

Before4 trying to write a CD, you should verify that Chapter - Essential System Files, Servers, and Utilities

the CD recorder drive exists and determine its device devices, locating the device is easy; just use the standard device name for the6 entire disk Services (for example, /dev/hdc; see Section 2.3.4 for more information). Chapter - Network name 5and specification. IDE Chapter - Configuring Your For Network Chapter 7

- Introduction to Shell Scripts

Chapter 9

- Compiling Software From Source Code

You can the existence Chapter 8 -verify Development Tools

and identity of a device with the -inq option to cdrecord. For example:

Chapter 10 - Maintaining the Kernel cdrecord -inq dev=device Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

If there an ATAPI Chapter 13is- Backups

device at device, the output of the cdrecord -inq command looks like this:

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Device type : Removable CD-ROM Version : 0 Chapter 17 - Buying Hardware for Linux Response Format: 1 Chapter 18 - Further Directions Vendor_info : 'PLEXTOR ' Appendix A - Command Classification Identifikation : 'CD-R PX-W4012A' Bibliography Revision : '1.01' Index Device seems to be: Generic mmc CD-RW. Chapter 16 - User Environments

List of Figures List of Tables List of Sidebars You can search

for a SCSI CD recorder device with this command:

cdrecord -scanbus

The output should look something like the following: scsibus0: 0,0,0 0,1,0 0,2,0 0,3,0 0,4,0 0,5,0 0,6,0 0,7,0

0) 1) 2) 3) 4) 5) 6) 7)

* * * * 'HP ' 'C1533A ' '9503' Removable Tape 'PLEXTOR ' 'CD-R PX-R412C ' '1.04' Removable CD-ROM * *

A Linux SCSI device has a bus (for the host controller), a target, and a LUN (Logical Unit Number). Take a close look at the bold terms in the preceding output; these are the bus, target, and LUN numbers. You can see that the SCSI bus is 0, the target of the burner (a Plextor drive) is 5, and the LUN is 0. Therefore, the device you need to know is 0,5,0. Most burner devices do not have multiple units, so you can abbreviate the device to 0,5. If you know the generic SCSI /dev/sg* device name of your CD-ROM, you can use that in place of the three-part numeric identifier. Look for messages like the following in your kernel logs to identify the generic device name. In this example, the device is /dev/sg1: Vendor: PLEXTOR Model: CD-R PX-R412C Rev: 1.04 Type: CD-ROM ANSI SCSI revision: 02 sr0: scsi3-mmc drive: 12x/12x writer cd/rw xa/form2 cdda caddy Attached scsi CD-ROM sr0 at scsi0, channel 0, id 5, lun 0

Attached scsi generic sg1 at scsi0, channel 0, id 5, lun 0,

type 5

How Linux Works: What Every Super-User Should Know by Brian Ward 11.2.2Creating a Filesystem Image and Writing a CD No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

To burn a CD, you need to create a new image of the filesystem to burn, then writemanagement, that imageshell to the CD and covering advanced topics such as networking, firewalls, development tools, device scripts, writer. You can do printers this either a temporary disk image file or in a pipeline. sharing withwith Samba.

Using a Temporary Disk Image

Table of Contents

How Linux Works—What Every Super-User Should Know

ISO9660 the original Chapter 1 - is The Basics

standard CD-ROM filesystem format that most CD-ROMs use.

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

To create an ISO9660 filesystem image from a directory on a Linux system, use mkisofs, like this:

mkisofs -r -o image.iso Chapter 5 - Configuring Your Networkdirectory Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

The-r8 option enablesTools the Rock Chapter - Development

Ridge extensions that transform the stark ISO9660 filesystem into one should use this for any CD-ROM that you intend for use on Unix systems. (For Microsoft Chapter 10 - Maintaining the Kernel systems, you may want to consider using -J for the Joliet extensions.) that looks more likeSoftware a Unix From filesystem. You Chapter 9 - Compiling Source Code

Chapter 11 - Configuring and Manipulating Peripheral Devices

You can write an image to the burner with cdrecord:

Chapter 12 - Printing

Chapter 13 - Backups

cdrecord -v dev=device Chapter 14 - Sharing Files with Sambaspeed=speed

image.iso

Chapter 15 - Network File Transfer Chapter 16 - User Environments

You can a cdrecord command Chapter 17 -test Buying Hardware for Linux

with the -dummy argument; this performs a recording run with the

burning off.Directions Chapter 18 laser - Further Appendix A - Command Classification

Before writing an image to a CD, you may also wish to test it with the loopback device (just remember to unmount it when finished!): Index Bibliography

List of Figures

mount -r List of Tables

-t iso9660 -oloop=/dev/loop0 image.iso /mnt

List of Sidebars

Using a Pipeline If you don't want to create a temporary image file, you can attempt to create the filesystem and write to the CD device in one pipeline: mkisofs -r directory | cdrecord -v dev=device speed=speed -

The only problem you may encounter with this is a buffer underrun, where mkisofs can't produce data quickly enough for cdrecord to consume. If you run into a problem like this, one possible remedy is to lowerspeed, or you can see if there are any other processes on your system that are hogging the CPU.

How Linux Works: Every Super-User Should Know 11.3Introduction toWhat USB by Brian Ward

ISBN:1593270356

No Starch © 2004 pages) Linux supports a widePress variety of(347 USB (universal serial bus) devices. A USB system on a PC consists of a Thisinside guide describes the inner hubs workings a Linux system beginning with more the fileports, systemand andthe bootactual processUSB and host controller your computer, thatofact as splitters to give you covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and devices. Thesharing Linuxprinters kernel with supports USB devices through three types of drivers: Samba.

Host interface drivers

Table of Contents

How Linux Works—What Every Super-User Should Know USB device drivers Chapter 1

- The Basics

ChapterOther 2 - Devices, Filesystems, related and the Kernel driversDisks, not necessarily to USB, ChapterUSB 3 - mass How Linux Bootsdriver storage Chapter 4

but required by a USB device driver (for example, the requires the SCSI disk support driver)

- Essential System Files, Servers, and Utilities

When5the- Configuring host interface Chapter Your driver Networkrecognizes Chapter 6

a controller, the kernel logs messages such as these:

- Network Services

Chapter 7 - Introduction to Shell ohci_hcd: 2003 Oct 13Scripts USB

1.1 'Open' Host Controller (OHCI) Driver (PCI) irq 9, pci mem d4806000 Chapter 9 - Compiling Software Fromnew Source Codebus registered, assigned bus number 1 ohci_hcd 0000:00:02.0: USB Chapter 10 - Maintaining thehub Kernelfound hub 1-0:1.0: USB Chapter 11 - Configuring and Manipulating Peripheral Devices hub 1-0:1.0: 2 ports detected Chapter 8 - Development Tools ohci_hcd 0000:00:02.0:

Chapter 12 - Printing Chapter 13 - Backups

Notice14that the controller an Chapter - Sharing Files with has Samba

integrated hub with two ports. Plugging in external hubs yields kernel

messages like theFile following: Chapter 15 - Network Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux hub 1-0:1.0: new USB device

on port 2, assigned address 3 found Appendix A - Command hub 1-2:1.0: 4 Classification ports detected Chapter 18 - Further Directions hub 1-2:1.0: USB hub Bibliography Index List of Figures List of Note TablesDon't List of Sidebars the

be surprised if you see hub-related log messages when plugging in a USB device, even if device is not a hub. Some of these devices contain hubs.

When you plug in a USB device, the kernel asks the various device drivers if they know how to talk to the device. If a driver recognizes the device, it can claim the device and take over its management.

11.3.1USB Device Filesystem and Utilities With the usbdevfs filesystem mounted at /proc/bus/usb on your system, you can take a look around this directory to see the details of the devices that are connected to your system. However, you can also get a short summary with the lsusb command from the usbutils package: Bus Bus Bus Bus

001 001 001 001

Device Device Device Device

005: 003: 002: 001:

ID ID ID ID

054c:002d 0451:2046 046d:c00c 0000:0000

Sony Corp. MSAC-US1 MemoryStick Reader Texas Instruments TUSB2046 Hub Logitech Inc. Optical Wheel Mouse Virtual Hub

If you want to see the gory details of all of your devices, run lsusb -v. Be warned, though, that this prints an extremely verbose listing.

11.3.2USB Input Devices Basic USB keyboard and mouse support is not complicated. To use these devices on your system, you need the USB human input device (HID) driver in your kernel. The relevant kernel log message looks like this: drivers/usb/input/hid-core.c: v2.0:USB HID core driver

With this in place, any USB keyboard that you plug into your computer should work with no further configuration. Here is the message that the kernel logs when you plug in an old Apple keyboard:

input: USB HID v1.00 Keyboard [Alps Electric Apple USB Keyboard] on usb-0000:00:02.0-2.1 How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

USB mice aren't much more difficult to configure; the only thing you need to do is to tell the X server or This guide describes the inner workings of a Linux system beginning with the file system and boot process and gpm where to find a advanced USB mouse at networking, your /etc/X11/XF86Config file device and grep for gpmshell in your covering topics(look such as firewalls, development tools, management, scripts, and sharing printers with Samba. init.d directory). The kernel maps all mice to /dev/input/mice, using the PS/2 mouse driver. The kernel message that results from the hookup of a new mouse looks like this: Table of Contents How Linux Works—What Super-User Know input: USB HID Every v1.10 MouseShould [Logitech Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

USB Optical Mouse] on usb-0000:00:02.0-1

11.3.3-USB Digital Cameras, External Flash Media, and External Configuring Your Network Chapter 6 - Network Services Disks Chapter 7 - Introduction to Shell Scripts Chapter 5

Chapter 8

- Development Tools

Linux accesses external USB storage devices, including flash memory, in blocks, presenting the storage - Compiling Software From Source Code as a SCSI disk. Therefore, you need the following drivers in your kernel if you would like to use such a Chapter 10 - Maintaining the Kernel device: Chapter 9

Chapter 11 - Configuring and Manipulating Peripheral Devices ChapterSCSI 12 - Printing disk support,

compiled directly into your kernel or as the sd_mod kernel module

Chapter 13 - Backups ChapterA14 - Sharing Files driver with Samba USB interface (see

Section 11.3)

Chapter 15 - Network File Transfer

storage support, ChapterUSB 16 - mass User Environments

compiled directly into your kernel or as the usb-storage module

Chapter 17 - Buying Hardware for Linux

Assuming that you have all Chapter 18 - Further Directions

of the drivers in place, you should see a kernel log message proclaiming that there is a new SCSI bus when Appendix A - Command Classification you plug in a flash media card device or other external mass storage device: Bibliography Index List of Figures scsi1 : SCSI

emulation for USB Mass Storage devices Sony Model: MSAC-US1 Rev: 1.00 List of Sidebars Direct-Access Type: ANSI SCSI revision: 02 SCSI device sda: 15840 512-byte hdwr sectors (8 MB) sda: Write Protect is off sda: Mode Sense: 00 06 00 00 sda: assuming drive cache: write through sda: sda1 Attached scsi removable disk sda at scsi1, channel 0, id 0, lun 0 Attached scsi generic sg2 at scsi1, channel 0, id 0, lun 0, type 0 List of Tables Vendor:

Upon disconnecting the device, you will see a message like this: usb 1-2.1: USB disconnect, address 4 Seeing the new SCSI bus in the kernel log does not necessarily mean that you have access to the attached USB device. If your system does not have hotplug support, you may need to run a script called rescan-scsi-bus.sh to get the kernel to recognize the new device. You can verify the geometry, partitions, and filesystems on the storage device with an fdisk command such as this: fdisk -l /dev/sda

Flash Memory Filesystem Issues The flash memory in most digital cameras contains an MS-DOS filesystem that you can easily mount when you see the device in the kernel logs. Warning You may wish to mount the filesystem in read-only mode, because it is too easy to remove flash media cards and devices before unmounting the filesystem. If you alter the filesystem, then remove the card before flushing the changes to the physical media with an unmount operation, you risk data corruption.

How Linux Works: What Every Super-User Should Know 11.4IEEE 1394/FireWire Disks by Brian Ward

ISBN:1593270356

No Starch Press 2004 (347 pages) IEEE 1394 (also known as© FireWire) drivers are relatively new to Linux. The Linux IEEE 1394 driver system is This describes the inner of akernel Linux system beginning with the file system the and boot and similar to that ofguide the USB system, andworkings the Linux support for IEEE 1394 includes baseprocess module advanced topics such as networking, firewalls, development tools, device management, shell scripts, and (ieee1394)covering and host interface drivers. One common interface is OHCI-1394 (which has a module name of sharing printers with Samba. ohci1394), and the TI PCILynx interface also has a driver (pcilynx). Table of Contents

Kernel messages like the following indicate that the host interface driver detected the hardware:

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

ohci1394_0: OHCI-1394 1.1 (PCI): IRQ=[26] MMIO=[9006000-90067ff] Max Packet=[2048] - Devices, Disks, Filesystems, and the Kernel ieee1394: Host added: ID:BUS[0-00:1023] GUID[0001080020005cb4] Chapter 3 - How Linux Boots Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

IEEE 1394 hard disks use SBP-2 (Serial Bus Protocol). As in the USB mass storage code, the Linux sbp2 - Network Services driver masquerades as a SCSI host controller. When you plug in a drive, look for these kernel messages:

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

scsi09 Chapter

:- Compiling SCSI emulation IEEE-1394 SBP-2 Devices Software Fromfor Source Code ieee1394: sbp2: the Logged Chapter 10 - Maintaining Kernel into SBP-2 device ieee1394: sbp2: and Node 0-02:1023: speed [S400] - Max payload [2048] Chapter 11 - Configuring Manipulating PeripheralMax Devices ieee1394: Node added: ID:BUS[0-02:1023] GUID[0090a95000001796] Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

If your15system does have Chapter - Network Filenot Transfer

hotplug support (see Section 11.5), you may need to probe the SCSI bus with therescan-scsi-bus.sh script described earlier in order to get the kernel to recognize the IEEE 1394 drive. 17 Upon recognizing drive, the kernel emits the usual SCSI drive messages: Chapter - Buying Hardwarethe for Linux Chapter 16 - User Environments Chapter 18 - Further Directions

Vendor: WDC Classification Model: Appendix A - Command

FireWire/USB2.0 Rev: 4.17 Direct-Access ANSI SCSI revision: 06 blk: queue fffffc001954b928, no I/O memory limit Index Attached List of Figures scsi disk sda at scsi0, channel 0, id 0, lun 0 SCSI device sda: 234441648 512-byte hdwr sectors (120034 MB) List of Tables sda1 sda2 Listsda: of Sidebars Type: Bibliography

Note The Apple iPod is an SBP-2 device. To access the disk and its filesystem, you need appropriate filesystem support and possibly also the appropriate partition table support in your kernel. The PC version of the iPod uses the FAT32 filesystem, so you can use the vfat filesystem. The Macintosh version uses a completely different filesystem type, so you need the Macintosh partition map support in your kernel, as well as Macintosh filesystem (HFS) support as a module or compiled directly into the kernel.

How Linux Works: What Every Super-User Should Know 11.5Hotplug Support by Brian Ward

ISBN:1593270356

No Starch PressLinux © 2004USB (347 pages) Now that we've covered and IEEE 1394 support, you should learn a little about Linux hotplug This guide the inner of aconfiguration Linux system beginning with the systemwhen and boot and support, a system thatdescribes can handle theworkings automatic and cleanup of file devices youprocess plug them covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and into the system. sharing printers with Samba.

The idea is simple; the kernel runs /sbin/hotplug when you plug in a device. Here's the procedure: Table of Contents

1. You plug in aEvery device. The kernel notices. How Linux Works—What Super-User Should Know Chapter 1

- The Basics

2. The kernel runs /sbin/hotplugtype, where type is the device type (usb,ieee1394,scsi, - Devices, Disks, Filesystems, and the Kernel and so on). The kernel sets a number of device-related environment variables in the new hotplug Chapter 3 - How Linux Boots process. Chapter 4 - Essential System Files, Servers, and Utilities Chapter 2

Chapter 5

- Configuring Your Network 3. The /etc/hotplug script runs /etc/hotplug/type.agent.

Chapter 6

- Network Services

Chapter - Introduction to Shell Scripts 4. 7The /etc/hotplug/type.agent Chapter 8

script tries to configure the device.

- Development Tools

Chapter - Compiling Software From There9really isn't much more to itSource than Code this. Chapter 10 - Maintaining configuring devices. the ForKernel example,

Each device type's .agent file has its own method of usb.agent goes through these steps:

Chapter 11 - Configuring and Manipulating Peripheral Devices

1. usb.agent looks in /etc/hotplug/usb.distmap and /etc/hotplug/usb.usermap to locate a kernel module for the devices.

Chapter 12 - Printing

Chapter 13 - Backups

Chapter - Sharing Files withaSamba 2. 14Having identified module,

usb.agent attempts to load the module.

Chapter 15 - Network File Transfer Chapter - User Environments 3. 16If /etc/hotplug/usb/type

exists, usb.agent runs that program.

Chapter 17 - Buying Hardware for Linux Chapter - Further Directions Linux 18 hotplug is almost entirely

script-driven, which means that the details are even more subject to keep in mind that if you ever have problems or questions you can Bibliography always read the hotplug scripts to determine what they are trying to do, even if the documentation is Index inadequate or out of date. Appendix - Command Classification changeAthan the rest of Linux. However,

List of Figures List of Tables List of Sidebars

Linux (PCMCIA) Works: What Every Super-User Should Know 11.6PC How Cards by Brian Ward

ISBN:1593270356

No Starch Press 2004 (347 pages) Linux PCMCIA support is ©highly dependent on kernel versions. If you upgrade your kernel, you almost Thistoguide describes inner workings of a Linux system beginning with the file system and boot process and certainly need upgrade yourthePCMCIA drivers and tools.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Although some of the core PCMCIA drivers are in the main Linux kernel distribution, you still need the pcmcia-cs package for additional drivers and system utilities. The components of the PCMCIA system Table of Contents include the following: How Linux Works—What Every Super-User Should Know ChapterKernel 1 - The Basics modules

for PC Card interface controllers and individual PC Cards. These modules go in

Chapter/lib/modules/version/pcmcia. 2 - Devices, Disks, Filesystems, and the Kernel Chapter 3

- How Linux Boots

daemon forand managing ChapterThe 4 /sbin/cardmgr - Essential System Files, Servers, Utilities Chapter 5

support utilities ChapterVarious 6 - Network Services Chapter 7

configuration when you insert or remove a card.

- Configuring Your Network

and services, located in /etc/pcmcia and /sbin.

- Introduction to Shell Scripts

There are- Development too many pieces of the system to set up and configure by hand, so the pcmcia-cs package Tools provides several scripts to get you on your way. The most important of these is an init.d script called Chapter 9 - Compiling Software From Source Code pcmcia, where, depending on your distribution, you may need to modify a few lines to specify which Chapter 10 - Maintaining the Kernel PCMCIA interface controller chipset you have. Look at this section: Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 8

Chapter 12 - Printing Chapter 13 - Backups # Source PCMCIA

configuration, if available ] ; then Chapter # 15 Debian - Network startup File Transfer option file Chapter . 16 /etc/pcmcia.conf - User Environments elif 17 [ --f /etc/sysconfig/pcmcia ] ; then Chapter Buying Hardware for Linux HatDirections startup option file Chapter # 18 Red - Further . A/etc/sysconfig/pcmcia Appendix - Command Classification else Bibliography Index # Slackware startup options go right here: # Should be either i82365 or tcic List of Figures PCIC=i82365 List of Tables # Put socket driver timing parameters here List of Sidebars PCIC_OPTS= # Put pcmcia_core options here CORE_OPTS= # Put cardmgr options here CARDMGR_OPTS= # To set the PCMCIA scheme at startup... SCHEME= fi if [ 14 -f- Sharing /etc/pcmcia.conf Chapter Files with Samba

The mention of specific Linux distributions may seem confusing, so step back and recall your shell script essentials from Chapter 7. The script does the following checks and actions: 1. If /etc/pcmcia.conf exists, the script reads configuration details from there and skips past the fi. This is probably the case if you're running Debian GNU/Linux. 2. If step 1 fails, the script looks for /etc/sysconfig/pcmcia, which is the location of the pcmcia file in Red Hat Linux. 3. If steps 1 and 2 both fail, the script directly sets PCIC,PCIC_OPTS, and so on. Note that this may apply to distributions other than Slackware Linux. To get cardmgr talking to your PCMCIA interface controller, you should only need to set the PCIC variable. Check through your init.d and /etc files to find the file in which you need to set this variable (every distribution is different, so using grep PCIC may come in handy). If you don't know what sort of hardware you have, there is a pcic_probe program that comes with the pcmcia-cs source code that can help you. The value of PCIC should match one of the module filenames in /lib/modules/version/pcmcia; it's typically something like i82365 or tcic. With the correct PCIC setting in place, you can manually load the interface controller driver and start cardmgr with this command: pcmcia start

How Linux Works: What Every Super-User Should Know

However, because pcmcia is an init.d script, you should create rc.d links to start and stop the ISBN:1593270356 by Brian Ward PCMCIA services at boot ©and No Starch Press 2004shutdown (347 pages) time (refer back to Section 3.1 if you're a little hazy on this process). This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

11.6.1When You Insert a Card Table of Contents

Thecardmgr program reads configuration data and activates scripts in /etc/pcmcia in response to cards being inserted and removed. The central card configuration database is /etc/pcmcia/config.

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel When you insert a PC Card, cardmgr does the following:

Chapter 3

- How Linux Boots

Chapter 5

- Configuring Your Network

1. 4It -reads theSystem deviceFiles, identifier information Chapter Essential Servers, and Utilitiesfrom

the PC Card.

2. It looks up the identifier in /etc/pcmcia/config, retrieving the kernel module name that contains - Network Services the device driver. Chapter 7 - Introduction to Shell Scripts Chapter 6 Chapter 8

Development Tools 3. It -matches the kernel module name with a class name in /etc/pcmcia/config.

Chapter 9

- Compiling Software From Source Code

Chapter Maintaining the Kernel 4. 10It -loads the kernel module(s)

and configures the PC Card with respect to the local options in

Chapter 11 - Configuring and Manipulating Peripheral Devices /etc/pcmcia/config.opts. Chapter 12 - Printing Chapter 5. 13It -runs Backups a class

script located in the /etc/pcmcia directory, corresponding to the class name it

Chapter 14 found - Sharing in /etc/pcmcia/config. Files with Samba Chapter 15 - Network File Transfer

/etc/pcmcia

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

Let's look the /etc/pcmcia Chapter 18 - at Further Directions

directory in more detail. Each kernel module has one or more matching PC file. For example, here is an entry that matches the 3c589_cs module against its vendor and version identifier strings: Bibliography Card definitions in the /etc/pcmcia/config Appendix A - Command Classification Index List of Figures card "Lucent

Technologies WaveLAN Adapter" "Lucent Technologies", "WaveLAN/PCMCIA" List of Sidebars bind "wavelan_cs" List of Tables version

Thebind in the last line means to bind the card definition to one or more kernel modules. However, the card definition does not always specify that version of the hardware. cardmgr can also identify the appropriate kernel module by using other hardware criteria, including the function parameter, as in this example: card "ATA/IDE Fixed Disk" function fixed_disk bind "ide_cs" Well-defined device interfaces such as disks, serial ports (modems), and flash memory usually have a function parameter, but don't expect this from all devices. In particular, Ethernet cards usually don't have a function parameter. You may also see manual device-identifier matches that use the manfid keyword. Having identified the necessary kernel module(s), cardmgr then looks for the device driver module class, which are found in the first part of /etc/pcmcia/config. Here is a sample definition that maps wavelan_cs to the network driver class: device "wavelan_cs" class "network" module "wavelan_cs" Each driver class has a script in /etc/pcmcia that cardmgr runs after loading and configuring a card's module (you'll see more about class scripts shortly).

Configuration Options You should not modify /etc/pcmcia/config; instead, enter your local configuration data in

/etc/pcmcia/config.opts (cardmgr usually reads this file after config). For the most part, the PCMCIA utilities should work fine with the default settings, but the machine-and card-specific options in config.opts at your disposal if yourSuper-User hardware Should just won't behave. Howare Linux Works: What Every Know by Brian Ward

ISBN:1593270356

Of particularNo interest are the exclude Starch Press © 2004 (347 pages)and include keywords that enable you to manually specify IRQs and addresses. For example, you will see the following lines to prevent cardmgr from using standard This guide describes the inner workings of a Linux system beginning with the file system and boot process and IRQs, regardless of advanced what thetopics kernel may say about firewalls, their availability: covering such as networking, development tools, device management, shell scripts, and sharing printers with Samba.

# First built-in serial port 4

Table of Contents exclude irq

How Linux Works—What Every Super-User Should Know Chapter 1 - The Basics # First built-in

parallel port

Chapter 2 - Devices, exclude irq 7 Disks, Filesystems, and the Kernel Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 -specify Configuring Your Network You can per-module options

with the module keyword. These examples are also from the default

Chapter 6 - Network Services config.opts file: Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

module "ray_cs" opts "net_type=1 essid=ESSID1"

Chapter 10 - Maintaining the Kernel

module "wvlan_cs" opts "station_name=MY_PC"

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - In Sharing Files with Samba normal circumstances,

Note

Chapter 15 - with Network File Transfer iwconfig and

you do not configure wireless options with config.opts, but rather, possibly /etc/pcmcia/wireless.opts (see Section 5.15 for more

Chapter 16 - User Environments

information).

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Auxiliary Configuration Scripts

Appendix A - Command Classification Bibliography Each driver

class has a script in /etc/pcmcia. For example, the /etc/pcmcia/ network script to the network class mentioned earlier. cardmgr runs the class script after loading and List of Figures configuring a card's module. Index corresponds List of Tables

List of /etc/pcmcia Sidebars The

configuration scripts work like init.d boot scripts, taking an argument to start, stop, reload, or perform other actions: start Activates the device upon card insertion stop Deactivates the device upon card removal restart Reinitializes the device check Verifies the device suspend Deactivates a card, but leaves the driver running resume Picks up at the point where suspend left off, if possible Just because a script exists in /etc/pcmcia doesn't mean that it actually works. These scripts run through several combinations of distribution-specific configuration files, trying to find the right settings. If your PC Card doesn't auto-configure correctly upon insertion, you may need to modify one of the scripts or its corresponding .opts configuration file. Warning You may find it easiest to write your own driver class scripts or modify the existing ones, but remember to make a backup of any script you decide to change. Reinstalling the pcmciacs package overwrites each script in /etc/pcmcia (leaving a backup with a .O extension). The.opts configuration files remain in place during a reinstall. You should not normally need to call one of the /etc/pcmcia scripts by hand. cardmgr and cardctl (discussed next) do this for you.

11.6.2cardctl How Linux Works:you What Super-User Know information about cards and sockets. Thecardctl utility enables to Every alter card settingsShould and display ISBN:1593270356 by Brian Ward For example, you can view PC Card identifiers with this command: No Starch Press © 2004 (347 pages)

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

runas cardctl coveringident advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Theofoutput looks Table Contents

similar to this:

How Linux Works—What Every Super-User Should Know Chapter 1 -0: The Basics Socket Chapter 2 - Devices, Disks, Filesystems, and the Kernel product info: "Lucent Technologies",

"WaveLAN/IEEE", "Version 01.01", ""

Chapter 3 - How0x0156, Linux Boots 0x0002 manfid: Chapter 4 - Essential Files, Servers, and Utilities function: 6 System (network) Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Notice7 how this information Chapter - Introduction to Shell relates Scripts Chapter 8

to the configuration data in /etc/pcmcia/config.

- Development Tools

Here are other cardctl Chapter 9 -some Compiling Software Fromcommands: Source Code Shows the detailed Chapterconfig 10 - Maintaining Kernellow-level

hardware settings.

Chapter 11 - Configuring and Manipulating Peripheral Devices

Displays Chapterstatus 12 - Printing

card or socket status.

Chapter 13 - Backups

socket Shuts down Chaptereject 14 - Sharing Files with Samba

the card in socket (use ident to identify the socket number). You should run eject on certain cards, such as SCSI cards and other interfaces that take a long time to Chapter 15 - Network File Transfer removing them. Chapterinitialize, 16 - User before Environments Chapter 17 - Buying Hardware for Linux

insertsocket Tells any relevant drivers that you just put a card into socket. Like eject, this is notA necessary most cards. Appendix - Command for Classification Chapter 18 - Further Directions Bibliography Index

suspendsocket Attempts to freeze the driver for socket and cut the power.

List of Figures

resumesocket Attempts to recover from a suspend operation.

List of Tables

List of Sidebars reset

socket Resets the card in socket.

There are a few more complex options for cards that need to operate in multiple environments (schemes); see the cardctl(8) manual page and the PCMCIA-HOWTO for more information. Note Mostpcmcia-cs builds also come with cardinfo, a GUI display of the PCMCIA configuration. You may prefer to run this application in place of information commands such as cardctl status.

How Linux Works: What Every Super-User Should Know 11.7Approaching Other Devices by Brian Ward

ISBN:1593270356

No Starch Press 2004 (347 that pages)you can attach to your PC is enormous, and attempting to write a Obviously, the number of ©devices guideall describes of a Linux system beginning withyou the just file system andabout boot process chapter that This covers of themtheisinner nextworkings to impossible. However, with what learned SCSI, and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and USB, PCMCIA, and IEEE 1394, along with what you will learn about printers in Chapter 12 , Ethernet sharing printers with Samba. interfaces, and so on, you should be well equipped to take on almost anything. For example, you know how to identify a USB scanner; it's just a matter of installing the appropriate drivers and software (the most Table of Contents popular Unix scanning system is called SANE, if you are interested). How Linux Works—What Every Super-User Should Know Chapter 1

This book- The isn'tBasics finished with devices just yet, though. In particular, Chapter 13 has information about tape - Devices, Disks, Filesystems, and the Kernel drives, and Chapter 17 contains tips on how to purchase hardware so that you can avoid Linux Chapter 3 - How Linux Boots compatibility nightmares. Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 12: Printing by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

The printing process on Unix works roughly as follows: An application Table 1. of Contents

generates a document to print.

How Linux Works—What Every Super-User Should Know

2. 1You or Basics the application Chapter - The

sends the document to a print server by means of a print client program.

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

3. The print server puts the document on a queue.

Chapter 4

- Essential System Files, Servers, and Utilities 4. When it is the document's turn to print, the print server sends the document through a print filter Chapter 5 - Configuring Your Network program. Chapter 6

- Network Services

Chapter - Introduction Shell Scripts 5. 7The print filtertochanges the Chapter 8

document to make it acceptable to a printer.

- Development Tools

6. 9If -the printerSoftware does not understand PostScript Chapter Compiling From Source Code filter must rasterize the Chapter 10 - Maintaining the Kernel

(the standard document format in Unix), another print document into a bitmap form that the printer understands.

Chapter 11 - Configuring and Manipulating Peripheral Devices

7. 12The print server Chapter - Printing

sends the result to the printer device.

Chapter 13 - Backups

Making your printer work on a Unix system can be a trying experience. There are several problems:

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

There are few standards.

Chapter 16 - User Environments

ChapterEach 17 - Buying Hardware for Linux stage of the process can

present any number of errors.

Chapter 18 - Further Directions Appendix A - Command Classification There are several different

client, server, and filter packages for printing.

Bibliography Index

It's sometimes difficult to determine the purpose of each printing system component.

List of Figures

The existing List of Tables

software never seems quite satisfactory, so upgrades are frequent.

List of Sidebars

Security holes run rampant in network print servers.

There are two basic ways to configure network printing: one where all computers send their documents directly to a printer, and the other where all computers send their documents to a print server, which then talks to the printer. It can be confusing when you have a network full of machines that use both approaches. With all of this said, you may not even want to bother to learn how printing works. To be perfectly honest, if your distribution's printer setup tool works for you, it may not be worth going any further, as long as you know how to firewall the print server's network port. However, when things don't work according to plan, the information in this chapter will help you find out where the problem lies. This chapter first explains the pieces of the printing system on Linux and then shows you how to put everything together using CUPS (Common Unix Printing System). The best place to start is the print code that applications create, PostScript.

How Linux Works: What Every Super-User Should Know 12.1PostScript by Brian Ward

ISBN:1593270356

No Starch 2004 (347 pages) Unix applications thatPress print© generate PostScript files as output. PostScript is not a simple file format; guide describes the inner workings of a Linux system beginning with the system and rather, it is aThis page description language. Therefore, PostScript documents arefile programs, soboot youprocess need and an covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and interpreter tosharing view or read them. Most mid-to high-end laser printers understand PostScript, as do certain printers with Samba. inkjet printers, but the cheapest printers do not. If you have such a printer (and who doesn't like to buy cheap hardware?), your computer must perform the extra step of rasterization before the document is sent Table of Contents to the printer. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics When you rasterize a PostScript file, you convert its vector graphics into a bitmap. On Linux, the - Devices, Disks, Filesystems, and the Kernel Ghostscript program does this work. Ghostscript can produce output for almost any printer on the market, Chapter 3 - How Linux Boots but it also has many other uses because it is a full-featured PostScript interpreter. See Section 12.6 for Chapter 4 - Essential System Files, Servers, and Utilities more information. Chapter 2

Chapter 5

- Configuring Your Network

Chapter Services If you 6are- Network interested in PostScript

as a programming language, PostScript Language Tutorial and introduction to the language, and PostScript Language Reference Chapter 8 [Adobe - Development Manual 1999] Tools serves as a comprehensive guide to the language features. However, if you just Chapter 9 example - CompilingPostScript Software From Code want an file Source for tests, use a Web browser's print-to-file feature. Chapter 7 - Introduction to Shell Cookbook [Adobe 1985] is aScripts good

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 12.2Print Servers by Brian Ward

ISBN:1593270356

No Starch Press © 2004 pages) There are several different Unix(347 print servers. Here are just a few: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

Berkeley LPDprinters (Line Printer Daemon) One of the oldest print servers around, this system is fairly sharing with Samba. stable, but is somewhat sparse on features and can be difficult to configure. Many network-capable printers have integrated LPD servers. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics LPRng This new spin on LPD has many new features, but in all honesty, is not any easier to - Devices, Disks, Filesystems, and the Kernel configure. You may also see a related package named PLP (Portable Line Printer).

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapterlpsched 5 - Configuring Network This isYour the System

V printing system. If you're lucky, you'll never have to see it.

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

(CommonTools Unix ChapterCUPS 8 - Development

Printing System) Sooner or later, someone was bound to get so fed up with on Unix that they wanted to rip everything to pieces. is the latest ChapterCUPS 10 - Maintaining the entry Kernel in the Unix printing field, and it may prove to be the most successful. Its and protocol departs from the older printing systems, but it still has a server (called the Chapterinternals 11 - Configuring and Manipulating Peripheral Devices and print filters. In addition, the client commands are mostly identical to the lpsched Chapterscheduler) 12 - Printing Chaptercommands, 13 - Backupswith LPD-compatible substitutes as well. state of printerFrom clients andCode daemons Chapterthe 9 ugly - Compiling Software Source

Chapter 14 - Sharing Files with Samba

This chapter concentrates on Chapter 15 - Network File Transfer

CUPS, which is quickly gaining popularity because it is definitely much than the alternatives. In particular, CUPS offers a Web-based interface for many 17 of -the more mundane printing tasks. Chapter Buying Hardware for Linux easier16 to -configure and use Chapter User Environments Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 12.3Print Filters by Brian Ward

ISBN:1593270356

No Starch Press ©Unix 2004 (347 pages) Two print filters dominate printing: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

Foomatic Thisprinters print filter works with almost any print server, and on the command line. Foomatic can sharing with Samba. call Ghostscript for printers that do not understand PostScript. Table of Contents How Linux Works—What Every Super-User Should Know

ifhp This is a general-purpose filter for PostScript printers. ifhp is an older print filter that works well - The Basics with the Berkeley LPD-style servers.

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 12.4Print Clients by Brian Ward

ISBN:1593270356

No traditional Starch Pressclients © 2004 (347 pages) There are two that send data to a print server: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

lpr This is theprinters matching sharing with client Samba.for Berkeley LPD-based servers. Associated programs include lpq (to view the current printer job queue) and lprm (to remove a job from the queue). Table of Contents How Linux Works—What Super-User Should Know lp Both CUPS Every and System V lpsched use Chaptercapability). 1 - The Basics The Chapter 2

the lp interface to print (CUPS also has limited lpr lpstat command shows printer jobs, and cancel removes a print job.

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 - How Linux Linux Boots On traditional systems,

you send a PostScript job to the printer named printer with a command to send the job to the default printer):

Chapter 4 (you - Essential System Servers, and Utilities like this do not needFiles, -Pprinter if you want Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

lpr -Pprinter file - Introduction to Shell Scripts

Chapter 7 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

For CUPS, you may also use the lp program (-dprinter is optional if you are sending to the default printer): Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 10 - Maintaining the Kernel Chapter 12 - Printing

lp -d13 printer Chapter - Backups

file

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Commands like lpr and lp Chapter 16 - User Environments

let you send any PostScript file or data pipeline directly to a printer. However, this model is that users have no idea that the print server expects PostScript (in fact, most users have no idea what PostScript is). In response, administrators change their Chapter 18 - Further Directions print filters to automatically convert plain-text input files to PostScript so that users can use lpr to send Appendix A - Command Classification either a PostScript or plain-text file to the printer without worrying about conversions. Bibliography one of17the biggest problems with Chapter - Buying Hardware for Linux

Index

Other operating systems don't usually let you get very close to the printer; instead, they make you print through an application that produces the correct output. Unix has these applications, too (such as gimp List of Tables and its gimp-print counterpart), but Unix also lets you get very close to the printer with lpr. List of Sidebars List of Figures

Users tend to want to print pictures and various other kinds of data. If you send a JPEG file or other file to a printer with lpr, it may do the right thing if the administrator set up the print filter to recognize and filter the file. More often than not, though, the print system either rejects the file or prints endless pages of junk, because the system tried to convert the binary file into PostScript using the text filter. Therefore, it is extremely important that you know where the system converts your file into PostScript. This is not a problem if you primarily use graphical applications to print, because these programs normally generate PostScript and send the result to a command such as lpr. However, if you like to use the command line, you must be very careful about what you send to the printer. CUPS is fairly smart about document conversions because it attempts to determine the MIME type of any input data before sending it to the printer. Furthermore, the system verifies that it can convert the data to something that the printer understands. If CUPS doesn't know how to convert the data, the CUPS server rejects the document rather than passing the printer data that it won't understand.

12.4.1Network Printing You should have an idea of how network printing clients send data to print servers: Berkeley LPD clients send data to TCP port 515 on a print server. CUPS uses the Internet Printing Protocol (IPP). IPP is a TCP protocol that looks like HTTP (Hypertext Transfer Protocol). The standard IPP port is 631, but CUPS also comes with a daemon that accepts the LPR protocol on port 515. Most network-ready PostScript laser printers allow you to connect to TCP port 9100 and talk directly to the print engine. Most network-aware print filters use this port to send data. Regardless of the protocol, you should be especially vigilant with respect to open network ports on print servers. Filter out or firewall any open ports. There have been serious vulnerabilities in print servers in the past, and you can expect that many more will crop up in the future, especially with a system as new as

CUPS. This also holds true for network-aware printers. You do not want an intruder to waste the money that you spend on printer supplies. How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 12.5CUPS by Brian Ward

ISBN:1593270356

No Starch Pressout © 2004 With these preliminaries of (347 the pages) way, let's look at CUPS. CUPS has several interfaces, including a Webdescribes the tool. inner The workings a Linux system beginning withnormal the file maintenance system and bootand process and based statusThis andguide administration Webofinterface is very good for operation, covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and but unfortunately, if your needs lie outside the abilities of the interface, you still have to know how the system sharing printers with Samba. works and where the various configuration files reside. Table Contents Youofcan install

CUPS anywhere you like. Most distributions use a /usr installation prefix, so the clients are in and so on. This book assumes that your directory prefix Chapter 1 Here - The Basics is/usr. are the directory locations and contents: How Linux Works—What Every Super-Userare Should Know /usr/bin, the system programs in /usr/sbin, Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots /usr/sbin The cupsd server and administration programs

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter/usr/bin 6 - Network Services User-level

clients, including lpr and lp substitutes

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Configuration Chapter/etc/cups 9 - Compiling Software From files Source Code Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

/usr/lib/cups Filters, backends, network frontends, and Web interface scripts

Chapter 12 - Printing

Chapter 13 - Backups

Printer log Chapter/var/log/cups 14 - Sharing Files with Samba

files

Chapter 15 - Network File Transfer Chapter 16 - User Environments

/var/spool/cups Spooled print jobs

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification /usr/share/cups PPD

file sources, fonts, and other program data

Bibliography Index

/usr/share/doc/cups List of Figures

Online documentation

List of Tables List of Sidebars

12.5.1Configuring cupsd The central server and scheduler in CUPS is named cupsd, and the central configuration file is cupsd.conf. You normally do not need to do anything to get a working cupsd, but a stock configuration file isn't usually very secure (see Section 12.5.2).

Examine the configuration file to get an overview of the things you can change. If you have ever configured the Apache Web server, you will immediately observe similarities between the httpd configuration files and the CUPS files. Yourcupsd.conf file contains a lot of information, but first look for the AccessLog path and change it if you want the log file in some other place: AccessLog /var/log/cups/access_log

The default IPP port is 631, so you should see the following line: Port 631

You should not need to change this. However, you may wish to add more ports with the Listen keyword. The following parameters select the user and group that run all tasks except the cupsd server. You likely do not need to change these, but you may need to add the user and group to your system: User lp Group sys

12.5.2CUPS Security

Before you start CUPS, you should get a handle on security matters. Configured and installed from source code, CUPS does not have an enviable level of security, and you should do something about that before you How Linux Works: What Every Super-User Should Know even start the server. If your CUPS installation came with a Linux distribution, you should still take a look ISBN:1593270356 Brian Ward through this by section to verify that you have a practical level of security. No Starch Press © 2004 (347 pages)

guidehow describes the inner digest workings of a Linux system beginning with the file of system and boot process and for This sectionThis covers to configure authentication, the most useful type authentication available covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and the CUPS Web administration interface. Run through the following steps on a new installation: sharing printers with Samba. 1. Scan your cupsd.conf for a section that looks like this: Table of Contents How Linux Chapter 1AuthType - The Basics Basic Chapter 2AuthClass - Devices, Disks, Filesystems, and the Kernel System Chapter 3

- How Linux Boots

Chapter 4## - Essential System Files, Servers, and Utilities Restrict access to local domain Chapter 5Order - Configuring Your Network Deny,Allow Chapter 6Deny - Network Services From All Chapter 7Allow - Introduction Shell Scripts From to127.0.0.1 Chapter 8#Encryption - Development Tools Required Chapter 9 - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

2. 13Change AuthType Chapter - Backups

Basic to AuthType Digest. Basic authentication sets up a Web browser to as plain text. As earlier in the networking chapters, this is a really bad idea.

Chapter 14 send - Sharing Unix Files userwith passwords Samba Chapter 15 - Network File Transfer

3. 16Run theEnvironments following command Chapter - User

to add an admin user to the CUPS digest password file

(/etc/cups/passwd.md5): Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix lppasswd A - Command -a Classification admin Bibliography Index List of4. Figures When

prompted, choose a password containing at least six characters and one number.

List of Tables

Certificate Authentication (for Command-Line Utilities)

List of Sidebars

You are now set up to use the CUPS W eb interface securely. However, you will inevitably turn to commandline administration programs such as lpadmin when managing CUPS. These utilities also require authentication because they operate through the same network port as the Web interface. However, you may notice that you don't need a password to run these command-line programs as the superuser. Why is this so? The answer is that CUPS has another form of authentication called certificate authentication, used primarily by the command-line programs and internal server communication. The CUPS scheduler places identifiers in the certificate directory /etc/cups/certs for various purposes, but the one you care most about is /etc/cups/certs/0. Any user that can read this file can run administrative programs without a password, because these programs send the certificate instead of a username and password. Note Don't use chmod to allow administrative access for non-root users because you may inadvertently allow administrative access for anyone on the system. Instead, add the desired users to the Unix group specified by the Group directive from Section 12.5.

12.5.3Starting CUPS With your security situation now under control, you're ready to start the CUPS scheduler and add some printers. To start CUPS, all you need to do is run cupsd as the superuser. If you compile CUPS from source code, you should take careful note that the install procedure modifies your init.d and rc.d boot directories to make CUPS part of your startup sequence. To test your installation, access the Web interface by pointing a W eb browser to CUPS at this URL (notice that this is the IPP port on your machine): http://localhost:631/ This should yield a screen with several printing options. There are no printers in a new CUPS installation, so adding a printer is your first order of business.

12.5.4Adding and Editing Printers How Linux Works: What Every Super-User Should Know

The easiest by way to add printer list Brian Warda printer is with the W eb interface (there is an AddPrinter button on the ISBN:1593270356 page). The first time Press you try to do administration task, CUPS asks you for a username and password. Use No Starch © 2004 (347any pages) theadmin user thatinner youworkings configured in Section This and guidepassword describes the of a Linux system12.5.2. beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. To add a printer with the command-line interface, use the lpadmin command. The bare minimum command for adding a printer without a print filter is as follows: Table of Contents How Linux Works—What lpadmin -p nameEvery -v Super-User device Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 - How Depending on Linux your Boots configuration, Chapter 4

you may need the -E option to specify encryption.

- Essential System Files, Servers, and Utilities

Chapter 5

Your Network Adding- Configuring a Test Printer

Chapter 6

- Network Services

Chapter 7 -case Introduction to Shell Scripts As is the with most Unix utilities,

commands like lpadmin do nothing more than modify text files (except opens a network connection to the CUPS server, sends some data, and then the Chapter - Compiling Fromshould Sourceknow Code exactly what happens when you run lpadmin. server9changes theSoftware files). You Chapter 8 -CUPS, Development Tools that with lpadmin

Chapter 10 - Maintaining the Kernel Chapter Add a11 dummy - Configuring test printer and Manipulating by going through Peripheralthe Devices following Chapter - Printing 1. 12Run lpadmin

steps:

to add the printer:

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

lpadmin -p test -v file:/dev/null

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

2. Uselpstat to verify that the printer is there:

Chapter 18 - Further Directions

Appendix A - Command Classification

lpstat Bibliography

-p

Index List of Figures

Your List of Tables

new printer should show up as follows:

List of Sidebars

printer test disabled since Jan 01 00:00 reason unknown 3. Examine/etc/cups/printers.conf. You should see an entry like this: Info test DeviceURI file:/dev/null ... ... 4. Activate your printer: lpadmin -p test

Thelpstat -p command should now report the printer as idle rather than disabled. 5. Send a test job to the printer: echo test | lp -d test 6. Verify that the job started by looking at /var/log/cups/error_log. The file-name is somewhat misleading, because error_log also contains normal diagnostic messages. You should see some entries that look like this:

I [05/Oct/2003:14:44:46 -0700] Started "/usr/lib/cups/cgibin/printers.cgi" (pid=17156) I [05/Oct/2003:14:46:23 -0700] Adding How Linux Works: What Every Super-User Shouldstart Know banner page "none" to job 1. I [05/Oct/2003:14:46:23 -0700] Adding end banner page "none" to job 1. ISBN:1593270356 by Brian Ward I [05/Oct/2003:14:46:23 No Starch Press © 2004 (347 pages)-0700] Job 1 queued on 'test' by 'user'. 7. The

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers Samba. Use the following command to make sure this is the case: job should alsowith complete.

Table of Contents

lpstat -W completed -l test

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2The - Devices, Filesystems, outputDisks, should look like and this:the Kernel Chapter 3 Chapter 4 Chapter 5

- How Linux Boots - Essential System Files, Servers, and Utilities

test-1

- Configuring Your Network

user

Chapter 6

queued for test - Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

1024

Sun Oct

5 14:46:23 2003

8. Remove the test printer when you're finished by using this command:

Chapter 10 - Maintaining the Kernel

lpadmin -xand test Chapter 11 - Configuring Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

This lengthy procedure confirms that your CUPS server is running and that you can add and modify printers.

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Adding a Real Printer

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

Now that you have some familiarity with the process, you are ready to add a real printer with a particular model using this command: Appendix A - Command Classification Chapter 18 - Further Directions Bibliography

lpadmin Index

-p name -v device -m model

List of Figures List of Tables

The List of model Sidebarsparameter

is extremely important because it provides printer-specific information, including the printer driver specification. If you do not use the -m parameter, CUPS uses a "raw" print model, sending unfiltered input directly to the printer. You almost certainly do not want this, because printers can generate copious amounts of garbage upon receiving bad input. If you want to make the new printer the default, run this command: lpoptions -d name

For the most part, you provide a PostScript Printer Description (PPD) filename as model. You can get a list of PPD files with this command: lpinfo -m However, in a stock CUPS installation, it's unlikely that the output list will contain an appropriate PPD entry for your printer, even though some of the entries may look tempting. Before discussing PPD files (see Section 12.5.6 for more information on those), let's briefly look at how to specify a device for the -v option in the earlierlpadmin command.

12.5.5Printer Devices (Backend Specifications) As you might surmise from the file:/dev/null specification in the test printer you created, you specify devices with Uniform Resource Identifiers (URIs). You can get a partial list of URI options with the lpinfo command: lpinfo -v The output looks something like this:

network socket How Linux Works: What Every Super-User Should Know network http ISBN:1593270356 by Brian Ward network ipp No Starch Press © 2004 (347 pages) network lpd This guide describes the inner workings of a Linux system beginning with the file system and boot process and direct parallel:/dev/lp0 covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and direct scsi sharing printers with Samba. serial serial:/dev/ttyS0?baud=115200 serial serial:/dev/ttyS1?baud=115200 Table of Contents ... How Linux Works—What Every Super-User Should Know ... Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots The right-hand column contains backend types and complete URIs. You might see the following backends:

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 7

- Introduction to Shell Scripts

Most direct Chapterparallel 5 - Configuring Your connections Network

are still through the parallel port. The port named LPT1 in DOS and Windows is /dev/lp0 on Linux, so the following device specification works fine in most cases: Chapter 6 - Network Services Chapterparallel:/dev/lp0 8 - Development Tools Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

you may to usePeripheral the bidirectional ChapterHowever, 11 - Configuring and want Manipulating Devices

capabilities of the port for PostScript printers. For may want an accounting program to ask the printer how many pages it prints for each job. device for the bidirectional parallel port: ChapterUse 13 -this Backups you Chapterexample, 12 - Printing

Chapter 14 - Sharing Files with Samba Chapterparallel:/dev/parport0 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A -Newer Command Classification usb printers with USB Bibliography looks

connections use a slightly different backend than parallel ports do. The URI something like the following, although the device filename may not be the same on your system:

Index List of Figures

usb:/dev/usb/lp0

List of Tables

List of Sidebars

socket This is a direct TCP network connection to the print engine of a network printer. Most of these printers listen on TCP port 9100, so you can specify this as follows (since port 9100 is the default, you don't really need the :9100): socket://printer_host:9100 lpd If you want CUPS to send jobs to the Berkeley LPD port of a remote print server or printer, use this URI specification: lpd://host/printer_name smb This is for printing to a Windows printer share. You need to use Samba's smbspool program in this case. See Section 14.6.2 for more details on the URI specification and setting up the Samba backend. ipp, http These are for printing to other network IPP servers (such as remote CUPS servers). Here is an example: ipp://host/printer_name serial In the earlier days of Unix, machines talked to printers with a serial port, and some special-purpose printers still have serial ports. Because serial ports have a more complex system configuration than parallel ports, you often need special parameters to indicate the baud rate and other port settings. At the very least, you should specify the baud rate, as in this example: serial:/dev/ttyS1?baud=38400

However, you often need to specify the parity and flow-control settings. Flow-control settings include soft (orxonxoff),dtrdsr, and hard (or rtscts). Use a + sign before each additional setting, as shown in the following example: How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) serial:/dev/ttyS1?baud=38400+size=8+parity=none+flow=dtrdsr This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

scsi SCSI printers are rare, but if you happen to find one, you can print to its generic SCSI device, as in this example:

Table of Contents

How Linux Works—What Every Super-User Should Know Chapterscsi:/dev/sg1 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

file This prints to a file. By default, CUPS disables printing to any file on the system except /dev/null. - Configuring Your Network You can change this by adding a FileDevice parameter in your cupsd.conf file. Be warned that you Chapter 6 - Network Services risk very serious security breaches if you do so. Chapter 7 - Introduction to Shell Scripts Chapter 5

Chapter 8

- Development Tools

CUPS does not let you choose a backend that it knows it cannot reach. For example, if your kernel does not - Compiling Software From Source Code have parallel port support, CUPS does not list parallel ports when you run lpinfo -v. However, the system Chapter 10 - Maintaining the Kernel isn't perfect; a port showing up in the list does not mean that support actually exists. Chapter 9

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter Each 12 one- Printing of these

backend specifications uses its own separate backend program located in The backend comes in at the very end of the print process.

Chapter 13 - Backups /usr/lib/cups/backend.

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

12.5.6PPD Files

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

After choosing anDirections appropriate Chapter 18 - Further

device, you can complete the printer definition with a PPD file. CUPS uses PPD

files forAits printer database. Appendix - Command Classification Bibliography

A PPD Index

file is in plain text and describes a printer's capabilities. CUPS keeps its default PPD files in /usr/share/cups/model; to make the options in a new PPD file available to the CUPS Web interface, put List of Figures the file in /usr/share/cups/model and send your cupsd a HUP signal. When you import a PPD file into List of Tables the CUPS PPD file database with lpadmin -m, CUPS makes a copy of the file in /etc/cups/ppd. List of Sidebars The PPD file gives you fine control over printing options. Notice that if you choose the raw interface (that is, no PPD file), you get no options with the Configure Printer button in the CUPS Web interface, so you cannot change media, duplex, banner page, and other settings. Here is the general printer and file information from the PPD file of an Apple LaserW riter 16/600: *FormatVersion: "4.3" *FileVersion: "1.1" *LanguageVersion: English *LanguageEncoding: ISOLatin1 *PCFileName: "POSTSCRI.PPD" *Manufacturer: "Apple" *Product: "(LaserWriter 16/600)" Looking elsewhere in the file, you might see some information on page sizes: *PageSize Letter/US Letter: "setpagedevice" *PageSize A4/A4: "setpagedevice" A standard PPD file should also contain font information: *DefaultFont: Courier *Font AvantGarde-Book: Standard "(001.006S)" Standard ROM *Font AvantGarde-BookOblique: Standard "(001.006S)" Standard ROM *Font AvantGarde-Demi: Standard "(001.007S)" Standard ROM *Font AvantGarde-DemiOblique: Standard "(001.007S)" Standard ROM *Font Bookman-Demi: Standard "(001.004S)" Standard ROM *Font Bookman-DemiItalic: Standard "(001.004S)" Standard ROM

*Font *Font *Font *Font

Bookman-Light: Standard "(001.004S)" Standard ROM Bookman-LightItalic: Standard "(001.004S)" Standard ROM Courier: Standard "(002.004S)" Standard ROM How Linux Works: What Every Super-User Should Know Courier-Bold: Standard "(002.004S)" Standard ROM by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

The preceding excerpts are from GPL of a PPD file. PostScript printer provide covering advanced topics a such as version networking, firewalls, development tools, devicemanufacturers management, shell scripts,PPD and printers files for theirsharing products, andwith forSamba. the most part, these should work fine with CUPS. However, non-PostScript printers do not normally come with PPD files, so they need a third-party PPD file that specifies a print filter to Table rasterize of Contents PostScript. You can get CUPS PPD files at sites such as http://www.linuxprinting.org/. How Linux Works—What Every Super-User Should Know Chapter 1

The Basics 12.5.7--Specifying a Filter Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

One of the most frequently encountered problems with CUPS is that many of the PPD files you find on the - Essential System Files, Servers, and Utilities Internet contain CUPS-specific print filter parameters that you may not have on your system. You should be Chapter 5 - Configuring Your Network able to recognize these parameters and have an idea of how to correct or delete them as you go. Chapter 6 - Network Services Chapter 4

Chapter 7

- Introduction to Shell Scripts CUPS filters convert file formats in two ways:

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

To a common format This type of filter converts various file formats into a common format. This common format will be either PostScript or raster data. The mime.convs file controls the filters that Chapter 11 - Configuring and Manipulating Peripheral Devices perform the conversion. For the most part, you should not have to worry about these filters, which are Chapter 12 - Printing covered in the next section. Chapter 13 - Backups Chapter 10 - Maintaining the Kernel

Chapter 14 - Sharing Files with Samba ChapterFrom 15 - Network File Transfer a common format

A filter specified in the PPD file runs just before the backend to change the common format data into the language that the printer understands. If you have a PostScript printer, you Chapter 17 - Buying Hardware for Linux probably do not need this filter in your PPD file. However, if you don't have a PostScript printer, these Chapter 18 - Further Directions backend filters require a lot of attention, as you will see. Chapter 16 - User Environments

Appendix A - Command Classification Bibliography

CUPS Filters and mime.convs

Index

List of Figures CUPS comes List of Tables formats into

with a number of filters in /usr/lib/cups/filter that transform various intermediate file printer-ready data. However, it is difficult to see where and how CUPS runs these filters.

List of Sidebars

When you print a file, you can observe something like the following in the log file (this example is for a text file): Started filter /usr/lib/cups/filter/texttops (PID 3999) for job 25. Started filter /usr/lib/cups/filter/pstops (PID 4000) for job 25.

To get this detailed logging, the LogLevel parameter in your cupsd.conf must be a minimum of info. However, info does not log the initial input file type; you need to set the parameter to debug in order to log this additional information. In the log, you can see some filters running, and from the names of the filters, you know that CUPS has some sort of idea about the job's file type. Unfortunately, the actual workings of the conversion mechanism aren't terribly obvious from the log file output. Here's how the sequence works: 1. CUPS determines the output format that the backend needs to send to the printer by looking at the PPD file. 2. CUPS determines the input file type with the help of /etc/cups/mime.types. In the preceding example log output, the application/postscript rule in /etc/cups/mime.types matched. 3. CUPS looks through the /etc/cups/mime.convs file for a suitable filter to perform the conversion between the input file format and the format that the backend needs. Consider this line from mime.convs that transforms plain-text files to PostScript output: text/plain

application/postscript

33

texttops

The four columns here are the input MIME type, the output MIME type, the estimated cost, and the name of the filter program that converts the input to the output. 4.

4. CUPS runs the filter or filter sequence required for the printer backend. If there are no suitable entries inmime.convs, CUPS logs this message: How Linux Works: What Every Super-User Should Know by Brian Unable to Ward convert file 0 to printable format for job n!

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and 5. CUPS runs any necessary additional filter before handing the final output to the backend (see the next sharing printers with Samba. section). Table of Contents

Specifying a Backend Filter in the PPD File

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics Just before sending the job to the printer backend, CUPS may run a backend filter from the PPD file.

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 -filters How Linux Backend are Boots set with

the cupsFilter parameter in the PPD file. Here is an example from the PPD file

Chapter 4 saw - Essential System Files, Servers, and Utilities that you earlier: Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

*cupsFilter:

Chapter As you9

"application/vnd.cups-postscript 0 foomatic-rip"

- Compiling From Source Code can see, theSoftware cupsFilter parameter's value consists of three parts:

Chapter 10 - Maintaining the Kernel

1. 11An- Configuring expected MIME type. In the preceding example, Chapter and Manipulating Peripheral Devices

the type is PostScript. The default is

application/vnd.cups-postscript.

Chapter 12 - Printing

Chapter 13 - Backups

2. The relative cost of the filter (set this to 0).

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

3. The filter's executable name.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux The preceding cupsFilter parameter Chapter 18 -filter Further Directions is a print that handles

is very typical for printers that do not understand PostScript. Foomatic many different kinds of printers.

Appendix A - Command Classification

There are Bibliography

a few gotchas with the cupsFilter setting:

Index

You don't List of Figures

need an extra filter if your printer already understands PostScript. Many PPD files for PostScript printers that you find on the Web contain filters that don't really do anything, but require extra software List of Tables configuration. Delete any cupsFilter lines in your PPD file if your printer understands PostScript. List of Sidebars The default PPD files and mime.convs file that come with CUPS do not contain the necessary settings to rasterize PostScript files, and it can be somewhat confusing to configure the rasterizer. For example, the generic HP LaserJet PPD files in the CUPS distributions expect raster (not PostScript) input. However, the default mime.convs file doesn't contain an active entry for transforming PostScript into raster output. For this reason, you may want to avoid the standard CUPS PPD files and look on the Web for appropriate files. To address the problem of rasterization, most PPD files for non-PostScript printers on the Web assume that you have Foomatic as a filter (see Section 12.5.8) with Ghostscript as the rasterization engine. If your printer doesn't understand PostScript, it's unlikely that you will be able to avoid Foomatic. There is good news, though. Most PPD files that you find on the Web work fine if all of your software (Ghostscript, Foomatic, CUPS, and so on) is installed correctly.

12.5.8Foomatic (for Non-PostScript Printers) If your printer does not have native PostScript support, there may still be one more piece of the puzzle to configure — the rasterizer filter. There are several options here, but the most popular system at the moment is Foomatic. Before going into details about Foomatic, you should be clear on the end goal here: you want a print filter to run a Ghostscript (gs) command to render PostScript input into bitmap form to send to the printer. The command arguments look something like this: gs -q -dSAFER -dNOPAUSE -dBATCH device_options -sOutputFile=- This seems simple enough, but unfortunately, device_options can be a tremendous mess. There are countless combinations of printer data formats and options. Foomatic attempts to resolve these problems with a database containing options for nearly every printer model out there. You may see references to this

database all over the Web but very little information on how to actually use the database. What most documentation fails to mention is that most administrators and users don't even interact with the How Linux Works: What Every Super-User Should Know database. Allbyyou need fact, this Brian Wardto worry about is building printer configuration data, such as PPD files. InISBN:1593270356 work is already done for you when you visit http://www.linuxprinting.org/ to get a PPD file for your printer. All of No Starch Press © 2004 (347 pages) the information that the Foomatic filter program (foomatic-rip) needs is in that PPD file. For example, here This guide describes the inner workings of a Linux system beginning with the file system and boot process and is a portion of the HP LaserJet 1100 PPD file that contains arguments: covering advanced topics such as networking, firewalls, Ghostscript development tools, device management, shell scripts, and sharing printers with Samba.

*FoomaticRIPCommandLine: "gs -q -dBATCH -dPARANOIDSAFER -dQUIET -dNOPA&& -sIjsServer=hpijs%A%B%C -dIjsUseOutputFD%Z -sOutputFi&& How Linux-" Works—What Every Super-User Should Know le=Chapter *End 1 - The Basics

Table Contents USEof-sDEVICE=ijs

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 - See Configuring Network Note SectionYour 12.6.3 for Chapter 6

notes on certain HP printer drivers.

- Network Services

Chapter 7

to Shell Scripts Testing- Introduction Foomatic

Chapter 8

- Development Tools

Chapter To use9

- Compiling Codefoomatic-rip program in lib/cups/filter (a symbolic link to Foomatic asSoftware a filter,From you Source need the can verify that Foomatic produces the correct printer output by running Chapter 11 - Configuring and command Manipulatingline, Peripheral Devicesprinter output by hand. You can then send this data directly foomatic-rip on the generating Chapter - Printing to the 12 printer, bypassing the print spooler. Chapter 10 location - Maintaining thefine). KernelYou another works

Chapter 13 - Backups

First, locate your Files printer's PPD file Chapter 14 - Sharing with Samba Chapter Run this 15 -command Network File toTransfer create

(ppd_file) and find a test PostScript file to test with (test_file.ps). printer data in test.prn:

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

foomatic-rip -v --ppd ppd_file test_file.ps > test.prn

Chapter 18 - Further Directions Appendix A - Command Classification Bibliography The-v option Index goes

specifies verbose operation so that you can see exactly what the filter is doing. If everything well, you should see the following at the end of the diagnostic messages:

List of Figures List of Tables

KID4 exited with status 0 Renderer exit stat: 0 Renderer process finished

List of Sidebars

Closing foomatic-rip. Successful completion also means that test.prn should now be a gigantic (probably binary) file that you can send directly to the printer device.

12.5.9Administrative Command Overview With the mess of print filters hopefully behind you, it's time to learn some commands for day-to-day tasks. Compared to other Unix server systems, it isn't terribly important that you know the syntax of every last command, because the Web administration interface does an adequate job in most cases (and is sometimes far preferable to the command line — for example, when doing printer media option configuration). However, you should develop at least a passing familiarity with the following commands (remember that each command has a manual page): lpadmin Adds, removes, and modifies printers. lpinfo Displays device and PPD file information (for use with lpadmin). lpoptions Sets printer options. To display a quick list of options for a particular printer, run this command: lpoptions -p printer -l lpstat Displays printer and job information (after you create printers). To display a printer's job queue, use this command:

lpstat -o printer How Linux Works: What Every Super-User Should Know

To see the status of every printer on the system, use this: by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

lpstatThis -aguide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

cancel Removes a job. To remove all jobs from a queue, run this command: Table of Contents How Linux Works—What Every Super-User Should Know

cancel -d printer -a

Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots disable Disables printing (but still possibly allows new jobs on the queue).

Chapter 4

- Essential System Files, Servers, and Utilities

Chapterenable 5 - Configuring Network EnablesYour printing. Chapter 6

- Network Services

Chapterreject 7 - Introduction Disablestoprint Shell queuing. Scripts Chapter 8

- Development Tools

Enables print queuing. Chapteraccept 9 - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel

lppasswd Modifies users and passwords (for digest authentication; see Section 12.5.2).

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

12.5.10Client Access Control

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

By default, CUPS allows printer and administration access only to localhost. If you have a network of grant access to your CUPS server, then you have to change your cupsd.conf file Chapter 17 - Buying Hardware for Linux to reflect this. Chapter 16 - User machines that Environments you want to Chapter 18 - Further Directions

Appendix Classification To get Aan- Command idea of how per-client Bibliography reads. It should start with a section that looks like this:

Index List of Figures

Order Deny,Allow List of Sidebars Deny From All Allow From 127.0.0.1 List of Tables

TheLocation / section defines global access-control parameters for the CUPS server. In the preceding example, the directives work together to give access to localhost (127.0.0.1) and nothing else: Order Deny,Allow Allows you to specify hosts and networks that are denied and allowed access with theDeny and Allow directives. Further more, it also means that you can override Deny directives with Allow directives. This is the most useful mode in CUPS, and you should never change it. Deny From All Denies access to all clients by default. Again, you should not change this. Allow From 127.0.0.1 Makes an exception to the preceding Deny From All rule, granting access to localhost. If you want to allow access for all of your printers to more clients, you can just add another rule directive after theAllow From 127.0.0.1 line. The following rule directive grants access to the subnet defined by 10.0.1.0/255.255.255.0: Allow From 10.0.1.0/255.255.255.0 You may have as many Allow From client lines as you like, and you can specify the client parameter in several ways. The following five specification types are the most useful: Subnet notation, as in the preceding 10.0.1.0/255.255.255.0 example IP addresses, such as 10.0.1.3

Fully qualified domain names, such as client.example.com Linux Works: What Every Super-User Should Know DomainHow wildcards, such as *.example.com by Brian Ward

ISBN:1593270356

NetworkNointerfaces, such as(347 @IF(eth0) Starch Press © 2004 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

Remember that the advanced Location / such section is for global access, includingtools, printer jobmanagement, control andshell other clientand covering topics as networking, firewalls, development device scripts, sharing printers with tasks. Administrative tasks, onSamba. the other hand, have their own Location section () that specifically excludes connections from all hosts except localhost. In fact, you have already seen this section Table when of you Contents forced CUPS to digest authentication. Search for it in your cupsd.conf to verify that it allows How Linux Works—What Every Super-User and Should administrative access to localhost, to Know nothing else. Chapter 1

- The Basics

canDisks, specify per-printer access Note Chapter 2 - You Devices, Filesystems, and client the Kernel Chapter 4

by adding access control sections, where name is the name of a printer. You'll probably need to experiment for a while to get it - How Linux Boots work perfectly. - to Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 3

Chapter 6

- Network Services 12.5.11 Auto-Discovery - Introduction to Shell Scripts

Chapter 7 Chapter 8

- Development Tools

One of the more interesting CUPS features is automatic network printer discovery. This is called browsing. - Compiling Software From Source Code Most CUPS installations have browsing active by default, meaning that CUPS listens for messages from other Chapter 10 - Maintaining the Kernel print servers on the network. The cupsd.conf parameter is Browsing: Chapter 9

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

Browsing On Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

However, without additional Chapter 16 - User Environments

help, your CUPS server will likely not make itself known to the other print servers on the network. To make your CUPS server broadcast its presence, you need a BrowseAddress broadcast address parameter in cupsd.conf. For example, to send notification packets to as many hosts on the Chapter 18 - Further Directions networkA as possibleClassification (essentially, as many as your routers allow), use this parameter: Appendix - Command Chapter 17 - Buying Hardware for Linux

Bibliography Index BrowseAddress

255.255.255.255

List of Figures List of Tables

You can think List of Sidebars

of a numeric broadcast address as a sort of inverse subnet combined with an IP address. For example, to send packets to the subnet defined by 10.1.2.0/255.255.255.0, try this: BrowseAddress 10.1.2.255 This said, the best choice is likely the "local" interface selection that sends broadcast packets out to all network interfaces except PPP links: BrowseAddress @LOCAL If you have a server with several Ethernet interfaces, but do not want to broadcast on all of these interfaces, use @IF. For example, here's how to broadcast to eth1: BrowseAddress @IF(eth1)

12.5.12Running an LPD-Compatible Server Browsing and broadcasting goes a long way toward allowing communication between various CUPS servers on a network, but if you want older clients running Berkeley LPD printing systems to be able to print to your CUPS server, you need to configure your server to allow jobs from these clients. To do this, run a special LPD server frontend called cups-lpd located in /usr/lib/cups/daemon. This is an inetd service (see Section 6.3), so you want a line like this in your /etc/inetd.conf (or the xinetd equivalent): printer stream tcp nowait cups-user /usr/lib/cups/daemon/cups-lpd cups-lpd

cups-user is your CUPS User parameter from cupsd.conf (usually lp). There is no built-in access control incups-lpd, but like any other network service, you want to make sure that your firewall rules have adequate coverage; see Section 5.13. Remember printer is defined How Linux Works: What Every that Super-User Should Know in /etc/services as port 515. by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

12.5.13Troubleshooting CUPS This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

When you have sharing a problem printers with with Samba. CUPS, it's particularly important to take things one step at a time. You may find this sequence helpful: Table 1. of Contents Make sure

that CUPS is working properly by creating a test printer with no filters (raw mode) and a file to the printer with the Web interface and lp, and verify Chapter 1that - The theBasics jobs complete with lpstat: How Linuxdevice Works—What Every Super-User Should of file:/dev/null. SendKnow a test Chapter 2 Chapter 3 Chapter 4 Chapter 5 Chapter 6

- Devices, Disks, Filesystems, and the Kernel - How Linux Boots

lpstat -W completed -o test_printer_name - Essential System Files, Servers, and Utilities lpstat -o test_printer_name - Configuring Your Network - Network Services

Chapter 7

- Introduction to Shell Scripts 2. Use your printer's PPD file to activate your filter. See Sections 12.5.4 and 12.5.6 for more detail if - Development Tools something goes wrong. Print more test files, again making sure that the jobs finish.

Chapter 8 Chapter 9

- Compiling Software From Source Code

Chapter - Maintaining the Kernel 3. 10Add the printer's actual

device, and then try another test job. If necessary, try printing to a file, then

Chapter 11 - Configuring anddirectly Manipulating sending the file to thePeripheral printer. Devices Chapter 12 - Printing Chapter 13 print - Backups If a test job fails

and stalls, the printer state changes to "not ready," and you need to start the printer new jobs. Do this with enable printer or the Web interface. Before you Chapter 15 - Network File Transferthough, you should look at your log files, which are described in the next section. start changing files around, Chapter again 14 to retry - Sharing the Files job or with run Samba any Chapter 16 - User Environments

Error Messages

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix The complex A - Command natureClassification of the print

spooler and filters makes it crucial that you pay careful attention to your log The most important log file is /var/log/cups/error_log (the name is slightly misleading Index because the file also contains normal diagnostic messages). messages. Bibliography List of Figures

Looking at List of Tables

the log reveals this format:

List of Sidebars

I [timestamp] Started filter /usr/lib/cups/filter/pstops (PID 3434) for job 26. D [timestamp] ProcessIPPRequest: 10 status_code=0 E [timestamp] [Job 26] unable to open print file - : Permission denied The letter at the start of the line indicates the message severity or priority. The three letters in the preceding example are as follows: I An informational log message. These notices usually indicate some significant event, such as a filter invocation or job submission. D A verbose debugging message. You should not care about these unless you run into a problem. E An error message indicating that something doesn't work. The CUPS scheduler usually keeps running if there is an error. However, you may end up missing a feature or having a stalled printer job. You can change the log level with the LogLevel parameter in the cupsd.conf file. The default level is info in most installations. If you want the debugging messages, you must use debug. If you change your LogLevel parameter, remember to reload your configuration file after making any changes by sending a HUP signal to cupsd.

Filter Problems The first thing you should do after running into trouble in the print filter stage is to make sure that the CUPS filters in /etc/cups/mime.convs function properly. To do this, first disable any filters that you might have in your printer's PPD file so that you can eliminate the backend filter from the list of things that can go wrong. You will probably only have such filters if you are using a non-PostScript printer. If that's the case, edit your printer's PPD file (the one in /etc/cups/ppd), looking for a cupsFilter parameter (see Section 12.5.7). Comment out the parameter by adding a % just after the *; for example:

*%cupsFilter:

"application/vnd.cups-postscript 0 foomatic-rip"

How Linux Works: What Every Super-User Should Know

After makingbythis change (and making cupsd re-read its configuration with a HUP signal), submit a test job to ISBN:1593270356 Brian Ward see if data can make it past the mime.convs filter stage to the printer device. Although you are not likely to No Starch Press © 2004 (347 pages) run into any This trouble with the CUPS-supplied filter programs in mime.convs, this process may help you guide describes the inner workings of a Linux system beginning with the file system and boot process and uncover spool directory permissions problems (discussed indevelopment the next section ) because these sorts of problems covering advanced topics such as networking, firewalls, tools, device management, shell scripts, and withprint Samba. usually showsharing up in printers the initial filter stages. Having worked Table of Contents

out any kinks not involving the cupsFilter filter, re-enable this parameter and look for more

trouble: How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Verify that the cupsFilter filter is in the lib/cups/filter directory. - Devices, Disks, Filesystems, and the Kernel

Chapter 2 Chapter 3

- How Linux Boots For the Foomatic filter, use foomatic-rip -v manually from the command line to check for valid - Essential System Files, Servers, and Utilities output (see Section 12.5.8).

Chapter 4 Chapter 5

- Configuring Your Network

ChapterCheck 6 - Network Services that the filter has Chapter 7

the correct path for any necessary program.

- Introduction to Shell Scripts

ChapterIf 8your - Development filter reliesTools on Ghostscript, Chapter 9

ensure that you have the required driver by running gs -help.

- Compiling Software From Source Code

Spool Directory Permission Errors

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 -this Printing Look for message

in your error log:

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

E [timestamp] [Job n] unable to open print file - : Permission denied

Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter - Buying runs Hardware for Linux CUPS17normally its filters as

the pseudo-user lp and the group sys, so this user must have access to the in order to access intermediate data. When fixing the permissions, look for

Chapter - Further Directions spool 18 directory /var/spool/cups Appendix A - Command Classification these problems: Bibliography Index

Check all component directories of /var/spool/cups. Can the lp user access each of them?

List of Figures

Make List of Tables

sure that you have the lp user in your /etc/passwd file.

List of Sidebars

Verify that lp belongs to the sys group. (Remember that you can change the pseudo-user and group with theUser and Group parameters of cupsd.conf.)

Device Problems After running through the filter gauntlet, you are ready to send output to devices. Fortunately, there is relatively little that can go wrong at this final stage: The lp user must have write access to any printer device directly connected to the system. In addition, check the kernel bootup messages and /proc to ensure that the kernel recognizes the device ports. For network printers, make sure that your host can reach the printer. If your device is the socket type on TCP port 9100, test the connection with this command: telnetprinter_address 9100

Terminate a successful connection by pressing CONTROL-], then CONTROL-D. Unless you know the printer's native language, this connection does little good other than confirming that it can be made.

How Linux Works: What Every Super-User Should Know 12.6Ghostscript by Brian Ward

ISBN:1593270356

Noget Starch Press © on 2004printing (347 pages) If you want to a handle under Unix, you should get to know Ghostscript. As mentioned before, This guide that describes inner workings of a Linux system beginning with file system and boot process and most Unix programs printthe generate PostScript output. Ghostscript is a the PostScript interpreter that includes covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and these features: sharing printers with Samba.

Bitmap rendering from PostScript code in several different output formats

Table of Contents

How Linux Works—What Every Super-User Should Know PostScript file filtering Chapter 1

- The Basics

ChapterReading 2 - Devices, Filesystems, and the Kernel and Disks, writing to PDF format Chapter 3

- How Linux Boots

previewing ChapterDocument 4 - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

To get a -feel for how Ghostscript works, run it with a file and no other arguments: Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

gsfile.ps Chapter 8 - Development Tools Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

In addition to gettingand a preview window showing the Chapter 11 - Configuring Manipulating Peripheral Devices

first page of the file, you should also see this message back

at your12terminal Chapter - Printingwindow: Chapter 13 - Backups Chapter 14 - Sharingpress Files with Samba >>showpage,

to continue or CONTROL-C to exit.

Appendix - Command Classification prompt;A you may press CONTROL-D Bibliography

There Index

are several frontend programs, such as gv and ggv, that give a nicer interface to the Ghostscript preview. use one of these frontend programs or not, running a preview can verify that you have a valid PostScript List of Tables file to begin with. This can go a long way in tracking down problems, especially if your print spooler also uses Ghostscript to rasterize images for the printer. List of Sidebars Whether you List of Figures

12.6.1Command-Line Options A full gs command line such as the one in Section 12.5.8 may seem a bit complicated, especially when it comes to device specification. However, it's not hard to gain enough familiarity to make use of Ghostscript's filtering capabilities. Take a close look at the following command, which filters old.ps to create new.ps: gs -q -dNOPAUSE -dBATCH -dSAFER -sDEVICE=pswrite -sOutputFile=new.ps old.ps

The first four options are typical for filters that run with no user input. Here's what they specify: -q Quiet mode; suppress any normal diagnostic output. -dNOPAUSE Do not wait for the user to press RETURN after each page. -dBATCH Terminate after interpreting all input. -dSAFER Disallow file alteration capabilities (to avoid security problems). The-dPARANOIDSAFER option disables file-read capabilities. The next two options usually go hand-in-hand when creating an output file: -sDEVICE=driver_name Use driver_name as the output driver. In this context, the term driver usually refers to a file format driver rather than a piece of code that manipulates devices, though there are exceptions (such as the x11 driver for the preview window). To see a list of drivers, run gs -help.

Note Some drivers require other command-line parameters to operate correctly. Two notable examples are the uniprint and ijs drivers. The uniprint driver comes with a number of .upp files How Linux Works: What Every Super-User Should Know use ISBN:1593270356 by (containing Brian Ward extra parameters) in the Ghostscript library directory. To use these settings, @file.upp; for example: No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and gs @file.upp -q -dNOPAUSE -dBATCH -sOutputFile=out ... sharing printers with Samba. Table of Contents -sOutputFile=file

Write output to file (use - for standard output). If you ish to create one file per page of PostScript input, insert %d somewhere nto the name of file. Ghostscript substitutes the page Chapter 1 - The Basics number for %d. How Linux Works—What Every Super-User Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Essential Ghostscript System Files, Servers, Tricks and Utilities 12.6.2-More

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6 -aNetwork Services Here are few more useful Chapter 7

things that you can do with Ghostscript:

- Introduction to Shell Scripts

a PostScript ChapterTo 8 transform - Development Tools

file into a PDF file, use the pdfwrite driver (Ghostscript comes with a ps2pdf

that doesSoftware essentially same thing): Chapterscript 9 - Compiling From the Source Code Chapter 10 - Maintaining the Kernel Chaptergs 11 -q - Configuring and Manipulating Devices -dNOPAUSE -dBATCHPeripheral -dSAFER -sDEVICE=pdfwrite

-sOutputFile=file.pdffile.ps

Chapter 12 - Printing Chapter 13 - Backups ChapterThe 14 pswrite - Sharing Files with(introduced Samba driver

in the previous section) is an effective way to make somewhat defective the file with Ghostscript, the chances are good that a file filtered with the Chapterpswrite 16 - User Environments driver will print on even a finicky printer. Chapterfiles 15 -print. Network File Transfer If you can view

Chapter 17 - Buying Hardware for Linux

combine several ChapterYou 18 -can Further Directions

PostScript or PDF files into one by adding the additional filenames to the end of

theA command Appendix - Command line. Classification Bibliography

To change the output resolution (in dots per inch), use the -rdpi or -rxdpixydpi parameters. The default resolution is usually 72 dpi. These commands generate larger bitmaps: List of Figures Index

List of Tables List of Sidebars gs -q

-dNOPAUSE -dBATCH -dSAFER -r150 -sDEVICE=pnmraw -sOutputFile=- file.ps gs -q -dNOPAUSE -dBATCH -dSAFER -r300x150 -sDEVICE=pnmraw -sOutputFile=- file.ps

12.6.3HP Inkjet Server If you have an inkjet or non-PostScript laser printer made by HP, then you almost certainly need the HPIJS (HP Inkjet Server) printer driver package. The main part of HPIJS is a program called hpijs. You can think of this as a plug-in driver for Ghostscript that translates Ghostscript's internal raster image format into printer formats. This driver is especially important if you are printing photographs or other graphics. You can tell if you need HPIJS by looking at the PPD file for your printer. If you see -sDEVICE=ijs in the FoomaticRIPCommandLine parameter, you need the driver. You can install it as a binary package or from source code; the only thing that matters is that Ghostscript can find the command in its path.

Note Current versions of hpijs come with foomatic-rip and a set of PPD files. The best output quality likely comes from using these PPD files rather than random ones you see on the Internet.

How Linux Works: What Every Super-User Should Know 12.7Further Printing Topics by Brian Ward

ISBN:1593270356

2004 (347 This chapterNo is Starch really Press only ©the tip ofpages) the iceberg when it comes to printing. Chapter 14 revisits printing to This the inner workings of a Linux system beginning withthe theaspects file system and boot process look at details ofguide howdescribes to interface CUPS with Samba servers, but among not touched hereand are covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and application configuration, complex color graphics support, and advanced PostScript topics, not to mention sharing printers with Samba. several other Unix print server packages.

Table of Contents

Here are some Web sites that can help you with your quest for Unix printer configuration:

How Linux Works—What Every Super-User Should Know Chapterhttp://www.linuxprinting.org/ 1 - The Basics

This site has PPD files and documentation on many print servers. It also contains the Foomatic central information site. Chapter 2 - Devices, Disks, Filesystems, and the Kernel Chapter 3

- How Linux Boots

http://www.cups.org/ This is the central CUPS Web site. - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

http://www.ghostscript.com/ A good source for Ghostscript software and topics.

Chapter 7

- Introduction to Shell Scripts http://gimp-print.sourceforge.net/ Gimp-print is a GIMP plug-in specifically designed for direct color - Development Tools printing. In certain cases, you may want to make gimp-print generate printer-ready data, bypassing Chapter 9 - Compiling Software From Source Code Ghostscript rasterization completely with the lp -oraw feature. (Gimp-print can also create Chapter 10 - Maintaining the Kernel PostScript output.) Chapter 8

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 13: Backups by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

There is no single system for backups on Linux. There are many different kinds of archiving programs and This guide describes the inner workings of a Linux system beginning with the file system and boot process and formats. Youcovering already saw tar, one of as thenetworking, most popular archivers, in Chapter 1. The good news is that advanced topics such firewalls, development tools, device management, shell scripts, and sharing printers with Samba. there isn't much more to making backups than what you already know; the bad news is that it's not too clear how you should get the archive to the physical medium. Table of Contents

This chapter takes you through the Should basicsKnow of backups: How Linux Works—What Every Super-User

what data you need to back up, what backup what types of backups you can make, how to use the most common archivers, and how to2 use tape drives. Chapter - Devices, Disks, Filesystems, and the Kernel devices available, Chapter 1 are - The Basics Chapter 3

- How Linux Boots

- Essential System Files, Servers, and Utilities 13.1What Should You Back Up?

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6 - Network Services Your backup priorities should

be as follows:

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

1. Home directories. Try to make daily backups of your home directories.

Chapter - Compiling Software From Sourceand Code 2. 9System-specific configuration data,

such as the stuff in /etc and /var. This should include your machine's list of installed packages.

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter - Printing 3. 12Locally installed Chapter 13 - Backups custom software

software (for example, /usr/local). You don't want to lose the work you put into installations, so make a backup every now and then.

Chapter 14 - Sharing Files with Samba

4. 15System software from Chapter - Network File Transfer

your distribution. This really is the least of your worries, because you can part of the system by reinstalling the operating system. Furthermore, by the time yourHardware disk getsforaround Chapter 17 - Buying Linux to crashing so hard that you need to restore from backups, you probably want to install a newer version of the operating system anyway. Chapter 18 - Further Directions probably restore this Chapter 16 - User Environments

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 13.2Backup Hardware by Brian Ward

ISBN:1593270356

No Starch © 2004 there (347 pages) In the formative yearsPress of Unix, was only one reasonable kind of backup hardware: the tape drive. guide describes the inner of a Linux system beginning thefairly file system and and boot they process and Tapes were This inexpensive compared to workings fixed storage (hard drives), theywith were reliable, could covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and be taken off-site for additional data security. sharing printers with Samba.

However, hard disk technology has outpaced tape drive technology in the past ten years. For PCs, tape drives are expensive compared to hard disks (and the tapes themselves are also expensive). In addition, How Linux Works—What Every Super-User Should Know tape drive capacities are far smaller than the disks now on the market.

Table of Contents Chapter 1

- The Basics

Chapter Disks, and thealternatives Kernel There2are- Devices, currently twoFilesystems, popular backup Chapter 3

to tape drives:

- How Linux Boots

DVD-R/RW drives ChapterCD4 -and Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

hardServices disk (internal ChapterAn 6 extra - Network Chapter 7

or external)

- Introduction to Shell Scripts

Both of these work, but you need to improvise, because there aren't any tried-and-true standard solutions - Development Tools for making backups to these devices. You still want to use a traditional backup utility (almost certainly tar) Chapter 9 - Compiling Software From Source Code to create archives on the medium, but you need to find a way to manage the archives by yourself. Chapter 10 - Maintaining the Kernel Chapter 8

Chapter 11 - Configuring and Manipulating Peripheral Devices

That said, don't count out the tape drive just yet. A significant portion of this chapter deals with tape drives.

Chapter 12 - Printing

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Linux Works: What Every Super-User Should Know 13.3FullHow and Incremental Backups by Brian Ward

ISBN:1593270356

Starch Press © 2004backup (347 pages) Before goingNointo detail about hardware and archiving programs, you need to know about the two guide describes the inner workings of a Linux system beginning with the file system and boot process and basic backupThis types:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Full backup An archive of everything on a filesystem or directory Table of Contents How Linux Works—What Every Super-User Should Know

Incremental backup An archive of all items that have changed since the last full backup

Chapter 1

- The Basics

Chapter 2 - Devices, Disks, Filesystems, the Kernel In large-scale operations, there areand more kinds

of backups, and you may hear of cumulative and differential between incremental and full backups — that is, an incremental backup may Chapter 4 all - Essential System Files, Servers, anddifferential Utilities contain of the changes since the last backup, and the differential backup, in turn, could Chapter 5 Configuring Your Network contain all changes since the last full backup. However, for small systems where you do backups by hand, Chapter 6 - Network it is reasonable toServices deal only with full backups and the incremental backups that build on the full backups. Chapter 3 - These How Linux backups. areBoots levels

Chapter 7

- Introduction to Shell Scripts

Chapter 8 - Development Tools The advantage to incremental

backups is that they usually finish quickly and do not require much storage the last full backup and the current state on the disk Chapter - Maintaining the Kernel gets to10be so significant that these advantages dwindle: the incremental backups start to take up as much Chapter Configuring and Manipulating space11 as- the full backups, and it canPeripheral be veryDevices difficult to merge an old full backup and a newer incremental Chapter 12if- you Printing backup ever need to restore a full set of files from the backups. In particular, files that you Chapter 13 - Backups intentionally deleted between the two backups can reappear. Therefore, you need to do a full backups on a Chapter 14basis. - Sharing Files with Samba regular Chapter - Compiling Software Source Code between space.9 However, over time,From the difference

Chapter 15 - Network File Transfer

Systems generally Chapter 16 -administrators User Environments

keep a set of full and incremental backups so that they can restore files period of time. For example, if you have daily incremental backups that go18back 30 days and a full backup from at least 30 days ago, you can restore any file that was on the Chapter - Further Directions filesystem at backup time during that time period. Of course, if you don't know the exact dates, finding the Appendix A - Command Classification file can take a little time. Bibliography that may only existed a short Chapter 17 -have Buying Hardware for for Linux

Index

Toofrestore List Figures

a complete set of files, you need to extract the latest full backup first, then the latest incremental backup (unless, of course, the full backup is by chance newer than the incremental backup). List of Tables List of Sidebars

How tar Linuxfor Works: What Every Super-User Should Know 13.4Using Backups and Restores by Brian Ward

ISBN:1593270356

No ,Starch Press © 2004 pages)of tar. As it turns out, you already know nearly all you need in order In Section 1.18 you learned the(347 basics guide describes inner workings of a Linux beginning with thecan file system process GNU and to do manualThis backups. If you the want a comprehensive listsystem of tar options, you look atand theboot (gigantic) covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and info documents. However, the good news is that you don't need to know very many options, and after reading sharing printers with Samba. this section, you should only need tar --help every now and then as a refresher. Table of Contents

13.4.1Creating Archives

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 - Devices,as Disks, and the Kernel With processors fastFilesystems, as they are now, and disks Chapter 3 - Howfor Linux compression anyBoots archive.

getting ever larger, it doesn't make much sense to omit Recall that you can create a compressed archive of a directory with one

Chapter 4 - Essential System Files, Servers, and Utilities command: Chapter 5

- Configuring Your Network

Chapter 6

- Network Services tar zcvf archive directory

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code A large part of making a backup is figuring out where to put the archive. There are a few choices here:

Chapter 10 - Maintaining the Kernel

ChapterFor 11 tape - Configuring Peripheral Devices drives,and seeManipulating Section 13.6.2 for how to write

the archive to the tape device.

Chapter 12 - Printing ChapterFor 13 backing - Backupsup

to a spare disk, you can write the archive as a file on the disk's filesystem.

Chapter 14 - Sharing Files with Samba

you need toFile pipe the output ChapterIf 15 - Network Transfer

to standard output (to feed it to another command, such as cdwrite), use

as -the archive name. Chapter- 16 User Environments Chapter 17 - Buying Hardware for Linux

Here are some options to consider when running GNU tar:

Chapter 18 - Further Directions

--exclude file Exclude Appendix A - Command Classification

file from the archive.

Bibliography Index

--exclude-fromfile Doesn't include in the archive any of the files listed in file.

List of Figures

--one-file-system Archives files from inside a single filesystem. This is handy for breaking up by partitions.

List of Tables

backups List of Sidebars

--absolute-paths Doesn't strip the leading / from an absolute pathname. This has its uses, but only if you know what you're doing. --listed-incrementalfile Uses file as the incremental state file (see Section 13.4.2). One tricky part about adding these options to a traditional tar command is that you must insert a - in front of the regular one-character options. Therefore, if you want to create an archive of the misc directory, but excludemisc/scratch, you would have to run the following with -zcvf rather than with zcvf, as you saw in the previous example. Here's how it would look: tar --exclude misc/scratch -zcvf archive misc

Note Remember that tar strips the leading / from an absolute pathname (unless you specify the -absolute-paths parameter). Therefore, to exclude an item, you must match the path that goes into the archive, not necessarily the one on the system. Let's say that you wanted to create an archive of / without /usr. You must remove the / by yourself: tar --exclude usr -zcvf archive /

13.4.2Incremental Backups with tar To enable incremental backups with GNU tar, you need to create an incremental state file that contains information about each newly archived file. Here's how to do it: 1. Run the following command to make a full backup in full_archive (state_file is the name of the state file; you must choose your own name):

tar --listed-incremental state_file -zcvf full_archive file1 ... How Linux Works: What Every Super-User Should Know

2. Makebya Brian copyWard of the original state file. For example:

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and cpstate_file state_file_incr covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

3. When it is time to make an incremental backup, run the same tar command as earlier, but with the copy that you created in step 2, state_file_incr:

Table of Contents state file

How Linux Works—What Every Super-User Should Know Chapter 1 Chapter 2

- The Basics

tar --listed-incremental state_file_incr -zcvf incremental_archive file1 ... - Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

This should produce a much smaller archive than the full backup, because tar compares the time(s) - Configuring Your Network listed in state_file_incr (remember, it's a copy of the original state_file) against the Chapter 6 - Network Services modification times of the current files on the disk. Chapter 7 - Introduction to Shell Scripts Chapter 5

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

4. Repeat steps 2 and 3 for subsequent incremental backups.

Chapter 5. 10To- Maintaining do anotherthe fullKernel backup,

delete or rename state_file and start at step 1.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing You need to make

a copy of the original state file before each incremental backup because GNU tar with --listed-incremental after its run. If you were to perform backups with Chapter 14 - state Sharing Files withand Samba the same file over over again, the incremental backups would only record the changes since the Chapter 15 - Networkbackup, File Transfer last incremental not since the last full backup. Although this would yield a complete set of changes, it Chapter - User Environments would16 also make it nearly impossible to find a lost file inside a set of incremental backups. Furthermore, to do Chapter 17 Buying Hardware for Linux a complete restore, you would need to use all of your incremental backups. Chapter 13 the - Backups updates file specified

Chapter 18 - Further Directions

Note that incremental Appendix A - Remember Command Classification Bibliography

backups are only good when accompanied by the previous full backup. Make sure that you don't overwrite your full backup with an incremental backup.

Index List of Figures

13.4.3Extracting Archives

List of Tables

List of Sidebars

Recall from Section 1.18.1 that you can extract files from a compressed archive as follows:

tar zxvf archive

By default, tar extracts all files in the archive. However, you can limit the extraction to specific files and directories by adding their names to the end of the command line (you may need to run tar ztvf to get a list of filenames): tar zxvf archive file1 file2 ...

When extracting system files and home directories as root (for example, from a restore or when moving the things around), it is critical that you use the p option to preserve the original permissions: tar zxvpf archive

Otherwise, tar creates files using the current permissions mask (umask). This can be annoying at the very least, and could cause your system to malfunction at the worst.

Warning Before extracting an archive, it's very important to check your current working directory against any files that the extraction process might create so that you don't accidentally clobber newer versions of files with older ones from the archive. When doing a partial restore, it's usually a good idea to change to an empty temporary directory first.

How Linuxto Works: What Every Super-User Should Know 13.5Backups Non-Traditional Media by Brian Ward

ISBN:1593270356

Starch Press 2004 (347to pages) Even thoughNoyou have the© ability create your own filesystems on CD- or DVD-R/RW drives and spare This should guide describes thewith inneran workings of aprogram Linux system with the file backups. system andThe bootprimary process and hard disks, you still stick archiver likebeginning tar to make your covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and reason is simple: tar preserves all file attributes, including permissions and ownership. In addition, it is sharing printers with Samba. easier to manage full and incremental backups with tar. Table of Contents If you choose to

make backups with cdrecord (see Section 11.2.2, your best bet is probably to write a with a command like this:

How Linux Works—What Every directly Super-User compressed tar archive to Should the CDKnow or DVD Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

tar zcf- How - |Linux cdrecord dev=dev cdrecord_args Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

You may need to experiment with the speed option to cdrecord, because the archiving command may - Network Services not produce data fast enough for your recorder. Chapter 7 - Introduction to Shell Scripts Chapter 6 Chapter 8

- Development Tools Again, remember that this command does not create a filesystem on the disc. To read from the archive, - Compiling Software From Source Code you can just use the raw device.

Chapter 9

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

13.5.1Backups to Hard Disks

Chapter 12 - Printing

Chapter 13 - Backups

Using 14 a spare hard disk backups Chapter - Sharing Files withfor Samba

is relatively easy. Create a regular filesystem on the disk and simply files. You should be able to keep a fair amount of data on the spare disk if you use and incremental backups. Chapter 16 compression - User Environments write your archives asTransfer regular Chapter 15 - Network File

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 13.6Tape Drive Devices by Brian Ward

ISBN:1593270356

Noare Starch Press © 2004 (347 pages) Tape devices character devices on a Linux system, going by a variety of filenames: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering topics such as networking, firewalls, development tools, deviceand management, shell scripts, and SCSI tapes useadvanced the names /dev/st0, /dev/nst0, /dev/st1, /dev/nst1, so on. The SCSI sharing printers with Samba. tape drive interface and driver is widely regarded as the most reliable, but, of course, SCSI tape drives are also more expensive than others.

Table of Contents

How Linux Works—What Every Super-User Should Know ATAPI tape devices start at /dev/ht0 and Chapter 1

/dev/nht0.

- The Basics

is limited support for tape on the ChapterThere 2 - Devices, Disks, Filesystems, anddrives the Kernel Chapter 3

floppy controller at /dev/ft0 and /dev/ntf0.

- How Linux Boots

To identify a tape System drive, look your kernel messages Chapter 4 - Essential Files,in Servers, and Utilities Chapter 5

for lines like this:

- Configuring Your Network

Chapter 6 - Network Vendor: HP Services

Model: C1533A

Rev: 9503 ANSI SCSI revision: 02 Chapter 8 - Development Tools st: Version 20010812, bufsize 32768, wrt 30720, max init. bufs 4, s/g segs 16 Chapter 9 - Compiling Softwarest0 Fromat Source Code channel 0, id 4, lun 0 Attached scsi tape scsi0, Chapter 7 - Introduction to Shell Scripts Type: Sequential-Access

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

There12 are- Printing two versions Chapter

of each tape device on a Unix system:

Chapter 13 - Backups

rewind tapeFiles device ChapterA14 - Sharing with rewinds Samba

the tape after every operation. For example, /dev/st0 is a rewind

Chapterdevice. 15 - Network File Transfer Chapter 16 - User Environments

Ano-rewind tape device does not rewind the tape after an operation. No-rewind devices start with n; for example, /dev/nst0 is a no-rewind device. Chapter 18 - Further Directions Chapter 17 - Buying Hardware for Linux Appendix A - Command Classification

For day-to-day operation, rewind devices are practically useless. You may as well forget that they exist; the next few sections show that you often need to reposition the tape.

Bibliography Index

List of Figures When working

with tapes, you sometimes need to know the tape block size. Applications tend to write to a certain block size, and many tape drives do not allow you to read from the tape if you specify List Sidebars block size. This is almost never a problem, because you normally write to and read from the theofincorrect tape with the same program. However, if you want to use dd to get direct access to tape files, you may need to specify the block size manually (see Section 13.6.7). List Tables theoftape in

Before you get started with a tape drive, you should set the TAPE environment variable to the no-rewind device name. This variable saves a lot of typing in the long run, in particular, with -f options for the mt andtar commands (which are explained in the next section ).

13.6.1Working with Tape Drives A tape is one of the simplest forms of media available. You can think of a tape as a sequence of files with afile mark between each file, as shown in Figure 13-1. Notice how there is no file mark at the beginning of the tape and that the first file is numbered 0.

Figure 13-1: Files and file marks on a tape. A tape does not contain a filesystem. Furthermore, there is no information on a tape indicating the name of each file (though automated backup systems usually include a special tape index file at the beginning of the tape). When manually working with a tape, you work with file numbers and file marks, and nothing else. To access the data on a tape, you must manipulate the tape drive head.Figure 13-2 shows the initial position of the tape head. Let's say that your tape device is st0, so you're using the tape device /dev/nst0. First, verify the tape position with the mt status command (the -ffile option specifies the tape device file; remember that you do not need this if you set the TAPE environment variable): mt -f /dev/nst0 status

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topicsat such networking, Figure 13-2: The tape head theasbeginning offirewalls, a tape. development tools, device management, shell scripts, and sharing printers with Samba.

The output should look like this (the following output is from a DAT drive): Table of Contents How Linux Works—What Every Super-User Should Know

SCSI 2 tape drive: - The Basics File number=0, block number=0, partition=0. Chapter 2 - Devices, Disks, Filesystems, and the Kernel Tape block size 0 bytes. Density code 0x13 (DDS (61000 bpi)). Chapter 3 - How Linux Boots Soft error count since last status=0 Chapter 4 - Essential System Files, Servers, and Utilities General status bits on (41010000): Chapter 5 - Configuring Your Network BOT ONLINE IM_REP_EN Chapter 1

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

Development Tools There's a- lot of information here:

Chapter 9

- Compiling Software From Source Code

ChapterThe 10 -current Maintaining Kernelis file the number

0.

Chapter 11 - Configuring and Manipulating Peripheral Devices ChapterThe 12 -current Printing block

number is 0, so the tape head is at the beginning of a file.

Chapter 13 - Backups

theSamba partition; ChapterYou 14 -should Sharingignore Files with Chapter 15 - Network File Transfer

size is 0, meaning ChapterThe 16 -block User Environments

most tape drives don't support it anyway.

that the tape drive does not have a fixed block size.

Chapter 17 - Buying Hardware for Linux

The density code indicates how much data can fit on the tape.

Chapter 18 - Further Directions

Appendix A - Command Classification

The soft error count is the number of recoverable errors that have occurred since the last time you ran

Bibliography mt status. Index List of Figures General

status bits explain more about the state of the tape and tape drive. BOT means "beginning of and ONLINE reports that the tape drive is ready and loaded. See Section 13.6.6 for a full list of List of Sidebars mt status bits. List of Tables tape,"

13.6.2Creating Archives on a Tape It is difficult to understand how a tape drive works by running through various files on a random tape in a collection of backups. Therefore, to explain the process of searching through a tape, this section shows you how to create some archives for yourself before going into the specifics of unarchiving. Once you have learned this, you will be able to play with a tape without significant confusion or worrying about losing data. Here is a procedure for creating three files on a tape — specifically, tar archives of /lib,/boot, and /dev: 1. Put a new tape in your drive (a blank tape, or one that you don't care about). 2. Make sure that your TAPE environment variable is set to the no-rewind tape device. 3. Runmt status to verify that the tape is in the drive and your TAPE variable is set. 4. Change to the root directory. 5. Create a tar archive of the first file on the tape with this command: tar zcv lib 6. Runmt status. The output should look something like the following, indicating that the tape is on the next file (file 1): SCSI File Tape Soft

2 tape drive: number=1, block number=0, partition=0. block size 0 bytes. Density code 0x13 (DDS (61000 bpi)). error count since last status=0

General status bits on (81010000): EOF ONLINE IM_REP_EN How Linux Works: What Every Super-User Should Know by Brian Ward

7. Create archive your /boot Noan Starch Press of © 2004 (347 pages) directory:

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and advanced topics such as networking, firewalls, development tools, device management, shell scripts, and tar covering zcv boot sharing printers with Samba.

Table 8. of Contents Create an

archive of your /dev directory:

How Linux Works—What Every Super-User Should Know Chapter 1 Chapter 2 Chapter 3

- The Basics

tar zcv dev

- Devices, Disks, Filesystems, and the Kernel - How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities The contents of your tape should now look like Figure 13-3.

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

Figure 13-3: The tape containing three archive files with the head at the start of a new file.

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups

13.6.3Reading From Tape

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 -you Userhave Environments Now that some files

on the tape, you can try reading the archive: 1. Change to the /tmp directory to avoid any accidents (in case you accidentally type x instead of t in Chapter 18 - Further Directions one of the steps that follow). Chapter 17 - Buying Hardware for Linux Appendix A - Command Classification Bibliography 2. Rewind

the tape:

Index List of Figures

mt rewind

List of Tables

List of Sidebars

3. Verify the first file on the tape, the archive of /lib: tar ztv A long listing of the files in the archive should scroll by. 4. Runmt status. The output should look like this: SCSI 2 tape drive: File number=0, block number=4557, partition=0. Tape block size 0 bytes. Density code 0x13 (DDS (61000 bpi)). Soft error count since last status=0 General status bits on (1010000): ONLINE IM_REP_EN The tape is still at file 0, the first file on the tape. How did this happen? The answer is that as soon as it finishes reading, tar stops where it is on the tape, because you may want to do something crazy (such as append to the archive). The tape head is now at the very end of file 0 (notice the block count in the mt output); see Figure 13-4.

Figure 13-4: The tape head at the end of file 0. The most important consequence of the new tape position is that another tarztv does not access the next archive on the tape, because the head is not at the beginning of the next file, but rather, it is at the

beginning of the file mark. To advance the tape forward to the next file (the /boot archive), use another mt command: How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

mt fsf

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics networking, firewalls, development management, This command moves the tape sosuch thatasthe head is at the end of the filetools, markdevice (the beginning ofshell the scripts, /bootand sharing printers with Samba. archive), as shown in Figure 13-5. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Figure 13-5: The tape head at the beginning of file 1. - Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Introduction to Shell Scripts 13.6.4-Extracting Archives

Chapter 7 Chapter 8

- Development Tools

Chapter 9 - Compiling To extract archivesSoftware from a From tape,Source all youCode need

to do is replace the t in the commands in the previous

Chapter 10with - Maintaining the Kernel section xp: Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

tar zxpv

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - you Network File Transfer As usual, should double-check

your current working directory before extracting any archives.

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

13.6.5Moving Forward and Backing Up

Chapter 18 - Further Directions

Appendix A - Command Classification

Themt fsf Bibliography the tape Index

command moves the tape to the start of the next file. There is also a command for moving back:

List of Figures List Tables mtof bsf List of Sidebars

However, it is important to understand that this command rewinds the tape to the end of the previous file on the tape; that is, to the start of the next file mark that the tape head sees. Let's say that you are at the start of file 1, as shown earlier in Figure 13-5. Running mt bsf reverses the state to that shown in Figure 13-4. Try it for yourself, and then run another mt status. The file number should be 0 with a block number of -1 (the driver cannot compute the length of the file by itself). In general, to get back to the start of the previous file when you are at the start of a file, you need to move back twice and then forward once. Because most mt tape movement commands take an optional file count (an example is the 2 here), you can run the following sequence: mt bsf 2 mt fsf However, there's another gotcha here, because the tape in this example is at the start of file 1. Running mt bsf 2 attempts to move the tape back two file marks. However, the beginning of the tape is not a file mark. Therefore, the mt bsf 2 in this sequence backs up, passing one file mark, and then hits the beginning of the tape, producing an I/O error. The subsequent mt fsf skips forward again, moving the tape back to the beginning of file 1. Therefore, if you want to get to file 0, you should always rewind the tape instead with mt rewind. Note The Linux mt includes a bsfm command that is supposed to take you directly to the start of the previous file. This nonstandard extension does not work quite correctly; if the tape head is at the start of a file, mt bsfm runs mt bsf, then mt fsf, taking you right back to where you started. The bottom line is that you need to pay careful attention to the tape head position with respect to the file marks and choose the appropriate command. If it all seems a little ridiculous to you, it's probably not worth sweating over; to get to file n on a tape, this always works (though it may be slower):

mt rewind mt fsf n How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

To eject the No tape, usePress the ©offline command: Starch 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and mt offline sharing printers with Samba.

Table of Contents How Linux Works—What Every Super-User Should Know

The Basics 13.6.6-mt Commands and Status

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

These3are the Linux mostBoots common Chapter - How

mt commands:

Chaptermt 4 status - EssentialProduces System Files, Servers, and Utilities a status report. Chapter 5

- Configuring Your Network

Chaptermt 6 fsf - Network Services n Winds forward

to the start of the first block of the next file. The n parameter is optional; if instead of just one.

Chapterspecified, 7 - Introduction to ahead Shell Scripts mt skips n files Chapter 8

- Development Tools

Chaptermt 9 bsf - Compiling Software Source n Winds backFrom to the endCode of the

previous file. The n is an optional file count.

Chapter 10 - Maintaining the Kernel

Rewinds the tape. Peripheral Devices Chaptermt 11 rewind - Configuring and Manipulating Chapter 12 - Printing

Rewinds the tape, then prepares for tape removal. In some tape drives, the tape drive ejects the tape; others, the drive unlocks the tape so that you can manually remove it. Chapter 14 - Sharing Filesinwith Samba Chaptermt 13 offline - Backups

Chapter 15 - Network File Transfer

mt retension Winds the tape all the way forward and then rewinds. This sometimes helps with tapes that you're having trouble reading. Chapter 17 - Buying Hardware for Linux Chapter 16 - User Environments Chapter 18 - Further Directions

mt erase Erases the entire tape. This usually takes a long time.

Appendix A - Command Classification Bibliography There are Index useful

countless other mt commands documented in the mt(1) manual page, but they really aren't very unless you're trying to extract blocks from the center of a file or to set SCSI tape driver options.

List of Figures List of Tables Running mt

status yields a number of status bit codes (such as the BOT code from Section 13.6.1). Here codes:

List Sidebars areof the important

ONLINE The drive is ready with a loaded tape. DR_OPEN The drive is empty (possibly with the door open). BOT The current position is the beginning of the tape. EOF The current position is the beginning of a file (the end of a file mark). This is a somewhat misleading code, because you can confuse it with the end of file. EOT The current position is the end of the tape. EOD The current position is the end of recorded media. You can reach this by trying to mt fsf past the very last file marker. WR_PROT The current tape is read-only.

13.6.7Direct File Access tar isn't the only command that can write archives to a tape. Sometimes you may not know what is on the tape, and even if you do know, you may want to copy a file from the tape to the local filesystem for further (and easier) examination. Your good old friend dd can do this, as this example for /dev/nst0 shows: dd if=/dev/nst0 of=output_file

This doesn'tHow always work — you may get Super-User an I/O errorShould because you did not specify the correct block size. Linux Works: What Every Know The programbythat writes tar, the Brian Ward the archive on the tape usually determines the block size; in the case ofISBN:1593270356 block size isNo 10KB (specified to dd as 10k). Therefore, because dd defaults to a block size of 512 bytes, Starch Press © 2004 (347 pages) you would use the following command to copy a tar archive from the tape to output_file: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

dd bs=10k if=/dev/nst0 of=output_file Table of Contents How Linux Works—What Every Super-User Should Know

Block sizes for common programs are listed in Table 13-1 (see also Section 13.7).

Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Table 13-1: Block Sizes for Common Archiving Programs

Chapter 4 - Essential System Archiver Block SizeFiles, Servers, and Utilities Chapter 5

- Configuring Your Network

tar 6 Chapter

10KB (20 x - Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

cpio9 Chapter

- Compiling Software From Source Code 512 bytes

dd

512 bytes)

512 bytes

10KB (20 x 512 bytes)

dump

bs=10k bs=512

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Amanda 32KB

bsParameter

bs=512 bs=10k bs=32k

Chapter 13 - Backups Chapter 14 - Unlike Sharingtar, Filesdd with Samba advances

Note

Chapter 15 - Network File Transfer

to the file mark.

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

the tape head to the next file on the tape, instead of just moving it up

HowArchivers Linux Works: What Every Super-User Should Know 13.7Other by Brian Ward

ISBN:1593270356

Presscommon © 2004 (347 archiver pages) AlthoughtarNoisStarch the most on Linux systems, there are two other important systems This guideand describes inner workings a Linux system beginning with sections the file system and boot process and called dump/restore cpiothe that you shouldofbe aware of. The following provide an overview of covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and the most important archiver operations, but they do not go into very much detail. sharing printers with Samba.

13.7.1Dump and Restore

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1 - The Basicssystem The dump/restore

is a throwback to the older days of Unix. Unlike most other archivers, the dump and therefore it only supports certain filesystem Chapter Linux Boots types.3On- How Linux, this list currently includes only the ext2 and ext3 filesystems, and this is unlikely to Chapter 4 because - Essential there SystemisFiles, change, littleServers, interestand in Utilities porting the system to the myriad other filesystems. This Chapter 5 - Configuring Your Network a somewhat unattractive backup solution. Still, some people prefer dump inflexibility makes dump/restore Chapter 6 - because Network Services (probably they're too old to learn new tricks, or perhaps that they don't like their backup program Chapter 7 - Introduction Shell on Scripts to change the accesstotimes their files), so you may be stuck with reading one of these archives. Chapter 2 -looks Devices, Disks, Filesystems, and the program at the internal structure of Kernel a filesystem,

Chapter 8

- Development Tools

Dump

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

Thedump to back up an entire directory Chapter 11 - command Configuring and Manipulating Peripheral Deviceslooks

like this:

Chapter 12 - Printing Chapter 13 - Backups

dump -0 -f archive directory

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 -use User You can a Environments tape device

as archive if you like, or if your tape device is in the TAPE environment entirely.

Chapter 17 -you Buying Linux variable, canHardware omit -ffor archive Chapter 18 - Further Directions Appendix - Command Classification The-0 Aoption forces a full (level

0) backup. If you actually intend to use dump to do regular backups, add to make dump write date information to /usr/etc/dumpdates. With this file and option in Index place, you can specify backup levels other than 0 (for example, a level 5 with -5). Bibliography a-u option List of Figures List of Note TablesWhen List of Sidebars be

using -u, you must dump the entire filesystem — that is, the directory parameter must the mount point or the disk device (for example, /dev/hda4).

Restore Therestore program extracts files and directories from an archive created with dump. If you're only looking for one or a few files, you need to run restore in interactive mode, so follow this procedure: 1. Run the following command, where archive is the archive (this can be a tape drive): restore iavf archive

2. Wait until restore has read the filesystem index from the archive and prints a restore > prompt. 3. Use the cd and ls commands until you find a file or directory that you want to restore from the archive. 4. Add the file or directory to the extraction list with the add command (add as many files and directories as you like): addfile

5. Typeextract to begin the extraction. 6. After extraction, restore asks this question: set owner/mode for '.'? [yn]

If you want to set the current directory's permissions and owner to the same as the root directory in the archive, answer y. This is nearly always a bad choice for an interactive restore, so answer n if

you have any doubt. It's not hard to fix this if you do make a mistake, though. Note The root directory inWhat the archive corresponds to the originating filesystem's mount point. Let's say How Linux Works: Every Super-User Should Know that you dump a partition mounted at /home. None of the paths in the archive would contain ISBN:1593270356 by Brian Ward /home — that is,©/home/user No Starch Press 2004 (347 pages) would show up as /user in the archive. This guide describes the inner workings of a Linux system beginning with the file system and boot process and

To forgo interactive mode and restore everything set the permissions the management, current directory), use and covering advanced topics such as networking,(and firewalls, development tools,for device shell scripts, sharing printers with Samba. thervf options: Table of Contents restore rvf

archive

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

13.7.2-cpio How Linux Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

Linux 5administrators rarely use cpio Chapter - Configuring Your Network other 6tasks, but you should Chapter - Network Services extract7 Chapter Chapter 8

(or its newer, more capable cousin named afio) for backups or still have an idea of how this program works so that you can create, test, and

archives. - Introduction to Shell Scripts - Development Tools

cpio 9has- Compiling three modes: Chapter Software From Source Code Chapter 10 - Maintaining the Kernel

Create, or "copy-out," mode (activated with -o) takes a file list from the standard input, creates an archive from a matching directory hierarchy, and sends the result to standard output or a file. Chapter 12 - Printing Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 13 - Backups

Extract, or "copy-in," mode (activated with -i) tests and extracts files from an archive.

Chapter 14 - Sharing Files with Samba

ChapterPass-through 15 - Network File Transfer mode (activated Chapterjob 16 better - User Environments unless you have

with -p) copies files. tar and rsync (see Chapter 15) usually do this a very specific list of files. This book does not cover this somewhat

Chapterobscure 17 - Buying Hardware cpio mode. for Linux Chapter 18 - Further Directions Appendix A - Command Classification

Creating Archives

Bibliography Index Because

you are unlikely to have a cpio file lying around on your system, you should experiment by yourself. The cpio copy-out mode requires that you generate a file list first. You can use the List of Tables output of find to create a file list in a pipeline to cpio. List of Figures creating one List of Sidebars

Let's say that you want to archive /usr/local/bin as a file named local_bin.cpio: find /usr/local/bin | cpio -o > local_bin.cpio On any halfway modern system, the output of this command includes lines like this for every single file created: cpio: /usr/local/bin/file: truncating inode number This annoying message isn't anything to worry about; it just means that cpio can't store the full inode number in the limited space available in the archive. The very end of the command should contain a block count (by default, 512 bytes equal one block), as in this example output: 20967 blocks

Note If you need to write an archive to a tape, you have two choices (these are equivalent because the block sizes in cpio and dd are the same): cpio -o -O tape cpio -o | dd of=tape

Testing and Extracting Archives Now that you have local_bin.cpio, you can list its contents with this command:

cpio -i -t -v -I local_bin.cpio How Linux Works: What Every Super-User Should Know Brian Ward The options by have the following meanings: No Starch Press © 2004 (347 pages) -i Specifies copy-in mode.

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and -t Specifies a test archive. sharing printers with Samba.

-v Sets verbose mode; shows the files as ls -l would. You may omit this option if you don't care. Table of Contents How Linux Works—What Should (the Knowdefault -Ifile Reads Every fileSuper-User as the archive Chapter 1

file is the standard input).

- The Basics

Chapter 2 - Devices, Disks,replace Filesystems, the Kernel To extract an archive, the and -t with -d: Chapter 3

- How Linux Boots

Chapter 4

Files, Servers, and Utilities cpio -i- Essential -d -v System -I archive

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7 - Introduction Shell Scriptswith However, this can betodangerous

the local_bin.cpio archive that you created earlier, because that - Development Tools archive contains absolute pathnames. This can be a threat to system stability and security, especially if Chapter 9 - Compiling From Code can easily overwrite a file such as /etc/passwd. Use the -you extract as root,Software because theSource extraction Chapter 10 Maintaining the Kernel no-absolute-filenames option to prevent this: Chapter 8

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

cpio --no-absolute-filenames -i -d -v -I local_bin.cpio

Chapter 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Keep in mind that there are a few more cpio options that cpio may need in copy-in mode if it can't figure out some of the format options of the archive for itself: Chapter 17 - Buying Hardware for Linux the byte order. The default cpio format depends on the byte order of the architecture of Chapter-b 18Switches - Further Directions the CPU that used to create the archive, so if you have an archive from a completely different Appendix A - Commandwas Classification kind of machine, you may need this option. Bibliography Chapter 16 - User Environments

Index

-Cn Uses n as the archive block size.

List of Figures List of Tables

-Hname Uses name as the archive format (valid formats are bin,crc,hpbin,hpodc,newc,odc, tar, and ustar). Note that only GNU cpio supports all of these options.

List of Sidebars

13.7.3Amanda Tapes Amanda is an automatic backup system that writes a "hybrid" archive on a tape. That is, the first 32KB block in an Amanda tape contains information about the archive, and the rest of the blocks make up a regular archive in tar or dump format. If you come across an Amanda file, do the following to extract the files: 1. Put the first block into a file named header: dd if=file of=header bs=32k count=1 2. Runstrings header. The output should look something like this: AMANDA: FILE 20031117 duplex /etc lev 0 comp .gz program /bin/tar To restore, position tape at start of file and run: dd if= bs=32k skip=1 | /bin/gzip -dc | bin/tar -f... 3. Follow the instructions. Extract the contents from the rest of the file as follows (if you're using a tape drive as file, the tape head should already be correctly positioned, so don't use skip=1): dd if=file bs=32k skip=1 | unpack_command unpack_command should follow the output you got in step 2. For example, if you're dealing with a tar archive, unpack_command might look like this:

gzip -dc | tar xpf How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 13.8Further Backup Topics by Brian Ward

ISBN:1593270356

Starch the Press © 2004 of (347manual pages) This chapterNo covers basics backups for small systems. However, once you get into larger This guide describes theto inner workings of a Linux system beginning with the file system and boot process and operations, there is much more explore:

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Automated backups. Amanda (http://www.amanda.org/) is a popular, powerful, and free automatic network backup package (that is, after you figure out how it works).

Table of Contents

How Linux Works—What Know Tape changers.Every The Super-User Linux mtxShould command Chapter 1

can operate a tape changer and autoloader.

- The Basics

withDisks, Samba. ChapterBackups 2 - Devices, Filesystems, and the Kernel Chapter 3

- How Linux Boots

systems such asUtilities BRU. ChapterCommercial 4 - Essentialbackup System Files, Servers, and Chapter 5

- Configuring Your Network

Database backup systems (Oracle and the like). - Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

A good, comprehensive, and detailed guide to backups (especially for large organizations) is Unix Backup - Development Tools and Recovery [Preston].

Chapter 8 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 14: Sharing Files with Samba by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Your Linux machine probably doesn't live alone on your network. If you have a PC running Windows, it's only natural that you would want to permit access to your Linux system's files and printers from those Table of Contents Windows machines with the standard Windows network protocol, SMB (Server Message Block). Mac OS X How Linux Works—What Every Super-User Should Know also supports SMB filesharing. Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel The standard filesharing software suite for Unix is called Samba. Not only does Samba allow your How Linux Boots network's- Windows computers to get to your Linux system, but it works the other way around — you can Chapter 4 - Essential System Files, Servers, and Utilities print and access files on Windows servers from your Linux machine with the included client software. Chapter 3 Chapter 5

- Configuring Your Network

Chapter Network Services To set6up- a Samba server,

you need to perform these steps: 1. Create an smb.conf file.

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter - Compiling Software Sourceto Code 2. 9Add filesharing shareFrom sections smb.conf. Chapter 10 - Maintaining the Kernel Chapter - Configuring and Manipulating Devices 3. 11Add printer share sections toPeripheral smb.conf. Chapter 12 - Printing

4. 13Start the Samba Chapter - Backups

daemons: nmbd and smbd.

Chapter 14 - Sharing Files with Samba

Ashare resource that you Chapter 15is- a Network File Transfer

offer to a client, such as a directory or printer.

Chapter 16 - User Environments

The discussion of Samba in this chapter is concise, limited to getting Windows machines on a single subnet to see a stand-alone Linux machine through the Windows Network Neighborhood browser. There Chapter 18 - Further Directions are countless ways to configure Samba, because there are many possibilities for access control and Appendix A - Command Classification network topology. For the gory details on how to configure a large-scale server, you will find How Samba Bibliography Works [Lendecke] a much more extensive guide, and there is also information at the Samba Web site, Index http://www.samba.org/. List of Figures Chapter 17 - Buying Hardware for Linux

List of Tables List of Sidebars

How Linux Works: Every Super-User Should Know 14.1Configuring theWhat Server by Brian Ward

ISBN:1593270356

No Starchconfiguration Press © 2004 (347file pages) The central Samba is smb.conf, and it is usually located in Samba's lib directory (for This guide describes the inner workings a Linux system beginning with the file file system andetc bootdirectory, process and example,/usr/local/lib). However, someofdistributions put the configuration in an covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and such as /etc/samba or /usr/local/etc. The smb.conf file breaks down into several sections sharing printers with Samba. denoted with square brackets (such as [global] and [printers]). Table Contents Theof [global]

section in smb.conf contains general options that apply to the entire server and all shares. These options pertain primarily to network configuration and access control. Here is a sample Chapter 1 - The Basics that shows you how to set the server name, description, and workgroup: [global] section How Linux Works—What Every Super-User Should Know Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

[global] - Essential System Files, Servers, and Utilities # server name Chapter 5 - Configuring Your Network netbios name = name Chapter 6 - Network Services Chapter 4

Chapter 7

- Introduction to Shell Scripts

# server description Chapter 8 - Development Tools server string = MyFrom server Chapter 9 - Compiling Software Sourcevia Code

Samba

Chapter 10 - Maintaining the Kernel

# workgroup Chapter 11 - Configuring and Manipulating Peripheral Devices workgroup Chapter 12 - Printing=

MYNETWORK

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba

These parameters work as follows:

Chapter 15 - Network File Transfer Chapter 16 - User Environments

netbios name The server name. If you omit this parameter, Samba uses the Unix hostname.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Appendix A - Command Classification server string A short description

of the server. The default is the Samba version number.

Bibliography Index

The SMB workgroup name. If you're on a Windows NT domain, set this parameter to the of your domain.

workgroup List of Figures List of Tables name

List of Sidebars

14.1.1Server Access Control There are a few options that you can add to your smb.conf file to put limits on the machines and users that can access your Samba server. The following list includes many options that you can set in your [global] section, as well as in the other sections that control individual shares (described later in the chapter): interfaces Set this to have Samba listen on the given networks or interfaces. Here are two examples: interfaces = 10.23.2.0/255.255.255.0 interfaces = eth0

bind interfaces only Set this to yes when using the interfaces parameter in order to limit access to machines that you can reach on those interfaces. valid users Set this to allow the given users access. For example: valid users = jruser, bill

guest ok Set this parameter to true if you would like a share to be available to anonymous users on the network. guest only Set this parameter to true to allow anonymous access only. browseable Set this to make shares available in Samba's browseable share list. If you set this parameter to no for any or all shares, you will still be able to access shares on the Samba server, but they will not be browseable, and therefore you will need to know their exact names.

14.1.2Passwords Howonly Linux Works: Whataccess Every Super-User Should Knowwith password authentication. In general, you want to allow to your Samba server ISBN:1593270356 by Brian Ward Unfortunately, the basic password system on Unix is different than that on Windows, so unless you specify No Starch Press © 2004 (347 pages) clear-text network passwords or authenticate passwords with a Windows server, you must set up an This guide describes inner workings of a how. Linux system beginning with the file system and boot process and alternative password file. Thisthe section shows you covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Assuming that your Samba configuration directory is /etc/samba, you can use these entries in your [global] section to define the Samba password file as /etc/samba/passwd_smb:

Table of Contents

How Linux Works—What Every Super-User Should Know

# 1use a Basics separate Chapter - The

password file for Samba to enable encrypted passwords security = user Chapter 2 - Devices, Disks, Filesystems, and the Kernel encrypt passwords = yes Chapter 3 - How Linux Boots smb file Files, = /etc/samba/passwd_smb Chapter 4 -passwd Essential System Servers, and Utilities Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

With these lines in place, you can manipulate the passwd_smb password file with the smbpasswd - Development Tools program. Chapter 9 - Compiling Software From Source Code Chapter 8

Chapter 10 - Maintaining the Kernel

Note If you have access to a Windows NT domain, you can set security = domain, to make Samba use the domain's usernames and eliminate the need for an SMB password file. However, Chapter 12 - Printing in order for domain users to access the machine running Samba, each domain user must have a Chapter 13 - Backups local account with the same username on the machine running Samba. Chapter 11 - Configuring and Manipulating Peripheral Devices

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Adding and Deleting Users

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

The first thing you need to do in order to give a Windows user access to your Samba server is to add the user to the passwd_smb file with the smbpasswd -a command:

Chapter 18 - Further Directions

Appendix A - Command Classification Bibliography

smbpasswd Index

-a username

List of Figures List of Tables

Theusername parameter to the smbpasswd command must be a valid username on your Linux system.

List of Sidebars

Much like the regular system's passwd program would, smbpasswd asks you to enter the new user's password twice. If the Samba password file does not exist, smbpasswd creates it for you, then confirms that it has created the new user. To remove a user, use the -x option to smbpasswd: smbpasswd -x username

At times, you may not necessarily want to delete a user, but rather, temporarily deactivate the user. The d option disables a user; and -e re-enables the user: smbpasswd -d username smbpasswd -e username

Changing Passwords You can change a Samba password as the superuser by using smbpasswd with no options or keywords other than the username: smbpasswdusername

However, if the Samba server is running, any user can change their own Samba password by entering smbpasswd by itself on the command line.

How Linux Works: What Every Super-User Should Know 14.2Starting the Server by Brian Ward

ISBN:1593270356

NoaStarch 2004 (347 pages) After you add user Press and a© password, you should probably test your server. To start the server, you need the inner workings of a Linux system beginning with the file is system andpath boot process to run nmbd This andguide smbddescribes with the following arguments, where smb_config_file the full of yourand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and smb.conf file: sharing printers with Samba.

nmbd -D -s smb_config_file Table of Contents smbd -s smb_config_file How Linux-D Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Thenmbd a NetBIOS Chapter 3 - daemon How Linuxis Boots

name server, and smbd does the actual work of handling share requests. the smb.conf file while smbd is running, notify the daemon the changes a HUP signal. Chapter 5 -ofConfiguring Your with Network The-D4 option specifies mode. If Utilities you alter Chapter - Essential Systemdaemon Files, Servers, and Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What EveryFiles Super-User Should Know 14.3Diagnostics and Log by Brian Ward

ISBN:1593270356

Starch Pressupon © 2004 starting (347 pages)one of the Samba servers, an error message appears on the If somethingNo goes wrong ThisHowever, guide describes the inner workingsmessages of a Linux system beginning with theand file system and boot command line. runtime diagnostic go to the log.nmbd log.smbd logprocess files. and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

These files are usually in a var directory, but you can change the location to dir by specifying the -l dir option to smbd and nmbd. However, if you want to override the log directory location (to /var/log, Table of Contents for example), it's usually better to change the log file directory and log filename at once with the logfile How Linux Works—What Every Super-User Should Know parameter in smb.conf. You can force the log output from smbd to a file with this line in the [global] Chapter 1 - The Basics section of your smb.conf: Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

log file = /var/log/smb.log Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Unfortunately, this does not set the nmbd log directory; if you want the log output from both daemons to go - Introduction to Shell Scripts to the same file, you must still use nmbd -l /var/log/smb.log. Chapter 8 - Development Tools Chapter 7 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 14.4Sharing Files by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) To export a No directory to SMB clients (that is, to share a directory with a client), add a section like this to This file, guidewhere describes the inner workings a Linux system beginning with and the file system and full bootdirectory process and yoursmb.conf label is what you of would like to call the share, path is the covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and path: sharing printers with Samba.

[label] Table of Contents = path Every Super-User Should Know How path Linux Works—What Chapter 1 - The = Basics comment share

description

Chapter 2 - Devices, Disks, Filesystems, and the Kernel guest ok = no Chapter 3 - How Linux Boots writable = yes Chapter 4 - Essential printable = System no Files, Servers, and Utilities Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

These8parameters areTools useful Chapter - Development

in directory shares: share. The public parameter is a synonym.

Chapterguest 9 - Compiling Software From Source ok Allows guest access toCode the Chapter 10 - Maintaining the Kernel

A yes true setting here marks Chapterwritable 11 - Configuring andor Manipulating Peripheral Devicesthe

share as read-write. Do not allow guest access to a

Chapterread-write 12 - Printing share. Chapter 13 - Backups

Specifies a printing Chapterprintable 14 - Sharing Files with Samba

share; this parameter must be set to no or false for a directory

Chaptershare. 15 - Network File Transfer Chapter 16 - User Environments

veto files Prevents the export of any files that match the given patterns. You must enclose each inside forward slashes (so that it looks like /pattern/). Here's an example that bars object Chapterpattern 18 - Further Directions files, as well as any file or directory named bin: Appendix A - Command Classification Chapter 17 - Buying Hardware for Linux

Bibliography Index

veto files = /*.o/bin/

List of Figures List of Tables List of Sidebars

14.4.1Home Directories You can put a special section called [homes] in your smb.conf file if you want to export home directories to users. The section should look like this:

[homes] comment = home directories browseable = no writable = yes

By default, Samba reads the logged-in user's /etc/passwd entry to determine the user's home directory for[homes]. However, if you don't want Samba to follow this behavior (that is, you want to keep the Windows home directories in a different place than the regular Linux home directories), you can use the %S substitution in a path parameter. Here is an example that switches a user's [homes] directory to /u/user: path = /u/%S

Samba substitutes the current username for the %S.

How Linux Works: What Every Super-User Should Know 14.5Sharing Printers by Brian Ward

ISBN:1593270356

No Starch 2004 (347 to pages) You can export all of Press your©printers Windows clients with a special [printers] section in your This Here's guide describes the inner workings of a Linux system beginning smb.conf file. how the section looks when you're using CUPS:with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

[printers] = Tablecomment of Contents

Printers

= Every yes Super-User Should Know How browseable Linux Works—What printing = CUPS Chapter 1 - The Basics path cups Disks, Filesystems, and the Kernel Chapter 2 -=Devices, printable = yes Chapter 3 - How Linux Boots writable = no Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

To use the printing = CUPS parameter, your Samba installation must be configured and linked against - Introduction to Shell Scripts the CUPS library. Chapter 8 - Development Tools Chapter 7 Chapter 9

- Compiling Software From Source Code

As you learned in Chapter 12, there are several other printing systems in addition to CUPS. On Linux, you can set the printing parameter to BSD,LPRNG,PLP, or CUPS. Of these, CUPS is the easiest.

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

Note Depending on your configuration, you may also want to allow guest access to your printers with ok = yes option because you may not want to give a Samba password or account Chapter 14 - Sharing Files with Samba to everyone who needs to access the printers. Chapter 13 - the Backups guest

Chapter 15 - Network File Transfer Chapter 16 - User Environments

14.5.1Sharing a Single Printer

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

If you want to export a single printer, Appendix A - Command Classification

you can do so with a printer section that looks like this:

Bibliography Index [printer_name] List of Figures

comment = My printer printer name = printer_name List of Sidebars printing = CUPS path = cups browseable = yes printable = yes List of Tables

You can specify a driver name for Windows clients with the printer driver parameter. For example, to tell a client that the printer is an HP LaserJet 4M, you can use the following in the printer section: printer driver = HP LaserJet 4M

How the Linux Samba Works: WhatClient Every Super-User Should Know 14.6Using by Brian Ward

ISBN:1593270356

No Starch © 2004named (347 pages) Samba comes with aPress program smbclient that can print to and access remote Windows shares. This guide describes inneryou workings a Linux system beginning fileinteract system and boot process and This program comes in handythe when are inofan environment where with you the must with W indows covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and servers that sharing offer no Unix-friendly means of communication. printers with Samba.

To get started with smbclient, use the -L option to get a list of shares from a remote server named Table of Contents SERVER: How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

smbclient -L -U username Chapter 2 - Devices, Disks, Filesystems, SERVER and the Kernel Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

You do not need -Uusername if your Linux username is the same as your username on SERVER. - Configuring Your Network

Chapter 5 Chapter 6

- Network Services

After running this command, smbclient asks for a password. If you want to try to access a share as a - Introduction to Shell Scripts guest, you can press ENTER; otherwise, enter your password on SERVER.

Chapter 7 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code Upon success, you should get a share list like this:

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Sharename Chapter 12 - Printing

Type ---Software Chapter 14 - Sharing Files with SambaDisk Scratch Disk Chapter 15 - Network File Transfer IPC$ IPC Chapter 16 - User Environments ADMIN$ IPC Chapter 17 - Buying Hardware for Linux Printer1 Printer Chapter 18 - Further Directions Printer2 Appendix A - Command Classification Printer --------Chapter 13 - Backups

Comment ------Software distribution Scratch space IPC Service IPC Service Printer in room 231A Printer in basement

Bibliography Index

Look at the Type field to make sense of each share. You should only pay attention to the Disk and Printer shares (the IPC shares are for remote management). In this list, there are two disk shares and List of Tables two printer shares. You can use the name in the Sharename column to access the share. List of Figures

List of Sidebars

14.6.1Accessing Files If you need only casual access to files in a disk share, use the following command (again, you can omit the -Uusername if your Linux username matches your username on the server): smbclient -U username '\\SERVER\sharename'

Upon success, you will get a prompt like this: smb: \>

In this file transfer mode, smbclient is similar to the Unix ftp; you can run these commands: getfile Copies file from the remote server to the current local directory. putfile Copies file from the local machine to the remote server. cddir Changes the directory on the remote server to dir. lcdlocaldir Changes the current local directory to localdir. pwd Prints the current directory on the remote server, including the server and share names. !command Runs command on the local host. Two particularly handy commands are !pwd and !ls to determine directory and file status on the local side. help Shows a full list of commands.

Using the SMB Filesystem

If you need frequent access to files on a W indows server, you can attach the share directly to your system with the smbmount command: How Linux Works: What Every Super-User Should Know Brian Ward smbmount by '\\SERVER\sharename\' -c 'mount mountpoint' -U username -P password

ISBN:1593270356

No Starch Press © 2004 (347 pages)

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

To use this command, youwith must have the smbfs kernel driver loaded as a module or directly compiled into sharing printers Samba. the kernel. In addition, the rest of the Samba programs should be in your path. By default, a Samba installation built from source code does not include the smbmount command. You must specify --withTable of Contents smbmount when running the Samba configure script to create these extra programs. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Devices, Disks,to Filesystems, and the Kernel 14.6.2-Printing a Windows Share

Chapter 2 Chapter 3

- How Linux Boots

Chapter 4 - Essential Files, Servers, and Utilities The easiest way toSystem print to a Windows SMB share

is through CUPS. Follow these steps to get a printer

Chapter 5 - Configuring Your Network working: Chapter 6

- Network Services

1. Put the CUPS SMB backend in place. Find the smbspool program in your Samba distribution, and - Introduction to Shell Scripts then create a symbolic link named smb in the backend directory to smbspool, like this:

Chapter 7 Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

ln- Maintaining -s smbspool_path/smbspool cups_prefix/lib/cups/backend/smb Chapter 10 the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

2. 13Restart CUPS. Chapter - Backups Chapter 14 - Sharing Files with Samba

3. Runlpinfo -v to confirm that the SMB spooler is in the available backends. You should see this in the output:

Chapter 15 - Network File Transfer Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

network smb Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index 4.

Add a new printer as outlined in Chapter 12. If you don't need a password to access the printer, use as the printer device path (notice that the backslashes are forward slashes in CUPS):

the following List of Figures List of Tables

List of Sidebars smb://SERVER/sharename

If you need a username and password, add them to the front of the server: smb://username:password@SERVER/sharename If your target printer is in a different W indows workgroup, you can specify the workgroup in the first part of the name: smb://username:password@WORKGROUP/SERVER/sharename

Sending Files Directly to a Printer Share If you have a file that is suitable for a printer (such as a PostScript file that you want to send to a PostScript printer), you can send it directly to the printer share with this smbclient variant: smbclient '\\SERVER\sharename' -U username -P < file This command is particularly useful when testing and troubleshooting printers. Working with CUPS and Samba simultaneously can be difficult, so if you find yourself running into trouble when trying to access a printer on a Windows system, try going through these steps: 1. Use the Windows system to print a test document to a file, then transfer file to your Linux system. 2. Run the command in the preceding example to attempt to print the test file. 3. If the file does not print, you have a problem on the Samba side. Otherwise, the problem lies with CUPS.

How Linux Works: What Every Super-User Should Know Chapter 15: Network File Transfer by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

This book's primary focus is the single-machine environment. However, any modern machine is on a network. Eventually, you will want to transfer files from one Unix machine to another. There are many Table of Contents ways to move files around, but the choices usually come down to these: How Linux Works—What Every Super-User Should Know ChapterUsing 1 - The Basics a simple Chapter 2

command such as scp if you need to transfer just a few files.

- Devices, Disks, Filesystems, and the Kernel

ChapterUsing 3 - How Linux Bootsprogram an archiving

such as tar through an ssh pipeline to transfer a directory hierarchy.

ChapterHere 4 - is Essential System Files, Servers, and Utilities an example: Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

tar cBvf - directory | ssh remote_host tar xBvpf -

Chapter 9

Compiling Software From Source Code This-old method gets the job done, but it is not very flexible. In particular, after the transfer completes, the remote host may not have an exact copy of the directory. If directory already exists on the Chapter 11 - Configuring and Manipulating Peripheral Devices remote machine, and it contains some extraneous files, those files persist after the transfer. Chapter 10 - Maintaining the Kernel Chapter 12 - Printing

ChapterUsing 13 - Backups a synchronizer

system that duplicates an entire directory structure on the remote host. The two are rsync and rdist.

Chaptermost 14 - popular Sharing Files with Samba utilities synchronizer Chapter 15 - Network File Transfer ChapterUsing 16 - User old,Environments clunky, insecure

programs like ftp that you should not use.

Chapter 17 - Buying Hardware for Linux

This chapter explains the Chapter 18 - Further Directions

rsync system. The main advantages of rsync over other systems are these:

Appendix A - Command Classification

There Bibliography Index

is only one command to learn, rsync, which has a relatively simple syntax.

It offers relatively good performance.

List of Figures List of Tables

It has multiple operating modes.

List of Sidebars

HowBasics Linux Works: What Every Super-User Should Know 15.1rsync by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) The base requirement of the rsync system is that you install the rsync program on the source and This guide inner workings of a Linux with the file system boot process and destination hosts. Thedescribes easiestthe way to transfer files is tosystem use a beginning remote shell account. Thisand section assumes covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and that you want to transfer files to or from a machine to which you have SSH access. sharing printers with Samba.

On the surface, the rsync command is not much different than scp or rcp. In fact, you can run rsync with the same arguments as those utilities. For example, to copy a group of files to your home directory on How Linuxyou Works—What Every Super-User Should Know host, can run this command:

Table of Contents Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

rsync3file1 file2 ... Chapter - How Linux Boots

host:

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

However,- Network given your current system and rsync configuration, this command probably will not work, Services because the rsync program defaults to using rsh as the remote shell, and as you saw in Section 6.7 , you Chapter 7 - Introduction to Shell Scripts shouldn't use something this insecure. To get around this, you can tell rsync to use ssh with the --rsh Chapter 8 - Development Tools option: Chapter 9 - Compiling Software From Source Code Chapter 6

Chapter 10 - Maintaining the Kernel

rsync11 --rsh=ssh file1 file2Peripheral ... host:destination_dir Chapter - Configuring and Manipulating Devices Chapter 12 - Printing Chapter 13 - Backups

Look out this error message: Chapter 14 -for Sharing Files with Samba Chapter 15 - Network File Transfer Chapter - Userfound Environments rsync16 not Chapter 17 -connection Buying Hardwareunexpectedly for Linux rsync: Chapter - Further Directions rsync18 error: error in

closed (0 bytes read so far) rsync protocol data stream (code 12) at io.c(165)

Appendix A - Command Classification Bibliography

This Index

notice says that your remote shell can't find rsync on its system. If rsyncisn't in the remote path system, use --rsync-path=path to manually specify its location.

butofis on the List Figures List of Tables

If you don't want List of Sidebars

to type --rsh=ssh every time that you invoke an rsync command, set the RSYNC_RSH environment variable to ssh. The remainder of the commands in this chapter assume that you have done this. If your username is different on the remote host, add user@ to the hostname, where user is your username on host:

rsyncfile1 file2 ... user@host:destination_dir

With no extra options, rsync copies only files. In fact, if you specify just the options described so far and you supply a directory dir as an argument, you will see this message: skipping directory dir

To transfer entire directory hierarchies, complete with the same symbolic links, permissions, modes, and devices, use the -a option, as in this example: rsync -a dir host:destination_dir

If you're not too sure what will happen when you transfer the files, use the -n option to operate rsync without actually copying any files. The -n option implies the -v (verbose mode) option, showing details about the transfer and the files involved: rsync -na dir host:destination_dir

The output looks like this:

building file list ... done ml/nftrans/nftrans.html [more files] How Linux Works: What Every Super-User Should Know wrote 2183 bytes read 24 bytes 401.27 bytes/sec by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

15.1.1Making Exact Copies of a Directory Structure By default, rsync Table of Contents

copies files and directories without considering the previous contents of the destination d containing the files a and b to a machine that already file named d/c, the destination would contain d/a,d/b, and d/c after the rsync. To make Chapter 1 had - TheaBasics an exact the source directory, must delete files in the destination directory that do not exist Chapter 2 -replica Devices,ofDisks, Filesystems, and theyou Kernel in the source directory, such as d/c in this example. Chapter 3 - How Linux Boots directory. For example, you transferred the directory How Linux Works—What EveryifSuper-User Should Know

Chapter 4

- Essential System Files, Servers, and Utilities

Use the --delete option to remove files from the destination that don't reside in the local directory, like - Configuring Your Network this: Chapter 6 - Network Services Chapter 5 Chapter 7

rsync8 Chapter Chapter 9

- Introduction to Shell Scripts

-a --delete dir host:destination_dir - Development Tools - Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

Note Chapter 12 - Again, Printing if

you're not certain about your transfer, use the -n option to tell you if rsync wants to files before it actually performs the removal.

Chapter 13 - delete Backupsany

Chapter 14 - Sharing Files with Samba

You may wish toTransfer use --max-delete=n Chapter 15 - also Network File

to make sure that rsync deletes no more than n files in the essentially amounts to a last-ditch effort not to delete large numbers of files when 17 there's some problem on the source side. However, it will still delete files until reaching n deleted Chapter - Buying Hardware for Linux files, and in fact, you may notice that your version of rsync might have a bug, where it deletes one more Chapter 18 - Further Directions than n files. Appendix A - Command Classification target 16 directory. This option Chapter - User Environments

Bibliography Index

15.1.2Using the Trailing Slash

List of Figures List of Tables

You have to be particularly careful when specifying a directory as the source in an rsync command line. Consider this command:

List of Sidebars

rsync -a dir host:dest_dir Once this command completes, you will have a directory dir inside dest_dir on host. However, adding a slash (/) significantly changes the behavior: rsync -a dir/host:dest_dir Here, rsync copies everything insidedir to dest_dir on host without actually copying the dir directory itself. The dir directory will not exist on host after the operation. Therefore, you can think of a transfer of dir/ as an operation similar to cpdir/*dest_dir on the local filesystem. Let's consider an example. Say that you have a directory d containing the files a and b (d/a and d/b). You run the following command to transfer them to the c directory on host: rsync -a d/ host:c After the transfer completes, the directory c contains copies of a and b, but notd. If, however, you had omitted the trailing / on d,c would have gotten a copy of d, with a and b inside, so that as a result of the transfer you'd have files and directories named c/d/a and c/d/b on the remote host. When transferring files and directories to a remote host, accidentally adding a / after a path would normally be nothing more than a nuisance; you could then go to the remote host, add the dir directory, and put all of the transferred items back in dir. Unfortunately, you must be careful to avoid disaster when combining the trailing / with the --delete option. If you use the --delete option to transfer dir to dest_dir without the slash, rsync ignores everything in dest_dir except dir. Using dir/, on the other hand, makes rsync compare the contents of dir against dest_dir and makes dest_dir look

exactly like dir. Therefore, you can accidentally delete a whole bunch of files in dest_dir. WarningHow Be Linux wary Works: of your What shell's automatic filename completion feature. GNU readline and many other Every Super-User Should Know ISBN:1593270356 bycompletion Brian Ward libraries tack a trailing slash onto a completed directory name. No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and 15.1.3Excluding Files and Directories covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

One very important feature of rsync is its ability to exclude files and directories from a transfer operation. Let's say that you would like to transfer a local directory called src to host, but you want to exclude Table of Contents anything named RCS. You can do it like this: How Linux Works—What Every Super-User Should Know Chapter 1

rsync2 Chapter

- The Basics

-a --exclude=RCS srcandhost: - Devices, Disks, Filesystems, the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

It's important to noteYour thatNetwork this command Chapter 5 - Configuring

excludes all files and directories named RCS because --exclude filename. If you want to exclude only one specific item, specify an absolute that starts withScripts /, as in this example: Chapter 7 -path Introduction to Shell takes 6a pattern, an absolute Chapter - Networknot Services Chapter 8 Chapter rsync9

- Development Tools - Compiling Software From Sourcesrc Code host: -a --exclude=/src/RCS

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - The Backups first Note

/ in /src/RCS in this command is not the root directory of your system, but rather, the the transfer.

Chapter 14 - very Sharing Filesdirectory with Samba base of Chapter 15 - Network File Transfer Chapter 16 -aUser Here are fewEnvironments more tips on

exclude patterns:

Chapter 17 - Buying Hardware for Linux

have as many ChapterYou 18 -may Further Directions

--exclude parameters as you like.

Appendix A - Command Classification

If you Bibliography Index

use the same patterns time and again, place those patterns in a plain-text file (one pattern per line), and then use --exclude-from=file.

List of Figures

To exclude directories named item but include files with this name, use a trailing slash: -exclude=item/. List of Sidebars List of Tables

The exclude pattern is based on a full file or directory name component and may contain simple wildcards. For example, t*s matches this, but does not match ethers. If you exclude a directory or filename, but find that your pattern is too restrictive, use --include to specifically include another file or directory.

How Linux Works: What Every Super-User Should Know 15.2Checksums and Verbose Transfers by Brian Ward

ISBN:1593270356

No Starch Press 2004 checksums (347 pages) Thersync command uses© file (near-unique signatures) to determine whether any files on the This are guide describes workings of a Linux system beginning with the file system and boot process and transfer source already onthe theinner destination.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

The first time you transfer an entire directory hierarchy to a remote host, rsync sees that none of the files already exist at the destination, and it transfers everything. Testing your transfer with rsync -n verifies Table of Contents this for you. How Linux Works—What Every Super-User Should Know Chapter 1 - The rsync, Basics After running

try running it again, but this time as rsync -n or rsync-v. This time, no files copy of the file set exists on both ends, so the file Chapter 3 - How checksums areLinux the Boots same. Chapter - Devices, Filesystems, the Kernel should2 show up inDisks, the transfer list and because an exact Chapter 4

- Essential System Files, Servers, and Utilities

However, when the files the source Chapter 5 - Configuring Your on Network

side are not identical to the files on the destination side, rsync and overwrites any files that exist on the remote side. There are a few options that override this checksum behavior: Chapter 7 - Introduction to Shell Scripts transfers source files Chapter 6 -the Network Services Chapter 8

- Development Tools

Chapter--ignore-existing 9 - Compiling Software From Source Code Does not clobber

files already on the target side.

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

-b) Does not clobber files already on the target, but rather renames files by adding a ~ suffix to their names before transferring the new files.

Chapter--backup 12 - Printing (abbreviation:

existing Chapterthese 13 - Backups

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

--suffix=s Changes the suffix used with --backup from ~ to s.

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapter--update 18 - Further (abbreviation: Directions Appendix - Command Classification theA corresponding file on the

-u) Does not clobber any file on the target that has a later date than source.

Bibliography Index With

no special options, rsync operates quietly, only producing output when there is a problem. However, rsync -v for verbose mode, and if you need even more output, rsync -vv gives yet more List of Tables details. (You can tack on as many v options as you like, but two is probably more than you need.) For a List of Sidebars comprehensive summary after the transfer, use rsync --stats. List of can Figures you use

How Linux Works: What Every Super-User Should Know 15.3Compression by Brian Ward

ISBN:1593270356

No Starch Press © 2004 Many administrators always use(347 -zpages) in conjunction with -a to compress the data before transmission:

rsync

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and with Samba. -azsharing dir printers host:destination_dir

Table of Contents

Compression can improve performance certain How Linux Works—What Every Super-User ShouldinKnow

situations. For example, if you are uploading a large a slow connection (such as the slow upstream link on many DSL connections), or if the latency between theFilesystems, two hosts and is high, it helps. However, across a fast 100 Mb/s local area network, Chapter 2 - Devices, Disks, the Kernel the two endpoints can spend more time compressing and decompressing data than the network takes Chapter 3 - How Linux Boots transmitting the uncompressed files. and Utilities Chapter 4 - Essential System Files, Servers, amount data across Chapter 1 of - The Basics

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 15.4Limiting Bandwidth by Brian Ward

ISBN:1593270356

No Starch Press ©of 2004 (347and pages) It's easy to clog the uplink DSL cable modem connections when uploading a large amount of data describes inner workings of a Linux beginning the file system andduring boot process to a remote This host.guide Even thoughthe you won't be using your system (normally large)with downlink capacity such and a covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and transfer, your connection will still seem quite slow if you let rsync go as fast as it can, because outgoing sharing printers with Samba. TCP packets such as HTTP requests will have to compete with your transfers for bandwidth on your uplink. Table of Contents To get around this,

you can use --bwlimit to give your uplink a little breathing room. For example, to limit the bandwidth to 10000 kilobytes per second, you might do something like this:

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

rsync --bwlimit=10000 -a dir host:destination_dir - How Linux Boots

Chapter 3 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 15.5Transferring Files to Your Computer by Brian Ward

ISBN:1593270356

No Starch Press 2004for (347copying pages) Thersync command isn't©just files from your local machine to a remote host. You can also guide describes the inner to workings of a Linux beginning with the host file system and bootsource process path and transfer filesThis from a remote machine your local host system by placing the remote and remote covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and as the first argument on the command line. Therefore, to transfer src_dir on host to dest_dir on the sharing printers with Samba. local host, run this command: Table of Contents

rsync -a host:src_dir dest_dir How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 5

- machine. Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

you omit host:, can and useUtilities rsync Note Chapter 4 - If Essential System Files,you Servers,

for making duplicates of directories on your local

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works:Topics What Every Super-User Should Know 15.6Further rsync by Brian Ward

ISBN:1593270356

No many Starch Press 2004 (347 pages) rsync can do more©things that are beyond the scope of this book. One of its most significant This guide inner workings a Linux system beginning with thethat file system and boot and abilities is acting as adescribes networkthe server. Such a of server offers several modules you can call byprocess symbolic covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and names instead of pathnames. You can also offer public read-only access to the modules; this is a nice sharing printers with Samba. alternative to anonymous FTP. Table of Contents Another important

feature is rsync batch mode operation. Although it is fairly easy to write scripts distribution, rsync can also employ a number of auxiliary Chapter 1 - The Basics files related to command options, logging, and transfer state. In particular, the state files make long Chapter 2 - Devices, Disks, Filesystems, and the Kernel transfers faster, and easier to resume when interrupted. How Linux Works—What Every Super-User Should Know containing rsync commands to do network file

Chapter 3

- How Linux Boots

Chapter System Files, Servers, and Utilities There4are- Essential also many more command-line options

than those described in this chapter. To get a rough is more detailed information in the rsync(1) manual page as well as Chapter - Network Services at the 6rsync home page: http://samba.anu.edu.au/rsync/ . Chapter 5 - Configuring Network There overview, run rsyncYour --help. Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 16: User Environments by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

This book's focus is on the Linux system that normally lies underneath a user's interactive session. Eventually, the system and the user have to meet somewhere. You saw plenty of commands and shell Table of Contents features in Chapter 1 and Chapter 7, but there's still one little piece missing: the startup files that set How Linux Works—What Every Super-User Should Know defaults for the shell and other programs. Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel Most users do not pay close attention to their startup files. Over time, the files become cluttered, - How Linux Boots containing unnecessary environment variables and tests that can lead to annoying (or quite serious) Chapter 4 - Essential System Files, Servers, and Utilities problems. Worse still, operating system vendors usually do not consider the consequences of what they Chapter 5 - Configuring Your Network put in the default startup files, packing them full of items that may even confuse the user. Chapter 3

Chapter 6

- Network Services

Chapter 7 -inIntroduction Scripts Keeping tune with to theShell shell-oriented

theme of this book, this chapter focuses specifically on shell startup a Unix account in the past, it may have come with a bafflingly large array Chapter 9 - files, Compiling Software From Codebecause they nearly always start with a dot (.). You may be of startup sometimes calledSource dot-files Chapter 10 - to Maintaining theit Kernel surprised learn that really isn't necessary to have so many startup files. Chapter - Development files. If8 you have everTools received

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 16.1Appropriate Startup Files by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347should pages) keep the user in mind. If you are the only user on a machine, you When designing startup files, you This guide describes the— inner workings a Linux system beginning with theaffected, file systemand andit's boot process and don't have much to worry about if you makeofan error, you're the only one easy enough covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and to fix. However, if your new startup files are to be the defaults for all new users on a machine or network, sharing printers with Samba. or if you think that someone might copy your files for use on a different machine, your task becomes considerably more difficult. If you make an error in a startup file for ten users, you might end up fixing this Table of Contents error ten times. That's annoying, to say the least. How Linux Works—What Every Super-User Should Know Chapter 1

There are- The twoBasics essential goals to keep in mind when creating startup files for other users:

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Simplicity Keep the number of startup files small, and keep the files as small and simple as possible - Essential System Files, Servers, and Utilities so that they are easy to modify but hard to break. Each item in a startup file is just one more thing that Chapter 5 - Configuring Your Network can break. Chapter 6 - Network Services Chapter 4

Chapter 7

- Introduction to Shell Scripts

ChapterReadability 8 - Development Use Tools many

comments in the files, so that the users get a good picture of what each part of

Chaptera 9file- does. Compiling Software From Source Code Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: WhatElements Every Super-User Should Know 16.2Shell Startup File by Brian Ward

ISBN:1593270356

No Starch Press © 2004file? (347 pages) What goes into a shell startup Some things may seem obvious, such as the path and a prompt This guide inner be workings a Linux system with the file system and bootlike? process and setting. But wait, whatdescribes exactlythe should in theofpath, and whatbeginning does a reasonable prompt look And covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and how much issharing too much to put in a startup file? printers with Samba.

The next few sections outline the essentials of a shell startup file, covering the command path, manual page path, prompt, aliases, and permissions mask.

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

16.2.1-The Command Devices, Disks, Filesystems,Path and the Kernel

Chapter 2 Chapter 3

- How Linux Boots

The most part of any shell startup file Chapter 4 - important Essential System Files, Servers, and Utilities

is the command path. The path should cover the of any general interest to a regular user. At the very least, the path should contain these components, in this order: Chapter 6 - Network Services directories that contain application Chapter 5 - Configuring Yourevery Network Chapter 7

- Introduction to Shell Scripts

Chapter 8 - Development Tools /usr/local/bin Chapter 9 - Compiling Software From Source Code /usr/bin Chapter 10 - Maintaining the Kernel /usr/X11R6/bin Chapter /bin 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba This order ensures that you can

override standard default programs with site-specific program variants

Chapter 15in - Network File Transfer located /usr/local. Chapter 16 - User Environments

It's important to make every general-use Chapter 17 - Buying Hardware for Linux

program on the system available through one of the directories using the Encap system described in Section 9.4 ). If the general-use programs are located in moreClassification than just these four directories, it probably means that your system is getting out of Appendix A - Command control. Don't change the path in your user environment to accommodate a new system directory. In fact, Bibliography in the interest of minimizing the number of directories in the command path, some administrators prefer to Index fold the programs in /usr/X11R6/bin into /usr/local/bin or /usr/bin with the help of symbolic List of Figures links or a different installation prefix. List of Tables listed 18 above (for Directions example, Chapter - Further

List of Sidebars

Many users use a bin directory to store their own shell scripts and programs, so you may want to add this to the front of the path:

$HOME/bin

If you are interested in systems utilities (such as traceroute,ping, and lsmod), add the sbin directories to your path: /usr/local/sbin /usr/sbin /sbin

Adding Dot (.) to the Path There is one small but controversial command path component to discuss: the dot. Placing a dot (.) in your path allows you to run programs in the current directory without using ./ in front of the program name. This may seem convenient when writing scripts or compiling programs, but it is a bad idea for two reasons: It can be a security problem. You should never put a dot at the front of the path. For example, an attacker could put a Trojan horse named ls in an archive distributed on the Internet. Even if a dot is at the end of the path, you are still vulnerable to typos such as sl. It is inconsistent and can be confusing. A dot in the path can mean that a command's behavior can change according to the current directory.

16.2.2The Manual Page Path Your manual path (the MANPATH environment variable used by man) should match your command path, except that each directory in the manual page path variable should end in a /man directory rather than

/bin. Here is the manual page pathWhat that corresponds to the command How Linux Works: Every Super-User Should Know path listed in Section 16.2.1: by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) /usr/local/man:/usr/man:/usr/X11R6/man:$HOME/man This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

16.2.3The Prompt Table of Contents

Avoid a Works—What long, complicated, useless Should prompt. For How Linux Every Super-User Know

whatever reason, many administrators feel the need to everything, - The Basics including the kitchen sink. Just because you can place the current working directory, hostname, username, fancy decorations in a prompt, it doesn't mean that you should. Chapter 2 - Devices, Disks,and Filesystems, and the Kernel drag in1 Chapter Chapter 3

- How Linux Boots

Above4 all, avoid strange characters, as these: Chapter - Essential System Files, Servers,such and Utilities Chapter 5 Chapter { } =6

- Configuring Your Network

&- Network < > Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

special to Note Chapter 10 - Take Maintaining thecare Kernel

avoid >. This can cause erratic, empty files to appear in your current a section of your shell window, because > redirects

youManipulating accidentally copy and paste Chapter 11 - directory Configuringif and Peripheral Devices Chapter 12 - output Printing from

a file.

Chapter 13 - Backups

Even 14 a shell's default prompt isn't Chapter - Sharing Files with Samba

ideal. For example, the default bashprompt contains the shell name and version number, and the default tcsh prompt includes the hostname, the current working directory, Chapter 15 - Network File Transfer and a 16 >. - User Environments Chapter Chapter 17 - Buying Hardware for Linux

Here is a simple prompt setting for bash that ends with the customary $(the traditional csh prompt ends with %):

Chapter 18 - Further Directions

Appendix A - Command Classification Bibliography

PS1='\u$ Index

'

List of Figures List of Tables

The is a substitution List of \u Sidebars

for the current username (see the PROMPTING section of the bash manual page). Other popular substitutions include the following: \h The hostname (the short form, without domain names) \! The history number \w The current directory (this can become somewhat long; you can display only the final component with \W) \$ $ if running as a user account, and # if root

16.2.4Aliases Among the stickier points of modern user environments is the role of aliases, a shell feature that substitutes one string for another before executing a command. At one time, these were efficient shortcuts intended to save some typing. However, aliases also have these drawbacks: They have balky syntax, especially when manipulating arguments. They are confusing; a shell's built-in which command can tell you if something is an alias, but it won't tell you where it was defined. They are frowned upon in subshells and non-interactive shells; they do not work in other shells. With all of these disadvantages, it makes sense to avoid aliases whenever possible, because it's easier to write a shell script (see Chapter 7). Modern computers can start and execute shells so quickly that the difference between an alias and an entirely new command should not mean anything to you. However, there is one particular instance where aliases do come in handy — when you wish to alter a part of the shell's environment. You can't change an environment variable with a shell script, because scripts run as subshells.

16.2.5The Permissions Mask Linux Works: Every built-in Super-User Should Know As describedHow in Section 1.17.1What , a shell's umask (permissions mask) facility sets your default by Brian Ward permissions. You should run umask in one of your startup files to make certain that any programISBN:1593270356 you run Starch Press © 2004 (347 pages) creates filesNo with your desired permissions. However, you may wonder what the best choice is, especially if This guide describes the inner a Linux system beginning with the file system and boot process and you have a stand-alone machine with workings no otherofusers. covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

The two reasonable choices break down as follows: 077 This is Table of Contents

the most restrictive permissions mask; it does not give any other users access to new files system where you do not want other users to look of Basics your files. Chapterat1 any - The andWorks—What directories.Every This Super-User is appropriate onKnow a multi-user How Linux Should Chapter 2

- Devices, Disks, Filesystems, and the Kernel

022 -Gives other users read access to new files and directories. This is more useful than you may How Linux Boots presume on aFiles, single-user system, because many daemons that run as pseudo-users would not Chapterinitially 4 - Essential System Servers, and Utilities to see files directories created with the more restrictive 077 umask. Chapterbe 5 able - Configuring Yourand Network Chapter 3

Chapter 6

- Network Services

Note Certain applications (mail programs in particular) override the umask, changing it to 077 because - Introduction to Shell Scripts they feel that their files are the business of no one but the file owner. Chapter 8 - Development Tools Chapter 7 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Should Know 16.3Startup File Order andSuper-User Examples by Brian Ward

ISBN:1593270356

Starchwhat Pressto © 2004 Now that youNoknow put (347 intopages) shell startup files, it's time to see some specific examples. Surprisingly, This guide describes the inner workings a Linux system beginning the file system and process and one of the most difficult and confusing parts ofofcreating startup files is with determining which ofboot several startup advanced topics such as networking, firewalls, development tools, device management, shell scripts, and files to use. covering The next sections cover the two most popular Unix shells, bash and tcsh. sharing printers with Samba.

16.3.1The bash Shell

Table of Contents

How Linux Works—What Every Super-User Should Know Chapter 1 you - Thehave Basicsthese In bash,

startup filenames to choose from: .bash_profile,.profile,.bash_login, to use for your command path, manual page path, Chapter 3 aliases, - How Linux prompt, andBoots permissions mask? The answer is that you should have a .bashrc file accompanied Chapter 4 - Essential System Files, Servers, and Utilities by a .bash_profile symbolic link pointing to .bashrc. Chapter 2 - Devices, Disks, Filesystems, the Kernel and.bashrc. Which one of these and is appropriate

Chapter 5

- Configuring Your Network

The reason for this setup Chapter 6 - Network Services

is that there are several different kinds of bash shell instance types, as follows:

ChapterInteractive 7 - Introduction ShellisScripts shelltoThe the type

of shell that you use to run commands from a terminal. There are - Development Tools two subtypes of interactive shells: Chapter 9 - Compiling Software From Source Code Login shell This is traditionally invoked by /bin/login; for example, when getty or sshd Chapter 10 - Maintaining the Kernel starts/bin/login. The exact circumstances that determine an interactive shell are a little Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - strange Printing (the first character of a login shell's invocation name is a -), but the basic idea is that the login shell is an initial shell. When bash runs as a login shell, it looks for a user's Chapter 13 - Backups .bash_profile,.bash_login, and .profile files, running the first one that it sees. Chapter 14 - Sharing Files with Samba Chapter 8

Chapter 15 - Network File Transfer

Non-login shell This is any other interactive shell. Windowing system terminal programs (xterm, GNOME Terminal, and so on) start non-login shells unless you specifically ask for a login shell. - Buying Hardware for Linux bash reads from .bashrc upon startup of a non-login shell.

Chapter 16 - User Environments Chapter 17

Chapter 18 - Further Directions

Appendix A - Command Classification

Non-interactive shell This is a shell that doesn't require input from aterminal.

Bibliography Index The

reasoning behind the two different startup file systems is that in the old days, users logged in through terminal with a login shell, then started non-login subshells with windowing systems or the List of Tables screen program. It was deemed a waste to repeatedly set the user environment and run all sorts of List of Sidebars wasteful programs in these subshells. With login shells, you could run fancy startup commands in a file such as .bash_profile, leaving only aliases and other "lightweight" things to your .bashrc. List of Figures a traditional

That's a nice theory, but in these modern times, nearly everyone logs in through a graphical display manager that never starts a login shell. Therefore, you need to set up your entire environment (path, manual path, and so on) in your .bashrc, or you would never see any of your environment in your terminal window shells. However, you also need a .bash_profile if you ever want to log in on the console or remotely, because these are login shells, and they don't ever bother with .bashrc. None of the issues described in the previous two paragraphs should matter, because it's never a good idea to make a complicated mess of your startup files, and modern hardware is so fast that a little extra work for every new shell shouldn't cause much of a performance hit anyway. Here is a very elementary (yet perfectly sufficient) .bashrc that you can also share with your .bash_profile: # Command path. PATH=/usr/local/bin:/usr/bin:/bin:/usr/X11R6/bin:$HOME/bin # Manual page path. MANPATH=/usr/local/man:/usr/man:/usr/X11R6/man:$HOME/man # PS1 is the regular prompt. # Substitutions include: # \u username \h hostname # \! history number \s shell name PS1='\u\$ '

\w \$

current directory $ if regular user

# EDITOR and VISUAL determine the editor that programs such as less # and mail clients invoke when asked to edit a file. EDITOR=vi VISUAL=vi

# PAGER is the default text file viewer for programs such as man. PAGER=less How Linux Works: What Every Super-User Should Know

# These are some handy options for less. by Brian Ward LESS=mei No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as variables. networking, firewalls, development tools, device management, shell scripts, and # You must export environment sharing printers with Samba. export MANPATH EDITOR VISUAL PAGER LESS Table of Contents # By default,

give other users read-only access to most new files.

How Linux Works—What Every Super-User Should Know umask 022 Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3 - Howearlier, Linux Boots As described you

can share this .bashrc file with .bash_profile via a symbolic link. One as this one-liner:

Chapter 4 -better) Essential System Files, and Utilities (possibly alternative is Servers, to create .bash_profile Chapter 5

- Configuring Your Network

Chapter 6

- Network Services . $HOME/.bashrc

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code Checking for Login and Interactive Shells

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

Now that your .bashrc matches your .bash_profile, you can no longer run extra commands for login shells. Therefore, if you want to define different actions for login and non-login shells, you can add the Chapter 13 - Backups following test to your .bashrc, which checks the first character of the shell's $0 variable for a - character: Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

case 16 $0- User in Environments Chapter -*)17 -command Chapter Buying Hardware for Linux Chapter 18 -command Further Directions Appendix A -... Command Classification Bibliography ... Index

;;

esac List of Figures List of Tables List of Sidebars

If, for whatever reason, you want to run certain commands only if a shell is interactive, use a construct like this in your .bashrc: case "$-" in *i*) command command ... ... ;; esac Normally,bash doesn't read startup files at all for non-interactive shells. The preceding code only applies if you set the BASH_ENV environment variable to a startup filename.

16.3.2The tcsh Shell The standard csh on virtually all Linux systems is tcsh, an enhanced C shell that popularized features such as command-line editing and multimode filename and command completion. Even if you don't use tcsh as the default new user shell (this book suggests using bash), you should still provide tcsh startup files in case your users happen to come across tcsh. You don't have to worry about the difference between login shells and non-login shells in tcsh. Upon startup,tcsh looks for a .tcshrc file. Failing this, it looks for the csh shell's .cshrc startup file. The reason for this order is that you can use the .tcshrc file for tcsh extensions that don't work in csh. You should probably stick to using the traditional .cshrc instead of .tcshrc; it's highly unlikely that anyone will ever use your startup files with csh. And if a user actually does come across csh on some other system, your .cshrc will work adequately. Here is sample .cshrc file:

# Command path. setenv PATH /usr/local/bin:/usr/bin:/bin:/usr/X11R6/bin:$HOME/bin How Linux Works: What Every Super-User Should Know

# Manual by page Brianpath. Ward setenv MANPATH No Starch/usr/local/man:/usr/man:/usr/X11R6/man:$HOME/man Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and advanceddetermine topics such as the networking, firewalls, development tools, deviceas management, shell scripts, and # EDITOR covering and VISUAL editor that programs such less sharing printers invoke with Samba. # and mail clients when asked to edit a file. setenv EDITOR vi Table of Contents setenv VISUAL vi How Linux Works—What Every Super-User Should Know Chapter 1 - The # PAGER is Basics the

default text file viewer for programs such as man.

Chapter 2 -PAGER Devices, less Disks, Filesystems, and the Kernel setenv Chapter 3

- How Linux Boots

Chapter 4 - Essential System Files, Servers, and Utilities # These are some handy options for less. Chapter 5 -LESS Configuring setenv mei Your Network Chapter 6

- Network Services

Chapter - Introduction to Shell Scriptsusers # By 7default, give other Chapter umask8 Chapter 9

read-only access to most new files.

- Development Tools 022 - Compiling Software From Source Code

Chapter 10 - Maintaining Kernel # Customize the the prompt. Chapter 11 - Configuring and Manipulating Peripheral Devices # Substitutions include: Chapter - Printing # %n 12 username

%m hostname number %l current terminal Chapter 14 - Sharing Files with set prompt="%m%% " Samba Chapter - Backups # %h 13 history

Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

%/ %%

current directory %

How Linux Works: What Every Super-User Should Know 16.4Default User Settings by Brian Ward

ISBN:1593270356

Noto Starch © 2004 (347and pages) The best way writePress startup files choose defaults for new users is to experiment with a new test user ThisCreate guide describes inner workings of a Linux system beginning withmost the file system and boot process on the system. the testthe user with an empty home directory. Then, importantly, refrain fromand covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and copying yoursharing own startup files to the test user's directory. Write the new startup files from scratch. printers with Samba.

When you think you have a working setup, log in as the new test user in all possible ways (on the console, remotely, and so on). Make sure that you test as many things as possible, including windowing system How Linux Works—What Every Super-User Should Know operation and manual pages. After you're happy with the test user, create a second test user, copying the Chapter 1 - The Basics startup files from the first test user. If everything still works fine, you now have a new set of startup files Chapter 2 - Devices, Disks, Filesystems, and the Kernel that you can distribute to new users.

Table of Contents

Chapter 3

- How Linux Boots

Chapter 4 - Essential System Files, Servers, and Utilities The following sections outline reasonable defaults Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

for new users.

16.4.1-Shell Introduction to Shell Scripts

Chapter 7 Chapter 8

- Development Tools

The default shell forSoftware any new user on aCode Linux Chapter 9 - Compiling From Source

system should be bash. In the old days, the Bourne shell (sh) was more difficult to use in interactive mode than alternatives such as the C shell (csh), so users Chapter 10 - Maintaining the Kernel typically had a login shell that was different than the Chapter 11 - Configuring and Manipulating Peripheral Devices standard system shell. This changed when bash arrived the scene, for it had all of the features of csh and its enhanced version (tcsh). Chapter 12on - Printing Chapter 13 - Backups

There are several good reasons for using bash on a Linux system:

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Users interact with the same shell that they use to write shell scripts (csh is a notoriously bad scripting tool; please, don't even think about it).

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux Chapterbash 18 - Further Directions is standard on Linux

systems; tcsh is sometimes not.

Appendix A - Command Classification

uses GNU readline, and therefore, its interface is identical to many other tools. tcsh has a powerful command-line editing system, but it takes some time to learn.

bash Bibliography Index

List of Figures

bash List of Tables

gives you finer control over I/O redirection and file handles.

List of Sidebars

However, you can't teach an old dog new tricks, and many seasoned Unix wizards use csh and tcsh simply because they can't bear to switch. Of course, you can choose any shell you like, but my opinion is that you should choose bash if you don't have any preference, and you should also use bash as the default shell for any new user on the system (if they have another preference, they will be able to change their own shell with the chsh command).

Note There are plenty of other shells out there (rc,ksh,zsh,es, and so on). But just because they exist does not mean they are suitable beginner shells.

16.4.2Editor The default editor should be vi or emacs. These are the only editors virtually guaranteed to exist on nearly any Unix system, and they will therefore cause the least trouble in the long run for a new user. As with shell startup files, avoid large default editor startup files. A little set showmatch in the vi .exrc startup file never hurt anyone, but steer clear of anything that significantly changes the editor's behavior or appearance, such as the showmode feature, autoindentation, and wrap margins.

16.4.3Pager It is perfectly reasonable to set the default PAGER environment variable to less, because it is very easy to use.

How Linux Works: What Every Super-User Should Know 16.5Startup File Pitfalls by Brian Ward

ISBN:1593270356

Press (347 pages) avoid in startup files (many have to do with the X Window There are a No fewStarch things you© 2004 really should System): This guide describes the inner workings of a Linux system beginning with the file system and boot process and

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Don't put X commands in a shell startup file. Table of Contents Don't set the

DISPLAY environment variable in a shell startup file.

How Linux Works—What Every Super-User Should Know ChapterDon't 1 - The set Basics the terminal Chapter 2

type in a shell startup file.

- Devices, Disks, Filesystems, and the Kernel

skimp onBoots descriptive ChapterDon't 3 - How Linux Chapter 4

comments in default startup files.

- Essential System Files, Servers, and Utilities

Don't- Configuring run commands in a startup file that print to the standard output. Your Network

Chapter 5 Chapter 6

- Network Services Never set LD_LIBRARY_PATH in a shell startup file (see Section 8.1.4).

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 16.6Further Startup Topics by Brian Ward

ISBN:1593270356

Starch Pressonly © 2004 (347 the pages) Because thisNobook deals with underlying Linux system, this chapter does not cover windowing guide files. describes workings a Linux system beginning with the file system and bootyou process environmentThis startup Thisthe isinner a large issueofindeed, because the display manager that logs in toand a covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and modern Linux system has its own set of startup files, such as .xsession, .xinitrc, and the endless sharing printers with Samba. mess of GNOME-and KDE-related items. Table of Contents

The windowing choices may seem bewildering, and this isn't far from the truth, because there isn't even one single common way to start a windowing environment in Unix. However, once you determine what Chapter 1 - The Basics your system does, you may get a little carried away with the files that relate to your graphical environment. Chapter 2 - Devices, Disks, Filesystems, and the Kernel This is fine, but don't carry it over to new users. The same tenet of keeping things simple in shell startup Chapter 3 - How Linux Boots files works wonders for GUI startup files too. How Linux Works—What Every Super-User Should Know

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 17: Buying Hardware for Linux by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and Overview covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Computers are frustrating. Simply shopping for one is enough to drive a sane person mad, and if you want a Linux machine, you might as well sign up for therapy now. Aside from relatively low hardware prices, the Table of Contents cards are stacked against you. A confusing barrage of specifications and incompatibilities awaits you in How Linux Works—What Every Super-User Should Know your quest, and along the way, you must often confront extremely lame advertising for what are often the Chapter 1 - The Basics ugliest examples of industrial design in history. Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots This chapter is a field guide to hardware selection. Although hardware is in a constant state of flux, the - Essential System Files, Servers, and Utilities good news is that an old adage applies: The more things change, the more they stay the same. If you can Chapter 5 - Configuring Your Network see computer hardware in more abstract terms, you have everything you need to make an educated Chapter 6 - Network Services purchase. Despite the constant escalation of specifications, a computer still has a processor (CPU), Chapter 7 - Introduction to Shell Scripts random-access memory (RAM), secondary storage, and some Chapter 4

Chapter 8

- Development Tools

Chapter 9 - Compiling Source Code I/O devices. Every Software now andFrom then, some underlying Chapter 10 -from Maintaining Kernel other memory doing the anything

technology may change, but nothing is going to stop than storing a bunch of ones and zeros.

Chapter 11 - Configuring and Manipulating Peripheral Devices

Here are guidelines Chapter 12 -three Printing

that you should remember:

Chapter 13 - Backups ChapterKnow 14 - Sharing Samba what Files you with want, and Chapterperformance 15 - Network File Transferbut trade-off,

don't lose sight of it This usually comes down to a price versus details such as ergonomics can be just as important.

Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux

listenDirections to vendors ChapterDon't 18 - Further

They generally want to sell you the most expensive thing in the store even correctly. In addition, these people are trained to sell systems for Windows users — in most cases they're not aware of hardware issues important to Linux users. Bibliography though it may not even work Appendix A - Command Classification Index List of Figures

You often get what you pay for However, refer to Rule 1 first: is the more expensive hardware what you really need and want? List of Sidebars List of Tables

How Linux Works: What Every Super-User Should Know 17.1Core Components by Brian Ward

ISBN:1593270356

No Starch © 2004focuses (347 pages)on desktop computers. With the exception of notebooks, I build my The discussion in thisPress chapter This components. guide describes The the inner a Linux system in beginning with the file system system and bootcosts process and machines from goalworkings is not toofsave money; fact, the finished often more covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and than similarly outfitted pre-assembled computers. The advantage is that there are fewer headaches with sharing printers with Samba. custom configurations. If you know exactly what goes into your computer, you will have no surprises, and in this territory, surprises only come in the unpleasant variety. You don't want hardware that Linux doesn't Table of Contents support, and an unreliable piece of hardware can seriously degrade your quality of life. How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics Assembling a computer is easy, but it isn't for everyone. It takes time and a certain amount of dexterity to - Devices, Disks, Filesystems, and the Kernel avoid hurting yourself on sharp electronic pieces. If you don't want to go for an off-the-shelf model that Chapter 3 - How Linux Boots may contain unknown components, and you also don't want to assemble your computer yourself, you still Chapter 4 - Essential System Files, Servers, and Utilities have two choices. You can find out exactly what is in that off-the-shelf model that you're looking at, and Chapter 5 - Configuring Your Network then determine whether the parts will work with Linux. Reputable manufacturers list this information and do Chapter 6 - Network Services not substitute parts. Your other choice is to buy custom parts and then have a small computer shop or Chapter 7 - Introduction to Shell Scripts friend assemble them for you. If you go to a shop, make it clear that component substitution is Chapter 8 - Development Tools unacceptable. Chapter 2

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the components: Kernel You need the following Chapter 11 - Configuring and Manipulating Peripheral Devices

motherboard. ChapterA12 - Printing other I/O Chaptermany 13 - Backups

Modern motherboards have integrated hard drive interfaces, as well as USB and ports.

Chapter 14 - Sharing Files with Samba

processor ChapterA15 - Network (CPU). File Transfer Chapter 16 - User Environments

Random-access memory (RAM).

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

A hard disk.

Appendix A - Command Classification Bibliography An Ethernet

NIC card (optional).

Index List of Figures A graphics

card.

List of Tables

A case to List of Sidebars

hold the components. The case usually includes a power supply.

17.1.1Processor and Motherboard Virtually all IA32-like (x86 PC) central processing unit (CPU) models work with Linux. The kernel and gcc compiler support many vendor-specific CPU optimizations, and features such as multiprocessing also work well with Linux. Two important considerations when choosing a processor should be power consumption and heat. CPUs that consume more power also generate a substantial amount of heat. To handle the extra heat, you need a lot of fans. Never overclock a processor running Linux, unless you like to see your computer crash.

Note If you are interested in taming the usual din that a computer makes, a great place to start is the power supply. Most power supply units included with PC cases are of the very cheapest sort, with loud, unreliable cooling fans. You can easily replace the power supply with a low-noise premium model from a third party. It will not be cheap, but if noise irritates you, it is worth every penny. Although nearly all CPU models will work with Linux, some care must be taken when choosing the CPU's home — the motherboard. You should consider your motherboard, processor, and memory as a single unit, and you may even want to choose your motherboard first and find a CPU to fit. After all, it is possible that your motherboard will cost more than the CPU! Pick a motherboard that has been available for a reasonable amount of time. Three or four months should be sufficient. Often, initial releases of motherboards have bugs that cause mysterious hardware failures. Avoid fancy (untested) new features. Linux doesn't immediately support each new bell and whistle that comes off the assembly line, and these unusual features may interfere with normal system operation. Watch out for brand-new processor models that require you to purchase a new motherboard chipset, as these can be expensive nightmares. Modern motherboards come with a number of integrated peripherals. They normally include two ATA disk interfaces, plus parallel, serial, and USB ports. Some motherboards come with additional hardware, such as integrated SCSI controllers, video chips, and sound. These integrated features can save you space on the motherboard and the hassle of installing your own components, but if you buy separate plug-in

components, you can perhaps save a little money and a compatibility headache. The advantages of integrated motherboard components are somewhat dubious in the case of most components except SCSI controllers. If, likeLinux many people, you choose a motherboard with integrated video, find out what chip it How Works: What Every Super-User Should Know uses and make certain ISBN:1593270356 by Brian Wardthat the XFree86 server has support for it (see http://www.xfree86.org/ and http://www.xouvert.org/). No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

17.1.2Memory Theofthird guideline Table Contents

from the beginning of this chapter ("you often get what you pay for") is most important only marginally more expensive than generic labels, and it can save many headaches. A Linux machine exhibits odd behavior if it has bad memory. If a program Chapter 1 - you The Basics seems2 to- crash often, for these Chapter Devices, Disks,look Filesystems, andsymptoms: the Kernel when buying memory. Name-brand memory is How Linux Works—What Every Super-User Should Know

Chapter 3

- How Linux Boots

The -crash happens in the same place every time. Essential System Files, Servers, and Utilities

Chapter 4 Chapter 5

- Configuring Your Network Rebooting makes the problem go away.

Chapter 6

- Network Services

ChapterThe 7 -operating Introduction to Shellappears Scripts system Chapter 8

unaffected, and other programs run fine.

- Development Tools

ChapterIt 9happens - Compiling Software From disk Source Code during frequent access. Chapter 10 - Maintaining the Kernel

You should considerand buying ECC (error-correcting Chapter 11 - Configuring Manipulating Peripheral Devicescode)

memory. It is a little more expensive than and not all motherboards support it (read your motherboard manual carefully), but ECC memory ensures that you never have a memory problem. Chapter 13 -practically Backups standard Chapter 12 -memory, Printing

Chapter 14 - Sharing Files with Samba

A Linux automatically Chapter 15 system - Network File Transfer

uses extra memory for disk cache, and this can substantially improve that use large files (or several small files). However, for many users, there is a point17where more memory adds little or no benefit because the system has already cached nearly Chapter - Buying Hardware for Linux everything. You can briefly check the state of a system's memory utilization with the free command; the Chapter 18 - Further Directions information in /proc/meminfo has a little more detail. Appendix A - Command Classification performance applications Chapter 16 - Userfor Environments

Bibliography

17.1.3Hard Disk

Index

List of Figures

List of Tables The old "IDE

versus SCSI" question was once one of the bigger debates surrounding hard disks. However, build a desktop computer, the debate means little, because you will likely choose an ATA (IDE) disk out of cost concerns. In the old days, power users considered ATA disks to be performance dogs, and there wasn't a large disparity in price when compared against SCSI disks. Improvements in CPU speeds, caching, memory cost, the interface, and hard disk manufacturing techniques have made ATA perform tolerably well for a desktop system with a single disk — even Apple switched its desktop disks to the ATA type.

List of Sidebars if you want to

A disk has two primary specification numbers: average access time (measured in milliseconds, or ms) and rotation speed (measured in rotations per minute, or RPM). In general, a faster (lower) access time is the more important consideration for Unix, because the system spends a lot of time looking at a bunch of small files. If you are a software developer, this is particularly important because compilers and scripting languages use many file accesses on a single invocation. On the other hand, if you have big files (movies, music, whatever), a higher rotational speed gets this stuff off the hard disk faster. There usually isn't a trade-off between rotational speed and access time because they are linked. More RPMs mean that the disk head takes less time to pass over the proper place on the disk platter for the next access, hence a lower average access time. Higher performance, however, comes at a price above and beyond the sticker price. The fastest-spinning disks are usually noisy and generate more heat. I'll spare you the "hard disks I have hated in the past" war stories, but if you want a quiet disk, look for one with a fluid bearing system (sometimes called FDB). These drives use liquid instead of solid ball bearings for their platters, and they are a big improvement for your ears. Any ATA disk should work in a Linux system. The kernel disk drivers are fast, and they support special features with the hdparm command. If you run into compatibility issues, they will likely be between your motherboard and the disk (in particular, some older motherboards do not support disks larger than 32GB; look for jumpers on the disk to "clip" the disk, limiting it to a lower capacity). If you put two ATA disks in the same system, put them on different interfaces (your motherboard should have primary and secondary ATA interfaces), which should improve concurrent access slightly. If you purchase an add-in ATA interface card, you may need extra drivers. When considering one of these cards, look for drivers in the ATA support menu described in Section 10.4.1.

17.1.4Network Cards and Infrastructure How Linux Works: What Every Super-User Should Know ISBN:1593270356 The Linux kernel by Brian supports Ward most wired PC Ethernet devices (also known as NICs, or network interface No Starch Press © 2004 (347card pages) cards), but you should check any against the compatibility list in a current Linux kernel. Don't believe a manufacturer's This guide claim describes of compatibility the inner workings in this of case a Linux — the system manufacturer beginning with may therequire file system youand toboot install process a special and topics such as networking, tools,that device management, shell scripts, kernel drivercovering beforeadvanced the device works. Keep in mindfirewalls, that thedevelopment kernel drivers come from vendors often and sharing printers with Samba. don't work correctly.

Table of cable Contents Most and

DSL adapters require an Ethernet card. You should be able to use any supported Ethernet that Linux supports the protocol. You may need to Chapter - The Basics like PPPoE for your provider (see Section 5.9). use a 1funny protocol How Linux Works—What Every Super-User Know card regardless of the protocol that Should you use, provided Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Current ofBoots 100Base-T Chapter 3 networks - How Linux

(100 megabits per second, or about 12 megabytes per second) are more very inexpensive. To attach several machines to a home network, need a Your hub Network or switch (it is possible to connect two machines directly with an Ethernet Chapter 5 -you Configuring crossover cable, but this isn't really worth the trouble). Chapter 6 - Network Services than adequate for System most purposes. They also Chapter 4 - Essential Files, Servers, andare Utilities

Chapter 7

- Introduction to Shell Scripts

The most Chapter 8 - significant Developmentdifferences Tools

between using a hub and a low-end switch is that a switch can send and has a potential of faster throughput and lower latency. However, unless youthe have a habit of sending large files around your network simultaneously, you won't Chapter 10 - Maintaining Kernel notice11 much of a performance difference between Chapter - Configuring and Manipulating Peripheral Devicesthe two. On the other hand, the difference in price between and switches is also fairly small. Whether you purchase a hub or a switch, pick a model that Chapter 12 -hubs Printing has ports each of your computers, plus a few extra. Also, make sure that the hardware supports the Chapter 13 - for Backups older 10Base-T This feature is often called 10/100, and it provides the most convenient way to Chapter 14 - Sharingstandard. Files with Samba move files from an old computer with a 10Base-T interface. Chapter 15 - Network File Transfer receive at the sameFrom timeSource and therefore Chapter 9 signals - Compiling Software Code

Chapter 16 - User Environments

Wireless Ethernet

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

You may to consider wireless Appendix A - want Command Classification you're on Bibliography Index

Ethernet for a notebook, even if you don't plan to use Ethernet when the go. There are several advantages:

It is one less cable to connect. This saves time as well as wear and tear on the machine.

List of Figures List of Tables

Visitors with wireless cards can connect to your network without much hassle.

List of Sidebars

Some PDAs can connect to a network with wireless Ethernet. You may need to connect to a foreign network at some time. There are also some disadvantages: It is more expensive. Security can be a hassle (see Section 5.15.1). There are some really annoying twerps who think that wireless Ethernet makes them the coolest people on the planet. To make wireless Ethernet work, you need a wireless access point along with the network card (some notebooks come with integrated cards). Many access points come in units that also provide a broadband router and an integrated switch. Even if you don't have a broadband connection or choose not to use the routing feature, the switch can still be useful for connecting desktop computers. For notebook Ethernet cards, see Section 11.6. For information on how to set up a wireless client, see Section 5.15.

17.1.5Graphics Hardware Your primary concern in choosing a video card should be compatibility with XFree86. Although you can inspect the list of compatible cards at http://www.xfree86.org/ and http://www.xouvert.org/, it is unfortunately not always easy to identify a card because manufacturers have a habit of not changing product names while altering hardware significantly. As with the motherboard, a good method for ensuring that your graphics hardware is compatible with your system is to identify a brand or particular graphics chip that has consistent support and then find a video card that isn't cutting-edge. If a card has been available for some time, there is a much greater chance of XFree86 support. Regarding performance, quick video hardware often means very little under Linux; in

fact, the fastest 3-D hardware may not be optimal for normal tasks in XFree86. XFree86 supports multi-output video cards and additional How Linux Works: What Every Super-User Shouldcards Knowthat can drive multiple monitors, sometimes called multiple heads. If you value your onscreen workspace, this is worth looking at ISBN:1593270356 because by Brian Ward the emergence of LCD displays makes it feasible to have two large monitors without a desk the size of an No Starch Press © 2004 (347 pages) aircraft carrier. You can also combine multiple displays into one big virtual display with the Xinerama This guide describes the inner workings of a Linux system beginning with the file system and boot process and extension. covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

HowHardware Linux Works: What Every Super-User Should Know 17.2Other Components by Brian Ward

ISBN:1593270356

© 2004the (347essential pages) Now it's timeNotoStarch movePress beyond components and look at your choices for the other parts that Thisto guide describes the inner workings of a Linux system beginning with the file system and boot process and you can attach a computer.

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

17.2.1Monitors Table of Contents How Linux Works—What Every Super-User Knowmore Because you will work with the shellShould interface

under Unix than other PC operating systems, you that displays crisp text. In addition, high resolution is important in a monitor Chapter 2 -you Devices, Filesystems, and the because wantDisks, the ability to display atKernel least two shell or text editor windows at once, so that you can Chapter 3 switch - How Linux Bootsthem. However, you can only take resolution so far. To the beginner, it is always quickly between Chapter 4 -to Essential Files, Servers, and Utilities more windows, but because this increases eye strain, tempting reduceSystem the font size to accommodate Chapter 5 Configuring Your Network there is no real substitute for a large display. Chapter - The Basics should1 choose a monitor

Chapter 6

- Network Services

Traditional Unix workstations like Sun Chapter 7 - Introduction to Shell Scripts

SPARCstations usually came with very large, heavy, expensive offering some of the highest resolutions commercially available. CRT displays now lighter andFrom carry the lowest Chapter 9 are - Compiling Software Source Code price tags of high-end displays. However, you should avoid them whenever possible. Above all, an LCD display offers a razor-sharp text display that is impossible on Chapter 10 - Maintaining the Kernel any CRT. This advantage, combined with a very light weight, small footprint, and lack of a flyback Chapter 11 - Configuring and Manipulating Peripheral Devices transformer makes a good case for an LCD display for all but the most special-purpose applications. (At Chapter 12 - Printing some 13 point in the not-so-distant future, a CRT will not even be a consideration, rendering this paragraph a Chapter - Backups historic Chapter 14curiosity.) - Sharing Files with Samba cathode tube (CRT) monitors Chapter 8 ray - Development Tools

Chapter 15 - Network File Transfer

As mentioned traditional Chapter 16 - User above, Environments

monitors that came paired with Unix machines had fairly high resolutions. used was around 1152 × 900 (often called megapixel displays ), and most users found it comfortable (you won't find this option on modern LCD displays). 1024 × 768 is a little Chapter 18 - Further Directions cramped but passable if you can keep a minimal desktop. It also may be the only option if you are Appendix A - Command Classification shopping for a notebook. A 1280 × 1024 display is the next step up and it is often ideal; if you happen to Bibliography have just a little extra money and are itching to spend it on something worthwhile, this is it. Higher Index resolutions List of Figures such as 1600 × 1200 are good if you have large graphics to display. However, if you want to increase List of Tablesyour workspace, especially for text, it's better to buy a second monitor and use the multi-monitor support mentioned in Section 17.1.5. A multi-monitor configuration costs less than a single huge monitor List of Sidebars and gives you more effective onscreen space due to the layout of the monitors. The minimum that Sun and NeXT Chapter 17 - Buying Hardware for Linux

17.2.2Keyboards Choose your keyboard wisely, because you'll use it more than you ever imagined in Linux. First, check the basics of the layout. Is the ESC key in a reasonable place, and is it a normal-sized key? This is extremely important for vi users, who press ESC on a regular basis. Where are the tilde-backtick (~`) and pipebackslash (|\) keys? These characters come up frequently in shell commands. (To those using non-U.S. keyboards, you might want to ask a friend about good key layouts and mappings.) If you intend to run only Unix on your computer, keys other than those immediately around the alphanumerics aren't very important. You don't really need a numeric keypad or 37 function keys. Arrow keys are also slightly less important when running Unix unless you're playing a game. Nearly every program that takes text input accepts CONTROL-P, CONTROL-N, CONTROL-B, and CONTROL-F (up, down, left, and right, respectively). In vi, you will make use of h, j, k, and l (left, down, up, and right). One little thing to watch out for is the CAPS LOCK key. On virtually every keyboard made today, it is next to the A key. This is wrong; the CONTROL key belongs there. Philosophical issues aside, see if the CAPS LOCK key is large enough and doesn't have an overly weird shape. You should remap the CAPS LOCK key to CONTROL and use it that way.

17.2.3Mice Other than your personal preferences and testing, there is only one important thing to remember when buying a mouse: Make sure your mouse has at least three buttons. The third (middle) button in X W indow System applications does a paste operation; you don't want to be without it. You can even use it to paste a URL into a browser window. Also, clicking on a link in Mozilla with the middle button makes the link appear in a new window or tab. In a modern mouse, the scroll wheel usually doubles as the third button when pressed down. The scroll wheel is more difficult to press than a real button, and many Unix veterans dislike this. However, there

may be some merit to it, because clumsy fingers on traditional three-button mice have been known to paste strange commands into Unix shells and editors. How Linux Works: What Every Super-User Should Know by Brian Ward 17.2.4Modems No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

Most fax modems manytopics voicesuch modems work with Linux. There is only very important shell rule scripts, when and coveringand advanced as networking, firewalls, development tools,one device management, buying a modem for Linux:with Never buy aWinmodem. These devices require complicated software drivers sharing printers Samba. to do signal processing. There are some straggling Linux drivers for certain Winmodems out there, but you shouldn't bother. You don't want to waste time trying to set this up, and you don't want the extra strain on Table of Contents your kernel. It is unfortunate that many notebooks come with Winmodems; if you have a Winmodem in How Linux Works—What Every Super-User Should Know your notebook, your only option is usually to get a PC Card modem. Chapter 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

That said, for desktops you have a choice between internal and external modems. Internal modems are - How Linux Boots cheaper, do not have external power supplies, and need no cords other than the telephone line. Chapter 4 - Essential System Files, Servers, and Utilities Unfortunately, they may also require some Plug-and-Play manipulation or disabling of built-in serial ports. Chapter 5 - Configuring Your Network You may be able to use an external USB modem, but make sure that there's a Linux driver before you Chapter 6 - Network Services buy. Chapter 7 - Introduction to Shell Scripts Chapter 3

Chapter 8

- Development Tools

Compiling Software From Source Code 17.2.5-Printers

Chapter 9

Chapter 10 - Maintaining the Kernel Chapter 11 -Unix Configuring Manipulating Peripheral Devices Because printerand drivers generate the PostScript

page description language, the easiest way to get a printer is to buy one that supports PostScript. Many laser printers and some inkjet Chapter 13 come - Backups printers with this capability. Unfortunately, these printers are also more expensive than those with Chapter 14imaging - Sharingtechnology. Files with Samba simpler Chapter 12 - Printing Linux-compatible

Chapter 15 - Network File Transfer

Linux 16 also supports printers Chapter - User Environments

that don't understand PostScript by using Ghostscript to transform the drivers into something that these printers understand. However, this adds an step to the printing process inside your machine, and it can be difficult to configure (see Chapter 18 extra - Further Directions ChapterA 12 ). Appendix - Command Classification PostScript generated by the printer Chapter 17 - Buying Hardware for Linux

Bibliography

There Index

are three common ways to connect a printer to a Linux system: using a parallel port, using a USB the printer to a local area network. The parallel port is an old and somewhat primitive method, but it works well. USB is the newest method and should work as well as your USB drivers do (see List of Tables Section 11.3). Printing over the network is fast, it requires no extra kernel drivers, and it is often the List of Sidebars easiest to configure. Most network-capable printers also support PostScript, but they are considerably more expensive than their non-networked counterparts. port, or adding List of Figures

How Linux Works:Hardware What Every Super-User Should Know 17.3A Word About Upgrades by Brian Ward

ISBN:1593270356

No Starch Press 2004 (347 pages) Before we look at how you© can save money, you should know something about upgrades. For many This guideofdescribes theseem inner workings of a Linux because system beginning with the file system and boot process and people, some kinds products more appealing you can upgrade them somewhere down covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and the line. Thissharing may work for old tools and kitchen appliances, but the computer industry doesn't think that printers with Samba. way. They want you to buy something, use it for a year, throw it away, and then buy the newest model because they wouldn't make any money if they actually had to offer upgrades for the dinosaurs of the past. Table of Contents Really, computers just aren't designed like the Stanley #5 jack plane, which was offered in the same basic How Linux Works—What Every Super-User Should Know form for 115 years. Chapter 1

- The Basics

Chapter 2

Disks, Filesystems, and the Kernel If you see- Devices, something advertised as being upgradable to some future specification with some extra piece of - How Linux Boots hardware, it probably isn't going to do you a whiff of good, especially if that extra piece of hardware doesn't Chapter 4 - Essential System Files, Servers, and Utilities exist yet. It usually means that the company has a newer product that isn't quite ready, and therefore, the Chapter 5 - Configuring Your Network marketing department is trying to think of ways to milk an old product. If that little upgrade actually does Chapter 6 - Network Services appear, it will most likely be crippled because the old and new technologies are so different that the Chapter 7 - Introduction to Shell Scripts engineers had to do some really bogus stuff to get the things to talk to each other. I could bring up Chapter 8 - Development Tools countless examples, many involving CPUs, but you should take my word on this one. Chapter 3

Chapter 9

- Compiling Software From Source Code

Chapter 10 -can Maintaining the Kernel So what you upgrade, and

what kinds of parts can you carry from an old computer to a new one? whether a disk is new or used. Memory is a little Chapter - Printing more 12 complicated. For the most part, you can always add more memory to your existing system, but keep Chapter 13 that - Backups in mind you may need to remove some of your old memory to make room for the new stuff. Chapter Configuring and Manipulating Peripheral Devices Disks,11 for- one, are always fairly easy to add to a machine,

Chapter 14 - Sharing Files with Samba

You should regardFile theTransfer motherboard, Chapter 15 - Network

processor, and memory as one unit when purchasing hardware. Don't one of these components over to a newer system (well, this is a slight fib; sometimes you can keep for your memory, but it's very rare). You may also need a new power supply, case, Chapter 17 - Buying Hardware Linux or graphics card when you upgrade other hardware on your system, because the standards for these Chapter 18 - Further Directions components are notClassification terribly stable. Appendix A - Command even think of carrying just Chapter 16 - User Environments

Bibliography

Peripherals Index

and USB devices are easier to carry from system to system. There really isn't any need to devices (like printers) if what you have works. And if you have a keyboard or mouse that you like a lot on your old system, then in the name of your own sanity, don't get rid of it. I hate to say List of Tables this, but they just don't build keyboards like they used to. It might be worth buying a special adapter to List of Sidebars make an old keyboard compatible with a new system (for example, to convert an AT keyboard to USB). change peripheral List of Figures

Upgradable firmware (embedded software) in external hardware components (such as modems) is also a good thing, because it's much easier for a company to write software to support new protocols than to develop and produce hardware fixes.

How Linux Works: What Every Super-User Should Know 17.4Saving Money by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347chapter pages) Axiom 3 in the introduction to this stated that you often get what you pay for; in other words, you This guide thethat inner workings a Linuxwell. system beginningthere's with the system and boot process and might need to pay fordescribes a system works andofworks However, nofileinjunction against saving covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and money. If you don't have an obsession with the very latest products, and you know what to look for, you sharing printers with Samba. can look for slightly older stuff and save a substantial sum. Table of Contents

17.4.1CPU

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2 - itDevices, Filesystems, and the Kernel Although is true Disks, that your CPU does most of the

work on a Linux system, the CPU normally spends most nothing. The uptime command usually reveals that the processor isn't running Chapter 4 - If Essential System Files,isServers, and Utilities any jobs. processor speed important to you, you'll know it from the type of computing that you do, be it Chapter 5 Configuring Your Network graphics or numerical analysis. But for the vast majority of users, there are many features more important Chapter 6 - Network than CPU speed, Services and carefully choosing a processor is one of the best ways to save money on a new Chapter 7 - Introduction to Shell Scripts computer. Chapter 3 - How Linux Boots of its time doing absolutely

Chapter 8

- Development Tools

Nowhere priceSoftware so wildly diverge among Chapter 9 - does Compiling From Source as Code

processors. A vendor's list at the time of this writing shows next step down is 50 percent of that price, but it is still 91.5 percent as fast as11the top model. A Manipulating slower processor costing 25 percent of the top model retains 78 percent of the Chapter - Configuring and Peripheral Devices performance. Now you may ask yourself, maybe I need that extra 22 percent of power? For comparison, I Chapter 12 - Printing am typing this on a computer that is only 12 percent as fast as the top processor in that list, and I have no Chapter 13 - Backups complaints. Chapter 14 - Sharing Files with Samba one price its fastest Chapter 10 - for Maintaining the CPU. Kernel The

Chapter 15 - Network File Transfer

The trick selecting a processor Chapter 16 -to User Environments

is to pick a spot on the performance/price curve that looks good. Figures Figure 17-1 shows how quickly the price rises as the processor speed reaches the fastest available. In Figure 17-2 on the next page, you can see how much performance Chapter 18 - Further Directions you get for each dollar that you spend for the same set of processors. Appendix A - Command Classification 17-1 and show plotsfor of Linux ten processors. Chapter 17 -17-2 Buying Hardware

Bibliography Index List of Figures List of Tables List of Sidebars

Figure 17-1: Costs of several processors.

Figure 17-2: Performance value.

If you are strictly interested in getting the most bang for the buck, the best choice is the CPU represented by the maximum in the graph on the right. However, keep in mind that you may want to go for one of the CPUs with slightly faster numbers it may cost onlyKnow a few dollars more, or you might be able to How Linux Works: Whatbecause Every Super-User Should ISBN:1593270356 buy a CD orby something Brian Wardelse with the savings from choosing a marginally slower option. No Starch Press © 2004 (347 pages)

You must beThis cautious in measuring the performance ofsystem a processor. halfway to and guide describes the inner workings of a Linux beginningThe withonly the file systemprecise and bootway process covering advanced topics such as networking, firewalls, tools, device management, shell scripts, and compare processors is to compare different clock speeds ofdevelopment the same model. Looking at the megahertz sharing printers with Samba. (MHz) numbers of two different models, even from the same manufacturer, is comparing apples and oranges. The benchmark results you read about are also unreliable because operation speeds vary among Table of Contents different processors. Unless you know exactly what you're looking for, benchmarks are next to useless. How Linux on Works—What Every Super-User Should Know Decide a price first, and then look for the best deals among the models that fall within your price range. Chapter 1

- The Basics

If you 2find any of this economic analysis Chapter - Devices, Disks, Filesystems, and the remotely Kernel Computer Architecture: Chapter 3 - How Linux BootsA Chapter 4

interesting, you might want to read the first chapter of Quantitative Approach [Hennessey].

- Essential System Files, Servers, and Utilities

Chapter 5

Configuring Your Network 17.4.2--Hard Disk Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

More expensive hard disks often provide more space for the money. For example, a certain hard disk may - Development Tools offer 100 percent more space over another model for only 33 percent more money. But if you're running Chapter 9 - Compiling Software From Source Code Linux, which is an operating system with relatively low system storage requirements, is "supersizing" really Chapter 10 - Maintaining the Kernel worth it? Considering how much a modern hard disk can store, will you actually use that extra space Chapter 11 - Configuring and Manipulating Peripheral Devices before you buy another disk? Chapter 8

Chapter 12 - Printing

Chapter 13 - Backups

By the time you need to purchase another disk, you may find that the cost per megabyte on a new disk is far lower, or that there are desirable technology improvements that may just make you want to Chapter 15 - Network File Transfer decommission your old disk. Remember that the hard disk still has moving parts, and it is therefore one of Chapter 16 - User Environments the least reliable components in a computer. Chapter 14 - Sharing Files with Samba

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

17.4.3Computer Case

Appendix A - Command Classification Bibliography

Ugly Index

cases with unrefined power supplies and unsophisticated internal structures are cheaper. If you're not put up with the hassle, this could be worth it (that is, you're a graduate student and know what it means to have something "cheap but somewhat functional if not kind of annoying"). Also, you List of Tables might be able to get a used case for free. Be careful, though: a secondhand power supply may not work List of Sidebars with your motherboard, and it may not work at all. picky and can List of Figures

17.4.4Video Card Sometimes you can get a graphics card that the vendor targets for office users. These cards are often less expensive than others. Also, old or discontinued models on clearance won't hurt performance on Linux.

How Linux Works: What Every Super-User Should Know 17.5Notebooks by Brian Ward

ISBN:1593270356

Starch Press © 2004 (347 pages) It is difficult No to balance Linux compatibility with the latest features on notebook computers. The most This guide describes the inner a Linux system that beginning with the file not system and boot process and common problems with notebooks areworkings built-in of video chipsets XFree86 does support. Other covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and componentssharing that tend to lack drivers are modems, Ethernet interfaces, sound cards, and CD-ROM drives. printers with Samba.

The online community is a good place to look for information on Linux notebook compatibility. The http://www.tuxmobile.org/ site is a clearing-house of links to people who are running Linux on nearly all How Linux Works—What Every Super-User Should Know common notebook models. However, these pages are often out of date, and the driver configuration or Chapter 1 - The Basics bug fixes described may not be necessary with current Linux drivers.

Table of Contents

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 17.6Smaller Designs by Brian Ward

ISBN:1593270356

Starch © 2004 (347 Once upon aNotime, if Press you wanted a pages) PC, your options were limited to large machines. Because This guide inner workings of athe Linux with manufacturers the file system and bootreluctant process and interchangeable partsdescribes were sothe important to build PCsystem as a beginning commodity, were to covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and design anything smaller because the form factor would change and be incompatible with everything on the sharing printers with Samba. market. Very small Unix machines were on the market, such as the Sun SPARCstation IPC and IPX, but they were expensive.

Table of Contents

How Linux Works—What Every Super-User Should Know

This is changing. Increased demand from consumers, small dimensional standards taken largely from The Basics notebook- computers, and special applications have created a market for a new class of machines. Form Chapter 2 - Devices, Disks, Filesystems, and the Kernel factors such as Mini-ITX are now on the market. They aren't the fastest computers around, and they aren't Chapter 3 - How Linux Boots overly expandable, but they have big advantages. They are small, quiet, use less power, generate less Chapter 4 - Essential System Files, Servers, and Utilities heat, and are astonishingly inexpensive. Linux has made a contribution to the increasing popularity of Chapter 5 - Configuring Your Network these machines. Whereas a computer with relatively low processor power stood no chance against a Chapter 6 - Network Services market using Microsoft's resource-hungry operating systems, the ever-increasing population of Linux users Chapter 7 - Introduction to Shell Scripts does not care. Manufacturers know this and make sure that their products support Linux. Chapter 1

Chapter 8

- Development Tools

Chapter 9 - Compiling Software From Code The current small machines are Source hybrids. The

motherboards can still fit into standard cases, use normala single PCI slot. They accept standard PC components, even the power Chapter 11However, - Configuring and Manipulating Devices are self-contained and generate little heat (including supply. because many of Peripheral the components Chapter - Printing it has become fashionable to custom-build smaller enclosures. These machines really power12 supplies), Chapter - Backups shine 13 when placed in special small cases that will not accept larger components. Chapter 10 - Maintaining the Kernel size memory, and often have

Chapter 14 - Sharing Files with Samba

One common example of this Chapter 15 - Network File Transfer

is the CD-ROM drive. On a regular desktop computer, these devices are a half-height 5 1/4-inch drive bay. To make them fit in a smaller machine, an easy substitution for the normal Chapter 17 - Buying Hardware for Linuxsize CD-ROM drive is a notebook CD-ROM drive. Like the embedded processors foundDirections on many small motherboards, a notebook CD-ROM drive may not be as quick as its Chapter 18 - Further larger cousin, but it Classification is a fraction of the size. Appendix A - Command gigantic they fit into Chapter 16 because - User Environments

Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Chapter 18: Further Directions by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

There's a lotThis to Linux. This book can only go so far, and although it's time to wind down, this chapter will guide describes the inner workings of a Linux system beginning with the file system and boot process and give you an covering idea of advanced what liestopics beyond fundamental topicsdevelopment covered intools, this device book. management, shell scripts, and suchthe as networking, firewalls, sharing printers with Samba.

18.1Additional Topics

Table of Contents

How Linux Works—What Every Super-User Should Know

Most (but not all) of these topics are network related. Furthermore, none are specific to Linux; you can The Basics carry the-knowledge you have of them to and from other Unix systems.

Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Electronic mail Email is a big topic. Chapters 5 and 6 talked a little about the SMTP port (25) used - Essential System Files, Servers, and Utilities for mail transfer, and they briefly mentioned Postfix and qmail, the two most viable mail transfer Chapter 5 - Configuring Your Network agents (MTAs) available now. There's more behind the MTA: for example, if you want to run an IMAP Chapter 6 - Network Services (Internet Message Access Protocol) server, you probably want the Cyrus package. Chapter 7 - Introduction to Shell Scripts Chapter 4

Chapter 8

- Development Tools

ChapterDomain 9 - Compiling From Source Code NameSoftware Service (DNS) Setting

up a client is easy, as you saw in Chapter 5, but setting up a most common DNS server is BIND (Berkeley Internet Name Domain), but Chaptera 11 - Configuring and Manipulating Peripheral Devices newer DNS server named djbdns is also gaining popularity. ChapterDNS 10 - server Maintaining the Kernel is trickier. The Chapter 12 - Printing Chapter 13 - Backups

In the world, ChapterWeb 14 - servers Sharing Files withUnix Samba

"Web server" usually means Apache, the most popular Web server in scripting languages and other tools have embedded Web server features debugging, status monitoring, and other tasks not directly related to serving Web pages to Chapterthat 16 -can Useraid Environments public. for Linux Chapterthe 17 general - Buying Hardware However, many Chapterthe 15 world. - Network File Transfer

Chapter 18 - Further Directions Appendix A - Command Classification

Virtual private networks (VPNs) A VPN allows you to connect several widely dispersed machines in Index a virtual network (for instance, a single subnet). Administrators typically create a VPN in conjunction with the IPSec protocol so that they can disperse sensitive data (that might otherwise be behind a List of Figures network firewall) through an encrypted network channel across a possibly insecure link. List of Tables Bibliography

List of Sidebars

Thescreen program Did you ever want to take your shell session wherever you go? You can do it with the screen program, a terminal multiplexer that supports multiple shells, disconnection, reconnection, scrollback, cut and paste, and more. This utility is a perennial favorite among seasoned Unix wizards. If you want some of the same functionality with a windowing system, check out VNC (Virtual Network Computing). DB files and DBM files When using many larger servers, you will encounter binary DB and DBM files. These files are very small databases that store blocks of data keyed by small strings, usually as some kind of hash table. For whatever reason, there are an absurd number of different DB/DBM file formats (DB, GDBM, NDBM, and SDBM, to name a few). Most packages that use DBM-style files come with their own manipulation utilities (for example, the postalias command that comes with Postfix), but scripting languages such as Perl include powerful interfaces that you can use if you need to do something beyond the ordinary with these database files. Relational databases You can run the powerful MySQL and PostgreSQL database servers on Linux. There are several commercial servers as well, but this book intentionally avoids talk of commercial software products. RCS and CVS The Revision Control System (RCS) is a way to track file revisions. Originally meant for software development, many systems administrators use RCS to control important system files so that they have a record of who made each change (and in theory, so that they can back out of harmful changes, though this rarely comes up in practice). The Concurrent Versions System (CVS) is a network-extensible revision control system that can handle several versions of the same package at once. Pluggable Authentication Modules (PAM) If you don't like the system of passwords in /etc/passwd, you can replace it with a PAM module that supports some other scheme.

Network Information Service (NIS) NIS is a terrifying combination of RPC and DBM files, used by many systems to provide networked information such as passwd and group. It is an old system that isn't particularly robust, secure, or pleasant, but Should it is supported by most Unix platforms. How Linux Works: What Every Super-User Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

Kerberos This is a powerful network authentication system. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Lightweight Directory Access Protocol (LDAP) LDAP serves a bunch of data entries to network clients (as NIS does), except that where NIS allows only a single key per data entry, LDAP supports a Table of Contents hierarchy of keys for entries. LDAP is very extensible; OpenLDAP is a popular open source LDAP How Linux Works—What Every Super-User Should Know server. Chapter 1 - The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

ChapterNetwork 3 - How File LinuxSystem Boots

(NFS) This is the traditional method of sharing files across a network on a Unix - Essential System Files, Servers, and Utilities cluster. NFS is a somewhat clunky system that is still in use because most Unix systems support it. Chapter 5 - Configuring Your Network Plus, the alternatives such as AFS (Andrew File System), DFS (Distributed File System), and 9P are Chapter 6 - Network Services too expensive, difficult to configure, and not terribly well understood. Chapter 4

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Sockets LayerFrom (SSL) Many network ChapterSecure 9 - Compiling Software Source Code

servers now offer SSL support to authenticate and with the same technology used for secure Web sessions. If you Chapterwant 11 - to Configuring Manipulating Peripheral Devices set up aand server that supports SSL, be prepared to learn all about public keys, private keys, Chaptercertificates, 12 - Printing signing, and more. Chapterencrypt 10 - Maintaining theTCP Kernel individual connections

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know 18.2Final Thoughts by Brian Ward

ISBN:1593270356

No Starch Press © 2004is (347 pages) One of the difficulties of Linux that, like most software, certain technical details change all of the time This guide describes the inner workings of a Linux system beginningand with they the file system andplain boot process because software maintainers change, they implement new features, can be just fickle. and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and Although thissharing book printers striveswith to cover topics that have some degree of stability, it's impossible to tell the Samba. future. The good news is that the base system really doesn't change much. Concentrate on what the system components do, not the details of every strange little option. Remember that the online Table of Contents documentation is always there. In many cases, learning the correct terminology is more important than How Linux Works—What Every Super-User Should Know learning the actual details, because it's the terminology that helps you in your search for the Chapter 1 - The Basics documentation. Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots Linux (and Unix in general) doesn't exist in a vacuum. There are a lot of people out there who can help - Essential System Files, Servers, and Utilities you. A few examples are IRC channels, mailing lists, user groups (check http://www.linux.org/groups/), and Chapter 5 - Configuring Your Network the USENIX/SAGE organizations (http://www.usenix.org/ ). USENIX has been around since the early days Chapter 6 - Network Services of Unix (incidentally, if you're interested in "the old days," you should read A Quarter Century of UNIX Chapter 7 - Introduction to Shell Scripts [Salus]). Chapter 4

Chapter 8

- Development Tools

Chapter 9 -your Compiling Software From Keeping system simple andSource cleanCode helps Chapter 10 - Maintaining the"errant" Kernel — zealously removing

when tracking problems. Don't get obsessed with it, though files can be harmful.

Chapter 11 - Configuring and Manipulating Peripheral Devices

Finally, be afraid Chapter 12don't - Printing

to try new stuff!

Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Appendix A: Command Classification by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages)

This appendix is a guide to the common standard commands. They are organized in the following tables: This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table A-1: File Management Commands

Command Table of Contents

Description

How Linux Works—What Every Super-User Should Know

Changes a file's group

chgrp

Chapter 1

- The Basics

chmod Changes a file's permissions Chapter 2 - Devices, Disks, Filesystems, and the Kernel Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter cp 5

- Configuring YouraNetwork Copies file

Chapter 6

- Network Services

chown

Changes a file's user ownership

dd 7 Chapter

Converts and copies - Introduction to Shell Scripts

Chapter df 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Displays disk usage statistics

du 10 - Maintaining Displays directory Chapter the Kernel

space usage

Chapter 11 - Configuring and Manipulating Peripheral Devices

file

Identifies a file type

Chapter 12 - Printing

Chapter find13 - BackupsSearches

for a file

Chapter 14 - Sharing Files with Samba

Creates a symbolic Chapter 15 - Network File Transfer ln

or hard link

Chapter ls 16 - User Environments Lists files Chapter 17 - Buying Hardware for Linux

mkdir Chapter 18 - FurtherCreates Directionsa

directory

Appendix A - Command Classification

mkfifo

Bibliography

mknod Index List of Figures

Creates a named pipe Creates a special file

List of Tables

Renames or moves a file

Listrm of Sidebars

Removes a file

mv

touch

Creates a file or updates a file's timestamp

Table A-2: Text Processing and Scripting Commands Command

Description

awk

Theawk general-purpose text processing language

basename

Strips extensions and directories from filenames

cat

Displays and concatenates files

cmp

Compares binary files

cut

Extracts columns of lines

diff

Compares text files

dirname

Extracts the directory from a filename

echo

Prints text

ed

A classic line-based text editor

egrep

Extended grep

ex

A newer line-based text editor

expr

Evaluates a mathematical expression

false

Returns a nonzero exit code

fmt

Breaks long lines and reformats text

grep

Searches for lines matching a regular expression

A multi-purpose typesetting utility

groff head

the first lines of Super-User a file HowDisplays Linux Works: What Every Should Know

ispell

by Brian Ward A spelling checker No Starch Press © 2004 (347 pages)

This guide describes thefile inner workings of a Linux system beginning with the file system and boot process and Displays a text covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printersawith Displays textSamba. file

less more nroff

Table of Contents

Formats roff documents for text display

How Linux Works—What Every Super-User Should patch Incorporates changes intoKnow files; Chapter 1

ISBN:1593270356

the opposite of diff

- The Basics

perl2 Chapter

A Disks, general-purpose scripting language - Devices, Filesystems, and the Kernel

Chapter sed 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

sort5 Chapter

SortsYour lines in a file - Configuring Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter tail8

- Development Tools Displays the

Chapter 9

- Compiling Software From Source Code

split

A stream editor

Chops a file into pieces last lines of a file

Duplicates a file Chapter 10 - Maintaining the Kernel tee

stream

Chapter and Manipulating Peripheral Devices test11 - Configuring ([) Checks a condition Chapter 12 - Printing

tr 13 - BackupsTranslates Chapter

(or substitutes) characters

Chapter 14 - Sharing Files with Samba

true

Returns an exit code of 0 (true)

Chapter 15 - Network File Transfer

Chapter uniq16 - User Environments Removes duplicate

adjacent lines

Chapter 17 - Buying Hardware for Linux

vi

A visual full-screen editor

Chapter 18 - Further Directions

Appendix Classification wc A - Command Counts words,

lines, and characters in a file

Bibliography

xargs Index

Executes a command repeatedly with arguments from the input stream

List of Figures List of Tables List of Sidebars Table A-3: Online

Documentation Commands

Command

Description

info

Displays GNU-style documentation

man

Displays the traditional Unix online manual

Table A-4: Process and System Utility Commands Command

Description

at

Runs a program at a certain time

chfn

Changesfinger information

chsh

Changes shells

crontab

Runs a periodic job

groups

Shows group membership

id

Shows the current user ID

kill

Sends a signal to a process

logger

Records a message to the system logger

login

Allows a user to login

lsof

Lists open files and other information

mount

Attaches a filesystem to a directory tree

newgrp

Changes the current default group

nice

Runs a process with a suggested priority

Changes a password

passwd

printenvHowPrints environment variables Linux Works: What Every Super-User Should Know by Brian Ward Displays processes No Starch Press © 2004 (347 pages)

ps renice reset

This guide describes the inner workings of for a Linux system beginning with the file system and boot process and Changes the suggested priority a process covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers to with Samba. Attempts reset the terminal

strace

Table of Contents

Traces system calls

How Every Super-User Should Know suLinux Works—What Switches users Chapter 1

- The Basics

sync2 Chapter

Writes buffers - Devices, Disks, kernel Filesystems, and to thedisk Kernel

Chapter time3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

top 5 Chapter

Shows processes - Configuring Yourthe Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Displays how much processor and system time a process takes

umount

with the most resource consumption

Detaches a filesystem from a directory tree

Table10 A-5: System Information Chapter - Maintaining the Kernel

Commands

Chapter 11 - Configuring and Manipulating Peripheral Devices

Command

Description

Chapter 12 - Printing

Chapter arch13 - BackupsDisplays

the system architecture

Chapter 14 - Sharing Files with Samba

df 15 - NetworkDisplays disk Chapter File Transfer

usage statistics

Chapter 16 - User Environments dmesg

Displays buffered kernel messages

Chapter 17 - Buying Hardware for Linux

finger Chapter 18 - FurtherDisplays Directionsuser

information

Appendix A - Command Classification

free

Bibliography Index hostname List of Figures

Displays free memory statistics Displays the current host's name

List of Tables

Shows the last users who logged in

Listtty of Sidebars

Displays the current terminal name

last

ISBN:1593270356

uptime

Displays system load and how long the system has been running

vmstat

Displays virtual memory statistics

uname

Displays kernel identification information

w

Displays uptime information and current users

who

Displays current users

whoami

Displays the current user

Table A-6: Archival and Compression Commands

Command

Description

bunzip2

How Linux Works: What Every Super-User Should Know A decompression program

bzip2

by Brian Ward A decompression program No Starch Press © 2004 (347 pages)

cpio gunzip

This guide describes the inner workings of a Linux system beginning with the file system and boot process and An archival program covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

A decompression program A compression program

gzip Table of Contents

How Linux Works—What Every Super-User Should Know

tar

Chapter 1

An archival program

- The Basics

Chapter uncompress 2 - Devices, Disks, Filesystems, and the Kernel A decompression program Chapter 3

- How Linux Boots

unshar- Essential System A de-archival program Files, Servers, and Utilities

Chapter 4

Chapter 5 - Configuring Your Network uudecode A decoding program Chapter 6

(the counterpart of uuencode)

- Network Services

uuencode Encodes Chapter 7 - Introduction to Shellbinary Scripts

file into a text file

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

zcat

ISBN:1593270356

Decompresses into a file stream

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

Table A-7: Miscellaneous Utility Commands

Chapter 12 - Printing

Chapter 13 - Backups

Command

Description

Chapter 14 - Sharing Files with Samba Chapter bc 15 - NetworkAFile Transfer simple calculator Chapter 16 - User Environments

cal

Shows a calendar

Chapter 17 - Buying Hardware for Linux Chapter Directionsthe date18 - FurtherDisplays

current date

Appendix A - Command Classification

dc Bibliography

Runs the RPN calculator

Index

Prints the working directory

pwd

List of Figures Listscript of Tables List of Sidebars

Starts a shell where all output is recorded in a file

sleep

Pauses for a specified number of seconds

strings

Attempts to show any text embedded in a binary file

yes

Prints an endless stream of lines

which

Displays the first matching program in the current path

Table A-8: Development Commands Command

Description

ar

A library archiver

as

An assembler

c++

A C++ compiler

cc

A C compiler

cpp

A C preprocessor

g++

A C++ compiler (see c++)

gcc

A C compiler (see cc)

gdb

The GNU debugger

install

Copies a file into a location with certain parameters

ld

linker

ldd

Displays dynamic libraries

make

A package-building tool

perl

A general-purpose scripting language

Table A-9: Shells How Linux Works: What Every Super-User Should Know

Commandby Brian Ward No Starch Press © 2004 (347 pages)

bash

Description The Bourne Again Shell

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and The C Shell sharing printers with Samba.

csh

The Korn Shell

ksh Table of Contents How Linux Works—What Every Super-User Should Know

The Bourne Shell

Chapter tcsh1

- The Basics

The TC Shell

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

sh

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know Bibliography by Brian Ward

ISBN:1593270356

Abrahams, PaulW., and Bruce Larson. UNIX for the Impatient.2nd ed. Reading:Addison-Wesley, No Starch Press © 2004 (347R. pages) 1995. This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.Language Reference .3rd ed. Reading:Addison-Wesley,1999. Adobe Systems Inc. PostScript

The definitive Table of Contents

reference to the PostScript page description language.

How Linux Works—What Every Super-User Should Know

Adobe Systems Inc. PostScript Language Tutorial and Cookbook.Reading:Addison-Wesley,1985.

Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel A guide to learning the PostScript page description language. Includes many examples.

Chapter 3

- How Linux Boots

Chapter 4 Alfred - Essential System Servers, and and Utilities Aho, V.,Brian W.Files, Kernighan, PeterJ.Weinberger, The

AWK Programming Language .

Chapter 5 - Configuring Your Network Reading: Addison-Wesley, 1988. Chapter 6

- Network Services

By7 the creators oftothis language. Chapter - Introduction Shell Scripts Chapter 8

- Development Tools

Aho, V.,Ravi Sethi,From andSource Jeffery D.Ullman.Compilers: Chapter 9 Alfred - Compiling Software Code

Principles, Techniques, and Tools.

Reading: Addison-Wesley, Chapter 10 - Maintaining the Kernel 1986. Chapter 11 - Configuring and Manipulating Peripheral Devices

The classic textbook for compiler construction, also known as "the dragon book." Although nearly 20 years old, this textbook still covers more than enough for a course. Chapter 13 - Backups Chapter 12 - Printing

Chapter 14 - Sharing Files with Samba

Albitz, Paul, and CricketLiu.DNS and BIND.4th ed. Sebastopol:O'Reilly & Associates, 2001.

Chapter 15 - Network File Transfer

Chapter 16 domain - User Environments The name service

maps names to IP addresses. If you need to administer domain names and you probably need this book.

Chapter 17 have - Buying for Linux you noHardware prior experience, Chapter 18 - Further Directions

Appendix A - Command Classification Appel, AndrewW.. Modern Compiler

Implementation in ML.Cambridge:Cambridge University Press,

Bibliography 1997. Index

of List of One Figures

the many newer compiler books on the market, Appel's guide spends less time with tokenizing focusing instead on intermediate representation, code generation, and advanced topics as optimization. List of such Sidebars parsing, List of and Tables

Beazley,DavidM.Python Essential Reference.2nd ed. Indianapolis: New Riders, 2001. A no-nonsense reference to the Python language and library. Beazley,DavidM.,BrianD.Ward, and IanR.Cooke, "The Inside Story on Shared Libraries and Dynamic Loading." Computing in Science and Engineering 3, no. 5 (2001):90–97. An overview of how shared libraries and dynamic loading work, and the things you can do with them. Bell Labs,Plan 9: Programmer's Manual.2nd ed. Washington, D.C.: International Thompson Publishing, 1995. Plan 9 is the operating system that the creators of Unix made after they got sick of Unix, featuring many interesting improvements in networking and the underlying filesystem infrastructure. Dougherty,Dale, and Arnold Robbins.sed & awk.2nd ed. Sebastopol:O'Reilly & Associates, 1997. A two-for-one guide to the stream editor and the AWK programming language. Filesystem Hierarchy Standard Group. "Filesystem Hierarchy Standard," Version 2.3 (2004),Rusty Russell,Daniel Quinlan, andChristopherYeoh,eds.http://www.pathname.com/fhs/ (accessed March 2004). A document describing why the Linux directory structure looks as it does. Friedl,Jeffery E. F. Mastering Regular Expressions.2nd ed. Sebastopol:O'Reilly & Associates, 2002. The regular expression is the basis of Unix pattern matching. You will use them in basic utilities such asgrep, in configuration files, and in scripting languages such as Perl. Hennessy,JohnL.,DavidA.Patterson, and DavidGoldberg,Computer Architecture: A Quantitative Approach.3rd ed. San Francisco: Morgan-Kaufmann,2002.

Explains why computer hardware works as it does, and why it is designed as it is. This book is comprehensive, covering topics from economic aspects to pipelining and performance analysis. How Linux Works: What Every Super-User Should Know

Hopcroft, E,Rajeev Motwani, and JeffreyD.Ullman,Introduction to Automata Theory, byJohn Brian Ward Languages, and Computation ed. Reading:Addison-Wesley,2000. No Starch Press © 2004 (347.2nd pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

The classic textbook for topics finite such stateasautomata, machines, andtools, elementary complexityshell in scripts, and covering advanced networking,turing firewalls, development device management, computer sharing science printers theory. with Samba. Hyde,Randall.The Art of Assembly Language .San Francisco: No Starch Press, 2003.

Table of Contents

How Linux Works—What Every Super-User Should Know

Covers how to program in x86 assembly language.

Chapter 1

- The Basics

Chapter 2 - Gerry, Devices,and Disks, Filesystems, and theRISC KernelArchitecture.2nd Kane, Joe Heinrich. MIPS

ed. Englewood Cliffs: Prentice Hall PTR,

Chapter 3 - How Linux Boots 1991. Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5 - Configuring Network Describes MIPS Your RISC architecture Chapter 6

and assembly language. An excellent overview of RISC design.

- Network Services

Kernighan, BrianW., andScripts RobPike.The Chapter 7 - Introduction to Shell

UNIX Programming Environment .Englewood Cliffs: Prentice

Hall, Chapter 8 1978. - Development Tools Chapter 9

- Compiling Software From Source Code

The guide toKernel programming Chapter 10 classic - Maintaining the

Unix system, covering the C compiler, shell scripts, and make. Although this book is showing its age (many of the programming components are outdated), it shows Chapter 11 - Configuring and Manipulating Peripheral Devices you basic structure of development environment that is still used today. Chapter 12 the - Printing Chapter 13 - Backups

Kernighan, BrianW., and DennisM.Ritchie. The C Programming Language.2nd ed. Upper Saddle River:Prentice Hall, 1988. Chapter 15 - Network File Transfer Chapter 14 - Sharing Files with Samba Chapter 16 - User Environments

Probably the best computer book ever written.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Killian, Tom,"Processes

as files." Proceedings of the Summer 1984 USENIX Conference, pages

Appendix A - Command Classification 203–207. Salt Lake City, 1984. Bibliography Index

The origin of the /proc filesystem.

List of Figures

StephenC., List of Kochan, Tables

and PatrickWood.Unix Shell Programming .3rd ed. Indianapolis: Sams,2003.

List of Sidebars

Lamb,Linda, and Arnold Robbins.Learning the vi Editor.6th ed. Sebastopol:O'Reilly & Associates, 1998. Lendecke,Volker.How Samba Works.San Francisco: No Starch Press, 2004. A refreshingly short guide to how Samba, SMB/CIFS, and NetBIOS work. Levine,JohnR.,Linkers and Loaders.San Francisco: Morgan-Kaufmann,2000. A comprehensive textbook for how linkers, shared libraries, and dynamic loaders work. Oram,Andrew, and SteveTalbott. Managing Projects with make .2nd ed. Sebastopol:O'Reilly & Associates,1991. Peek, Jerry,GraceTodino-Gonguet, and JohnStrang. Learning the UNIX Operating System .5th ed. Sebastopol:O'Reilly & Associates, 2002. Preston, W.Curtis. UNIX Backup and Recovery .Sebastopol:O'Reilly & Associates, 1999. Backups for the enterprise, including automated backup systems such as Amanda. Raymond, EricS., ed.,The New Hacker's Dictionary .3rd ed. Cambridge:MIT Press, 1996. The in-print version of the so-called jargon file. Salus, PeterH.,A Quarter Century of UNIX.Reading:Addison-Wesley,1994. Where Unix came from and how it evolved. Schneier, Bruce, Applied Cryptography.2nd ed. Hoboken:Wiley,1995. The only guide to cryptography that you're likely to need; explains the theory of cryptographic algorithms and how to implement them.

Schwartz,Randal L., and Tom Phoenix.Learning Perl.3rd ed. Sebastopol:O'Reilly & Associates, 2001. How Linux Works: What Every Super-User Should Know

Silberschatz, Abraham,Greg Gagne, and PeterBaerGalvin,Operating System Concepts.6th ed. ISBN:1593270356 by Brian Ward Hoboken: Wiley, 2002. No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

The classic textbook for topics operating systems kernels, sometimes called "the dinosaur book."shell scripts, and covering advanced such as networking, firewalls, development tools, device management, sharing printers with Samba.

Stallman, Richard,Roland Pesch, and StanShebs.Debugging with GDB.9th ed. Cambridge:Free Software Foundation, 2002. Table of Contents How Linux Works—What Every Super-User Should Know

Stallman, Richard.GNU Emacs Manual.15th ed. Cambridge:Free Software Foundation, 2002.

Chapter 1

- The Basics

Chapter 2 - Devices,Andrew Disks, Filesystems, and Networks. the Kernel 4th Tanenbaum, S., Computer Chapter 3

ed. Upper Saddle River: Prentice Hall PTR, 2002.

- How Linux Boots

Chapter 4 - Essential Systemanything Files, Servers, Utilities Explains just about you'dand want to know about Chapter 5 built. - Configuring are This is Your not aNetwork programmer's Chapter 6

- Network Services

Wall, and Tom Christiansen, Chapter 7 -Larry, Introduction to Shell Scripts

and JonOrwant, Programming Perl.3rd ed. Sebastopol:O'Reilly &

Associates. Chapter 8 - Development Tools Chapter 9

the theory of computer networks and how they

guide.

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

guide describes the inner workings of a Linux system beginning with the file system and boot process and SymbolsThis covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

$#,146 $$,19 ,147

Table of Contents

$0,Linux 147 Works—What Every Super-User Should Know How Chapter 1 - The Basics $1,145–146 Chapter 2

- Devices, Disks, Filesystems, and the Kernel $?,147–148

Chapter 3

- How Linux Boots

$@,146–147 Chapter 4 - Essential System Files, Servers, and Utilities Chapter - Configuring /.See5root filesystemYour Network Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

[.See test

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

A

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and accept,257sharing printers with Samba.

ADSL. See DSL

Table of Contents

aliases, How Linux 306 Works—What Every Super-User Should Know Chapter - The Basics ALSA,1213 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Amanda,280,284

app-defaults. See XSystem resources Chapter 4 - Essential Files, Servers, and Utilities Chapter 5 - Configuring application layer, 88 Your Network Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

archives.See backups

arithmetic tests, 152 Tools Chapter 8 - Development Chapter 9 - Compiling Software From Source Code ARP,108–109 Chapter 10 - Maintaining the Kernel

assembly code, 181–182

Chapter 11 - Configuring and Manipulating Peripheral Devices

at,75 12 - Printing Chapter Chapter 13 - Backups awk,158 Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know

B

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

by Brian Ward No Starch Press © 2004 (347 pages)

backups creating archives, 25 ,275–276,281–282 Table essential of Contents directories, 267–268 How Linux Works—What Every Super-User Should Know extracting archives, 25–26 ,271–272 ,277 ,281–284 Chapter - The Basics full,1268–269 Chapter 2 - Devices, Disks, Filesystems, and the Kernel incremental, 268–271 Chapter 3 - How Linux Boots testing archives, 26 ,276–277,283 Chapter - Essential System Files, Servers, and Utilities to 4CD/DVD writers, 272 Chapter - Configuring to 5hard disks, 272Your Network Chapter 6 - Network Services basename,157–158 Chapter 7

- Introduction to Shell Scripts

bash.8See shell Chapter - Bourne-again Development Tools

Chapter 9 - Compiling .bash_login, 307Software From Source Code Chapter 10 - Maintaining the Kernel

.bash_profile,307–309

Chapter 11 - Configuring and Manipulating Peripheral Devices

.bashrc, Chapter 12 - 307–309 Printing Chapter - Backups bg,20 13 .See alsojob

control

Chapter 14 - Sharing Files with Samba

/bin,30

Chapter 15 - Network File Transfer

/bin/sh. shell Chapter 16 - See User Bourne Environments Chapter - Buying Hardware for Linux block 17 devices. See devices, block Chapter 18 - Further Directions

block size (for tape drives). See tape drives,block size

Appendix A - Command Classification

boot loaders Bibliography Indexdescription,33 List ofGRUB, Figures 60 ,218–220

60 ,216–217,220–222 List ofLILO, Tables 59–62 List ofusing, Sidebars booting overview, 53–54 PC,217 Bourne shell command substitution, 155 command-line editing, 12–13,311 conditionals,148–153 description,2 here documents, 156–157 loops,153–154 parameters,145–147 prompt (seeprompt) quoting, 144–145 redirecting input and output, 15–16 startup file order, 307–309 subshells,160–161 user input, 161 using,2–4 variables,10 ,145–148 versus the C shell, 311 wildcards, 6–7,10 ,153 Bourne-again shell, 2.See also Bourne shell broadband, 105–107 bunzip2,27 .bz2,27 ,184 bzImage,214–215.See alsokernel, image file bzip2,27

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know

C

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

.c,164,185

by Brian Ward No Starch Press © 2004 (347 pages)

.C,185

Table of Contents

C compiler How Linux Works—What Every Super-User Should Know running, 164–165 Chapter 1 - The Basics

workings, 181–182 Chapter 2 - Devices, Disks, Filesystems, and the Kernel Chapter 3 - How Linux Boots C preprocessor, 166–167 Chapter 4

- Essential System Files, Servers, and Utilities

cable modem, 105–107,300 - Configuring Your Network cancel, 257 Chapter 6 243–244 - Network ,Services Chapter 5

Chapter 7 - 239–240 Introduction to Shell Scripts cardctl, Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

cardmgr,235–237,239

case,10 153- Maintaining the Kernel Chapter Chapter cat,311 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing

.cc,185

Chapter 13 - Backups

CC,174 Chapter 14 - Sharing Files with Samba Chapter 15 - Network Transfer;gcc cc,160 .See alsoCFile compiler Chapter 16 - User Environments

cd,5

Chapter 17 - Buying Hardware for Linux

cdrecord, 229–231 ,269,272 Chapter 18 - Further Directions Appendix A 174 - Command Classification CFLAGS, ,187–188 Bibliography

CHAP.See PPP,CHAP Index List of Figuresdevices. character

See devices, character

List of Tables

chat,99–102

List of Sidebars

chfn,69

chmod,23–24,143 chsh,9,69 clobbering, 15 command path, 11 ,304–305,308,310 command substitution. See Bourne shell ,command substitution compress,27 configuration files, 10 ,67–68.See alsodot files configure,185–189 cost considerations, 322–325 cp,4 cpio,280,282–283 cpp.See C preprocessor CPPFLAGS,174,187–188,199 CPU.See processor cron,73–75 csh,306.See alsotcsh .cshrc,310 CUPS access control, 257 adding printers, 248–250 auto-discovery, 258–259 basic setup, 245–246 command overview, 256–257 default printer, 249

ISBN:1593270356

introduction,243 LPD compatibility, 259 print filters (see printing, filters ;foomatic ) How Linux Works: What Every Super-User Should Know printer configuration, ISBN:1593270356 by Brian Ward 252–256 printer devices, 250–252 No Starch Press © 2004 (347 pages) security,246–247 This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and starting, 247 sharing printers with Samba. testing, 248–249 ,256 troubleshooting,260–262 Table Web of Contents interface, 247,256 How Linux WebWorks—What site, 265 Every Super-User Should Know Chapter 1

- The Basics

CVS,328 - Devices, Disks, Filesystems, and the Kernel .cxx, 185- How Linux Boots Chapter 3 Chapter 2 Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

D

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and daemons,65sharing printers with Samba.

databases, 328 date, 72Works—What Every Super-User Should Know How Linux

Table of Contents

Chapter 1 DBM, - The Basics DB and 328 Chapter 2

Devices, Disks, Filesystems, and the Kernel dd,34–35-,228 ,279–280

Chapter 3

- How Linux Boots

debugfs, Chapter 4 - 50 Essential System Files, Servers, and Utilities Chapter 5 - 176–177 Configuring Your Network debugger, Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

#define,166

depmod, Chapter 8 224 - Development Tools Chapter /dev,930 - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel

development tools, introduction, 163

Chapter 11 - Configuring and Manipulating Peripheral Devices

devfs, Chapter 1238 - Printing Chapter 13 - Backups devices Chapter 14 - Sharing Samba accessing withFiles dd,with 34–36 Chapter 15 -33–34 Network File Transfer block, ,210 Chapter 16 - User Environments CD/DVD writers, 229–231 Chapter 17 - Buying Hardware character, 33–34 ,212 for Linux Chapter 18 - Further Directions creating device files, 37–38 Appendix A - cameras, Command Classification digital 233 Bibliography disks,36 ,38 ,

210 (see alsodisks) media, 233 List offloppy Figuresdisks, 37 ,210,228–229 List ofIEEE Tables1394, 234 List ofkeyboard, Sidebars 212,232,320 loopback,210,231 mouse,212,232,320 parallel ports, 37 ,212,250 pipe, 33–34 printers,250–252,321 scanners,240 serial ports, 37 ,98–99,251 socket, 33–34 sound, 37 ,213 tape drives (seetape drives) terminal, 36 types,33–34 USB (seeUSB) df,47–48 Indexflash

dhclient,96 DHCP, 96 diff,8,148 digital cameras. See devices,digital cameras directories changing,5 creating,6 hierarchy,30–32 listing,4 path specification, 5 printing current directory, 8 removing,6 structure, 5 disable,257

disks devices (seedevices, disk ) partitioning, 38–41 How Linux Works: What Every Super-User Should Know performance, 316–317 ISBN:1593270356 by Brian Ward purchasing, 324–325 No Starch Press © 2004 (347 pages) space (see filesystems, capacity ) workings of a Linux system beginning with the file system and boot process and This guide describes the inner covering system ID, 39 advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. dmesg,35 ,222 dot of files, 10 ,303 Table Contents How Linux Works—What Every Super-User Should Know dotted-quad, 89 Chapter 1

- The Basics

DSL,105–107 ,300 - Devices, Disks, Filesystems, and the Kernel du, 48 Chapter 3 - How Linux Boots Chapter 2

Chapter Essential System Files, Servers, and Utilities dump,446 ,-280–281 Chapter 5

- Configuring Your Network

dynamic -linker/loader. See runtime dynamic linker/loader Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

E

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and e2fsck.Seesharing fsck printers with Samba.

echo,5

Table of Contents

effective user ID, 85Every .See Super-User alsouser ID How Linux Works—What Should Know Chapter EHCI,1213- The Basics Chapter 2

- Devices, Disks, Filesystems, and the Kernel

elapsed time, 76 - How Linux Boots emacs, Chapter 4 13 - Essential System Files, Servers, and Utilities Chapter 3

Chapter 5 - Configuring emergency booting, Your 62 Network Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

enable,257

Encap,8 193–196 Chapter - Development Tools Chapter 9 167 - Compiling Software From Source Code #endif, Chapter 10 - Maintaining the Kernel

environment variables, 10 ,160

Chapter 11 - Configuring and Manipulating Peripheral Devices

error code. See exit Chapter 12 - Printing

code

Chapter 13 - Backups error messages Chapter 14 - Sharing Files with Samba common, 17–19 Chapter 15 - Network File Transfer compiler, 165,197–200 Chapter 16 - User Environments configure, 188–189 Chapter 17 - build, Buying 215 Hardware for Linux kernel Chapter 18 -167–168 Further Directions linker, Appendix A -172 Command Classification make, Bibliography printing,260–262 IndexSamba,289 List ofscripts, Figures 178–179 List ofunderstanding, Tables 16–17 List of Sidebars

ESSID, 121–122 /etc,30 ,67–68

/etc/fstab,46–47,51–52 /etc/group,70–71 /etc/hosts,94–96 /etc/inetd.conf,127 /etc/init.d,57 /etc/inittab,54–56 /etc/ld.so.cache,169 /etc/ld.so.conf,169–170 /etc/localtime,72–73 /etc/modprobe.conf,225–226 /etc/modules.conf,225 /etc/nologin,59 /etc/nsswitch.conf,95 /etc/passwd,68–70.See alsopasswd /etc/pcmcia,122–123,237–239 /etc/rc*.d,56–59 /etc/resolv.conf,95 /etc/services,113,127.See alsonetwork, ports and services /etc/shadow,68 /etc/shells,70 /etc/syslog.conf,66–67 Ethernet

IP networking, 108–109 network interface, 92–93,317–318 networks,How 107–108 Linux Works: What Every Super-User Should Know wireless,121–124 ,318 by Brian Ward exec,160 No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and

executablescovering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with ,Samba. creating,164–165 ,167–172 181–182 file format, 209 30–31 Table locations, of Contents setuid, 22 ,45 ,152Every Super-User Should Know How Linux Works—What shell 143 (see alsoshell scripts) Chapter 1 scripts, - The Basics Chapter 2 - Devices, Disks, Filesystems, and the Kernel exit code, 147–148 Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

expr,160

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index F facility,

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. syslog, 66–67

faxing,71 fdformat, 229 How Linux Works—What Every Super-User Should Know

Table of Contents

Chapter 1 38–41 - The Basics fdisk, Chapter 2

- Devices, Disks, Filesystems, and the Kernel fg,20 .See alsojob control

Chapter 3

ISBN:1593270356

- How Linux Boots

file,48 - Essential System Files, Servers, and Utilities Chapter Chapter 5 - Configuring file descriptor, 77 Your Network Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

files 8 Chapter

- Development Tools

file mark. See tape drives,file mark

archiving and compressing, Chapter 9 - Compiling Software From 25–27 Source Code as 10 swap, 52 (see the also swap) Chapter - Maintaining Kernel comparing, 8 Chapter 11 - Configuring and Manipulating Peripheral Devices copying, 4 (see Chapter 12 - Printing

alsofiles, transferring)

deleting, 5 Chapter 13 - Backups device (seefiles, ) Chapter 14 - Sharing Filesspecial with Samba editing, 13 ,158–159 ,312 Chapter 15 - Network File Transfer extensions, 157–158 Chapter 16 - User Environments finding, 9 Chapter 17 - Buying Hardware for Linux identifying type, 8 Chapter 18 - Further Directions listing, Appendix A -4 Command Classification matching Bibliography

(seeBourne shell ,wildcards) and renaming, 4 77–78 List ofopen, Figures 21–24,151–152 List ofpermissions, Tables List ofregular, Sidebars22 sorting,9 special,33–34,37–38,77 temporary,155–156 testing, 150–151 transferring, 133,160–161,295–301 (see alsorsync) type, 22 ,33–34,150–151 viewing,8–9 Indexmoving

filesystems buffering, 44 capacity, 47–48 checking and repairing, 48–50 creating,42 FAT,41 ,45–46,214,228 ISO9660, 41 ,44–45,214,230–231 kernel configuration, 213–214 mount options, 42–47 mounting (attaching), 42–44,224,228 proc,30 ,50–51,214 Reiser, 41 second extended, 41–42 SMB,293 third extended, 41–42,50 tmpfs, 51 types,41–42 Windows and MS-DOS (seefilesystems, FAT) find,9 firewall accepting packets, 115 command reference, 117–118 denying connections, 115 description,113–114

IP chain, 114 IP table, 114–118 kernel configuration, 211–212 How Linux Works: What Every Super-User Should Know order of rules, 115–116 ISBN:1593270356 by Brian Ward policy,114 No Starch Press © 2004 (347 pages) strategies, 116–117 This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

Firewire.Seesharing devices ,IEEEwith 1394 printers Samba. firmware, 322 Table ofmedia. Contents flash See devices,flash

media

How Linux Works—What Every Super-User Should Know

floppy disks. See devices,floppy disks - The Basics

Chapter 1

foomatic, ,255–256 Chapter 2 -243 Devices, Disks, Filesystems, and the Kernel Chapter 3 - How Linux Boots for,153–154 Chapter 4

- Essential System Files, Servers, and Utilities

fsck,48–50 - Configuring Your Network

Chapter 5

fstab. /etc/fstab Chapter 6 See - Network Services Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

G

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and gateway, 89 ,sharing 93–94,printers 103 with Samba.

gcc , 160.See alsoC compiler;cc

Table of Contents

gdb, 176–177 How Linux Works—What Every Super-User Should Know Chapter 1 -69 The Basics GECOS, Chapter 2

Disks, Filesystems, and the Kernel getty,55- ,Devices, 71

Chapter 3

- How Linux Boots

Ghostscript, 146–147 ,255–256 ,262–265 Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5 ,232 - Configuring Your Network gpm,34 Chapter 6

- Network Services

graphics cards, 318–319,325 - Introduction to Shell Scripts grep,87,148 Chapter - Development Tools Chapter 7

Chapter Compiling Software Code group 9ID-(GID), 68–69 .See From also Source /etc/group Chapter 10 - Maintaining the Kernel

groups, 22 ,70–71.See also/etc/group

Chapter 11 - Configuring and Manipulating Peripheral Devices

GRUB. boot loaders,GRUB Chapter 12See - Printing Chapter 13 25 - Backups gunzip, ,27 Chapter 14 - Sharing Files with Samba

.gz,25 ,27 ,184

Chapter 15 - Network File Transfer

gzip,16 25 ,-27 Chapter User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know

H

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

.h,165,185

by Brian Ward No Starch Press © 2004 (347 pages)

halting,58–59

Table of Contents

hard links, 25 How Linux Works—What Every Super-User Should Know Chapter 1 - components, The Basics hardware Chapter 2

314–315

- Devices, Disks, Filesystems, and the Kernel

hardware upgrades, 321–322 Chapter 3 - How Linux Boots head,49 - Essential System Files, Servers, and Utilities Chapter Chapter header5 Chapter 6

- Configuring Your code Network files. See source ,header files - Network Services

here documents. See Bourne shell ,here documents - Introduction to Shell Scripts /home, Chapter 8 30 - Development Tools Chapter 7

Chapter host,995 - Compiling Software From Source Code Chapter 10 - Maintaining the Kernel

hostname resolution, 94–96,117,128,327

Chapter 11 - Configuring and Manipulating Peripheral Devices

host-to-network Chapter 12 - Printinglayer,

88 ,92–93

Chapter 13 support, - Backups234–235 hotplug Chapter 14 - Sharing Files with Samba

HPIJS,264

Chapter 15 - Network File Transfer

httpd, Chapter 16126 - User Environments Chapter 17 - 72–73 Buying Hardware for Linux hwclock, Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

I

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and ICMP,90–91sharing printers with Samba.

IEEE 1394. See devices,IEEE 1394 #if, 167Works—What Every Super-User Should Know How Linux

Table of Contents

Chapter 1 - The Basics ifconfig, 92–93 Chapter 2

- Devices, Disks, Filesystems, and the Kernel #ifdef,167

Chapter 3

- How Linux Boots

ifhp,243 Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5 - Configuring Your Network if-then-else. See Bourne shell, Chapter 6

conditionals

- Network Services

Imake, 190–191 Chapter 7 - Introduction to Shell Scripts #include, 166 Chapter 8 - Development Tools Chapter 9 files. - Compiling Software From Sourcefiles Code include See source code ,header Chapter 10 - Maintaining the Kernel

inetd,127–128

Chapter 11 - Configuring and Manipulating Peripheral Devices

inetd.conf. See /etc/inetd.conf Chapter 12 - Printing Chapter 13 - Backups info pages, 15 ,32 Chapter 14 - Sharing Files with Samba

init,53–59

Chapter 15 - Network File Transfer

init.d. /etc/init.d Chapter 16 See - User Environments Chapter 17 - Buying Hardware for Linux

initial RAM disk, 61 ,210,221–222 initrd.See initial RAM disk Appendix A - Command Classification Chapter 18 - Further Directions

Bibliography inittab.See /etc/inittab Index

inodes,42

List of Figures

Internet layer, List of Tables

88–90

List Sidebars 89 ,109–110 IPofaddress,

IP chain. See firewall ,IP chain IP filter. See firewall IP forwarding, 110 IP masquerading, 119.See alsonetwork, address translation IP table. See firewall ,IP table IPC, 207 IPP, 245–246,251 iwconfig,121–123

Index

How Linux Works: What Every Super-User Should Know

J

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

jar,181

by Brian Ward No Starch Press © 2004 (347 pages)

Java, 180–181

Table of Contents

JDK, 181Works—What Every Super-User Should Know How Linux Chapter 1 - The job control, 20Basics .See

alsoprocesses

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

journal file, 42

JRE, 180 Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know

K

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

by Brian Ward No Starch Press © 2004 (347 pages)

kernel boot floppy, 223 Table build of Contents requirements, 202 How Linux Works—What Every Super-User Should Know compiling, 214–215 Chapter 1 - The Basics configuring, 204–214 Chapter 2 - Devices, Disks, Filesystems, and the Kernel description, 32–33 Chapter 3 - How Boots image file, Linux 201,216–221 Chapter 4 - Essential System Files, Servers, and Utilities installing, 216–222 Chapter 5 - Configuring Your Network 202 justification for customizing, Chapter 6 - Network messages, 35 Services Chapter 7 - Introduction Shell Scripts ,223–226 modules, 201,206,to 208 ,214–216 Chapter 8 - Development Tools parameters, 216,219 ,221,226 Chapter 9 - Compiling From Source Code release version Software numbers, 203–204 Chapter 10 - Maintaining the Kernel source code, 203–204 Chapter 11 - Configuring startup, 53–54 and Manipulating Peripheral Devices Chapter 12 - Printing testing, 222 Chapter 13 - Backups

keyboard.See devices,keyboard

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

L

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and ld.See linkersharing printers with Samba.

ld.so,168–169

Table of Contents

ld.so.cache. See /etc/ld.so.cache How Linux Works—What Every Super-User Should Know Chapter 1 - The Basics ld.so.conf. See /etc/ld.so.conf Chapter 2

- Devices, Disks, Filesystems, and the Kernel

LDAP, 329 - How Linux Boots ldconfig, 169 System Files, Servers, and Utilities Chapter 4 - Essential Chapter 3

Chapter 5 - Configuring Your Network ldd,169 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

LDFLAGS,174,187–188

LD_LIBRARY_PATH, ,312 Chapter 8 - Development169–171 Tools Chapter - Compiling lease 9(DHCP), 96 Software From Source Code Chapter 10 - Maintaining the Kernel

less,8

Chapter 11 - Configuring and Manipulating Peripheral Devices

lex,177 Chapter 12 - Printing Chapter /lib,13 30 - Backups Chapter 14 - Sharing Files with Samba

libraries description,167–168 locations, 30 Chapter 17 - Buying Hardware for Linux shared (see shared libraries ) Chapter 18 - Further Directions static (see static libraries ) Appendix A - Command Classification Chapter 15 - Network File Transfer Chapter 16 - User Environments

Bibliography LILO.See boot

loaders,LILO

Index

linker, 165,167–168,170

List of Figures

links. See hard List of Tables

links;symbolic links

List of Sidebars listen (on a network

port), 113,126

literal.See Bourne shell, quoting ln,24–25 load average, 81 localhost. See loopback network interface localtime.See /etc/localtime logging commands, 83–84 login,71 loopback network interface, 92 lp,243–244 lpadmin,247–249,257 LPD,243,251,259 lpd,126 lpinfo,250,257 lpoptions,249,257 lppasswd,257 lpq,243–244 lpr,243–244 lprm,243–244 LPRng,243 lpsched, 243 lpstart,257 lpstat,243–244,248–249,257,260 ls,4,10

lsmod,223 lsof,77–78,134–135 lsusb,232

How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

ltrace,78–79 No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know

M

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

m4, 180

by Brian Ward No Starch Press © 2004 (347 pages)

MAC address, 108

Table of Contents

Mac OSWorks—What X, filesharing, 285 How Linux Every Super-User Should Know Chapter Basics ,186,188 make,1165- ,The 171–175 Chapter 2

- Devices, Disks, Filesystems, and the Kernel MAKEDEV, 38

Chapter 3

- How Linux Boots

man,13 alsomanual Chapter 4 .See - Essential System pages Files, Servers, and Utilities Chapter 5 pages, - Configuring Your 305,308,310 manual 13–15 ,32 ,Network Chapter 6

- Network Services

MBR, 217 - Introduction to Shell Scripts mcopy, Chapter 8 228 - Development Tools Chapter 7

Chapter mdir,9228- Compiling Software From Source Code Chapter 10 - Maintaining the Kernel

memory,316

Chapter 11 - Configuring and Manipulating Peripheral Devices

memory Chapter 12 -usage, Printing82–83 Chapter 13 - 228 Backups mformat, Chapter 14 - Sharing Files with Samba

minicom,98–99

Chapter 15 - Network File Transfer

mkdir, Chapter 166 - User Environments Chapter mke2 17 - Buying Hardware for Linux Chapter 18 - Further Directions

fs,42

Appendix A - Command Classification Bibliography mkisofs,230–231 Index

mknod,37

List of Figures

mkswap, 51–52 List of Tables List of Sidebars mktemp, 156

modems,98–99,320–321 modprobe,223–226 modprobe.conf.See /etc/modprobe.conf modules.conf.See /etc/modules.conf monitors,319–320 more,8 motherboard, 315 mount,43 mount point, 43 mountd,126 mouse.See devices,mouse mt,274–279

mtools,228 multiple heads, 319 mv,4

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

N

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and printers with Samba. nameserver,sharing 95

NAT. See network, address translation nc.Linux See netcat How Works—What Every Super-User Should Know

Table of Contents

Chapter 1 136–137 - The Basics netcat, Chapter 2

- Devices, Disks, Filesystems, and the Kernel

netmask (subnet mask). See subnet - How Linux Boots netstat, Chapter 4 - 133–134 Essential System Files, Servers, and Utilities Chapter 3

Chapter 5 - Configuring Your Network network Chapter 6 - Network Services address translation (NAT),

110,119–120,211–212

Chapter 7 - Introduction to Shell Scripts broadband (seebroadband ) Chapter 8 - Development Tools configuration basics, 87 Chapter 9 - Compiling Software From Source Code DHCP (seeDHCP ) Chapter 10 - Maintaining the Kernel diagnostic tools, 133–137 Chapter 11 - Configuring and Manipulating Peripheral Devices Ethernet (seeEthernet ) Chapter 12 - Printing firewall (seefirewall ) Chapter 13 - Backups hostname resolution

(seehostname resolution)

Chapter 14 - Sharing Files with Samba interface, 92–93 Chapter 15 - configuration, Network File Transfer kernel 211–212 Chapter 16 - User Environments latency, 90–91 Chapter 17 - Buying Hardware for Linux layers, 88 (see alsoapplication

layer;host-to-network layer;Internet layer;transport layer)

Chapter 18 -and Further Directions ports services, 112–113,133–135,140–141 Appendix - Command PPPA (see PPP) Classification Bibliography private,109–110 Indexsecurity,123–124,137–141 List of Figures

Network Time Protocol (NTP), 73

List of Tables

NFS, 329 List of Sidebars nfsd,126 nice value, 80–81 NIS, 329 nm,168 Nmap, 140–141 nmbd,126,286,289 notebooks,325.See alsoPCMCIA nsswitch.conf.See /etc/nsswitch.conf

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

O

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing .o.See object file printers with Samba.

object file, 165,181–182

Table of Contents

OHCI, 213 How Linux Works—What Every Super-User Should Know Chapter 1 - The 183 Basics open source, Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

OpenSSH.See SSH

OSS,213 Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5 - Configuring Your Network overclocking, 215,315 Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index P

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. description language, 242

page PAGER,312

Table of Contents

PAM, 328 How Linux Works—What Every Super-User Should Know Chapter 1 -PPP The Basics PAP. See ,PAP Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

parallel ports. See devices,parallel ports

partitioning. See disks ,partitioning Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5 9 - .Configuring Your Network passwd, See also/etc/passwd Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

passwords, changing, 9,69–70.See alsopasswd;/etc/passwd

patching SeeTools source Chapter 8 -software. Development

code, patching

Chapter 9 -command Compiling Software path.See path From Source Code Chapter 10 - Maintaining the Kernel

pathname.See path specification

Chapter 11 - Configuring and Manipulating Peripheral Devices

PC cards. See PCMCIA Chapter 12 - Printing Chapter 13 -209 Backups PCMCIA, ,235–240 Chapter 14 - Sharing Files with Samba

performance,81–83

Chapter 15 - Network File Transfer Chapter 16 - User Environments Perl,178–179 Chapter 17 - Buying Hardware Linux permissions (modes). Seefor files ,permissions;umask Chapter 18 - Further Directions

PHP,180 Appendix A - Command Classification Bibliography ping,90 Index

pipe, 15

List of Figures

pipe devices. List of Tables

See devices,pipe

List of Sidebars 191–193 pkg-config,

Plug and Play, 209 portmap,126,137 PostScript,242,244 power management, 208 PPD file, 250,252–256,265 PPP basics,96–98 CHAP,100,102–103 directory permissions, 103–104 kernel support, 211 options files, 99–101 ,103–104 over Ethernet (PPPoE), 106–107 PAP, 100,102–103 pppd,97–105 prefix, installation, 186–187 printers.See devices,printers printing clients,243–245 CUPS (seeCUPS) filters, 241,243,253–256,261 from Windows clients, 290–291 network, 244–245 overview, 241–242 photographs,264 servers, 243 to file, 252 to Windows shares, 293–294 priority

processes (seeprocesses,priority ) syslog,66–67 private key, How 131 Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

private network. See network, private No Starch Press © 2004 (347 pages) /proc.See filesystems, proc the inner workings of a Linux system beginning with the file system and boot process and This guide describes

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and

processes sharing printers with Samba. as files (seefilesystems, proc) background, 21 Table of Contents ID,147 How Linux Works—What Every Super-User Should Know kernel operation, 32–33 Chapter 1 - The Basics listing, 19 ,76–78 Chapter 2 - Devices, Disks, Filesystems, and the Kernel priority, 80–81 Chapter 3 - How Linux Boots terminating, 20 Chapter 4 - Essential System Files, Servers, and Utilities processor, 208,315,323–324 Chapter 5 - Configuring Your Network Chapter 6 - Network .profile, 307 Services Chapter 7

- Introduction to Shell Scripts

promiscuous mode, 133–135 - Development Tools

Chapter 8

Chapter 9 3-,305–306 Compiling Software From Source Code prompt, Chapter ps,19 10 ,76- Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices

pseudo-terminals, Chapter 12 - Printing 36 Chapter 13 - Backups pseudo-users, 69

Chapter 14 - Sharing Files with Samba

public key, 131 pump,16 96 - User Environments Chapter

Chapter 15 - Network File Transfer Chapter pwd,817 - Buying Hardware for Linux Chapter 18 - Further Directions

Python,179–180

Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index R

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. See filesystems, tmpfs

RAM disk. RARP,109

Table of Contents

rasterizing, 241–242,Every 262–264 How Linux Works—What Super-User Should Know Chapter 1 - The Basics rc,55–58 Chapter 2

- Devices, Disks, Filesystems, and the Kernel rc*.d.See /etc/rc*.d

Chapter 3

- How Linux Boots

RCS,328 Chapter 4 - Essential System Files, Servers, and Utilities Chapter 5 296 - Configuring Your Network rdist, Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

real user ID, 85 .See alsouser ID

rebooting, ,58–59 Tools Chapter 8 - 55 Development Chapter 9 regular

- Compiling Software expressions, 7,159 From Source Code reject,257

Chapter 10 - Maintaining the Kernel

Chapter 11 - Configuring and Manipulating Peripheral Devices

renice, Chapter 12 80–81 - Printing Chapter 13 - Backups rescan-scsi-bus.sh, 233 Chapter 14 - Sharing Files with Samba

restore,281–282

Chapter 15 - Network File Transfer

rm,5 16 - User Environments Chapter Chapter 17 6 - Buying Hardware for Linux rm -rf, Chapter 18 - Further Directions

rmdir,6

Appendix A - Command Classification Bibliography root directory.

See root filesystem

Index

root filesystem, 30–31,42 ,53–54,216

List of Figures

root shell, List of Tables

ISBN:1593270356

83–84

List of Sidebars route, 110

router, 89 ,93–94,106,110–111 routers, 91 RPC,137 rpcinfo,137 rsync basics,296–297 compression,300 exact duplicates, 297–298 excluding files, 299 limiting bandwidth, 300 SSH and, 296 testing transfers, 299–300 trailing slash, 298 runlevels,54–59 runtime dynamic linker/loader, 169 runtime library search path, 169

Index

How Linux Works: What Every Super-User Should Know

S

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

by Brian Ward No Starch Press © 2004 (347 pages)

Samba access control, 287–288 Table client, of Contents 291–294 How Linux Works—What Every Super-User Should Know domain, 286 Chapter 1 - settings, The Basics 286 global Chapter 2 - directories, Devices, Disks, Filesystems, and the Kernel home 290 Chapter 3 - How Linux Boots introduction, 285–286 Chapter 4 - Essential System message logging, 289Files, Servers, and Utilities Chapter 5 - Configuring Your Network printing, 251 Chapter 6 - Network shares, 286 Services Chapter 7 - Introduction to Shell Scripts starting, 289 Chapter 8 -and Development Tools287–288 users passwords, Chapter 9 - Compiling workgroup, 286 Software From Source Code Chapter 10 - Maintaining the Kernel

saved user ID, 85 .See alsouser ID /sbin, Chapter 1231 - Printing

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 13 - See Backups scanners. devices,scanners Chapter 14 - Sharing Files with Samba

scheduling jobs. See cron;at

Chapter 15 - Network File Transfer

scp,133 Chapter 16 - User Environments

Chapter 17 328 - Buying Hardware for Linux screen, Chapter 18 - Further Directions

scripting languages, 178–180

Appendix A - Command Classification

SCSI Bibliography Indexdisk

support in kernel, 210–211

List ofprinters, Figures 251 List of Tables SCSI disk

assignment, 36

List of Sidebars

second extended filesystem. See filesystems, second extended sed,158–159

serial ports. See devices,serial ports services adding and removing, 57–58 starting and stopping, 56–59 services.See /etc/services setserial,98–99 setuid.See executables,setuid shadow.See /etc/shadow shared libraries, 30 ,79 ,168–171,187,195–196 shell scripts creating,143–144 limitations,144,161 utilities,157–160 shell.See alsoBourne shell changing,9 interactive,307,309 login,307,309 non-interactive,308 using,2 shift,146 shutting down, 58–59 single-user mode, 62 small computers, 325–326 smbclient,291–294

ISBN:1593270356

smbd,126,286,289 smbmount,293 How Linux Works: What Every Super-User Should Know

smbpasswd,288

by Brian Ward

ISBN:1593270356

socket devices. No Starch See devices, Press © 2004 socket (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and sort,9

covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and Samba.

sharing printers with sorting.See files, sorting

sound devices. See devices, sound Table of Contents

source code configuring, 185–192,194–196 - The Basics dependencies, 171–173 Chapter 2 - Devices, Disks, Filesystems, and the Kernel documentation, 185 Chapter 3 - How Linux Boots header files, 165–166,198–199 Chapter 4 - Essential System Files, Servers, and Utilities installing,186,188,191,193–196 Chapter 5 - Configuring Your Network introduction,164–167 Chapter 6 - Network Services kernel (seekernel,source code) Chapter 7 - Introduction to Shell Scripts macros, 166–167 Chapter 8 - Development Tools patching,196–197 Chapter 9 - Compiling Software From Source Code unpacking, 184–185 Chapter 10 - Maintaining the Kernel How Linux Works—What Every Super-User Should Know Chapter 1

Chapter special11characters, - Configuring11–12 and Manipulating Peripheral Devices Chapter 12 - Printing

SSH,129–133 sshd,126 Chapter 14 - Sharing Files with Samba Chapter 13 - Backups

Chapter 15 - Network File Transfer SSL, 329 Chapter 16 - User Environments

standard error, 16

Chapter 17 - Buying Hardware for Linux

standard 15–16 Chapter 18 -input, Further3–4, Directions

Appendix A -output, Command Classification standard 3–4, 15–16 Bibliography

startup files components,304–307 List of Figures defaults,311 List of Tables principles,304 List of Sidebars problems,312 Index

static libraries, 30,168 stderr.See standard error stdin.See standard input stdout.See standard output strace,78–79 su,83 subnet,89–90,92–93,109–110 subshells.See Bourne shell,subshells sudo,84 superblock, 42,49 superformat,229 superuser,83–84 swap, 46,51–52 swapon,51–52 symbolic links, 24–25,151 sync,44 syslog,66–67,126,222 system calls, 14,77 system clock, 72–73 system crashes due to filesystem error, 48 recovering from, 62 system time, 76

Index

How Linux Works: What Every Super-User Should Know

T

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

tail,9

by Brian Ward No Starch Press © 2004 (347 pages)

TAPE,273

Table of Contents

tape drives How Linux Works—What Every Super-User Should Know advancing and rewinding Chapter 1 - The Basics

tape, 276–279

as 2backup device, Chapter - Devices, Disks,268 Filesystems, and the Kernel block 280 Boots Chapter 3 -size, How Linux

device names, System 272–273 Chapter 4 - Essential Files, Servers, and Utilities file5mark, 273–280 Chapter - Configuring Your Network mt6(see mt) Services Chapter - Network

status, ,279 to Shell Scripts Chapter 7 - 274 Introduction Chapter 8 - Development Tools tar,25–27 ,184,269–272 ,275–277,280,295 Chapter 9

Tcl,180

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

TCP, 88 ,126 ,135–136 Chapter 11,112–113 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing TCP wrapper, 127–128 Chapter 13 - Backups

tcpd.See TCP wrapper

Chapter 14 - Sharing Files with Samba

tcpdump, Chapter 15 - 135–136 Network File Transfer Chapter tcsh,16 310- User Environments Chapter 17 - Buying Hardware for Linux

.tcshrc,310

Chapter 18 - Further Directions

telnet, Appendix A 126 - Command Classification Bibliography temporary

files. See files, temporary

Index

terminating programs, 3 test, 148–153 List of Tables List ofprinting, Sidebars5 searching,7 viewing,8–9 List of Figures

text .tgz,27 third extended filesystem. See filesystems, second extended thrashing,52 ,82–83.See alsoswap time,76 timestamp, 5 /tmp,31 top,76 ,80 touch,5 traceroute,91 tracing program execution, 78–79 transport layer, 88 ,112–113 tune2fs,42 tunneling, 129–130

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

U

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba. UDP,112–113 ,135–136

UHCI,213 umask, ,26 ,271,307 How Linux24 Works—What Every Super-User Should Know

Table of Contents

Chapter 1 44 - The Basics umount, Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

undefined references, 167

Unix, 4relationship to Linux, 1–2 Chapter - Essential System Files, Servers, and Utilities Chapter 5 154 - Configuring Your Network until, Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

unzip,27

USB,51 ,231–233,Tools 251 Chapter 8 ,213 - Development Chapter 9 (UID), - Compiling Software From Source Code user ID 68–69 Chapter 10 - Maintaining the Kernel

user input. See Bourne shell ,user input

Chapter 11 - Configuring and Manipulating Peripheral Devices

user time, 76 Chapter 12 - Printing Chapter - Backups users,13 manipulating,

69–70

Chapter 14 - Sharing Files with Samba

/usr,31–32

Chapter 15 - Network File Transfer

/usr/local, ,193,304 Chapter 16 - User 32 Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know

V

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

/var,31

by Brian Ward No Starch Press © 2004 (347 pages)

vi,13

Table of Contents

vipw, 70Works—What Every Super-User Should Know How Linux Chapter - The Basics virtual1consoles, 36 ,55 ,63 ,71 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

viruses and worms, 139 - How Linux Boots /vmlinuz, 33 ,219–220 .See kernel, Chapter 4 - Essential System Files,also Servers, andimage Utilitiesfile Chapter 3

Chapter 5 82–83 - Configuring Your Network vmstat, Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

VPN,328

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

ISBN:1593270356

Index W Web

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing servers, 328 printers with Samba.

WEP, 122–124 while, How Linux154 Works—What Every Super-User Should Know

Table of Contents

Chapter 1 - See The Basics wildcards. Bourne

shell ,wildcards;regular expressions

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 6

- Network Services

Windows Chapter 3 - How Linux Boots booting, 217,219 Chapter 4 - Essential System Files, Servers, and Utilities filesharing,285–290 (see alsoSamba) Chapter 5 - Configuring Your Network printer sharing, 290–291 (see alsoSamba) Winmodems, 320–321to Shell Scripts Chapter 7 - Introduction Chapter 8 script, - Development Tools wrapper 170–171 Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know by Brian Ward No Starch Press © 2004 (347 pages)

X

ISBN:1593270356

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and resources,sharing 191 printers with Samba.

X xargs,159

Table of Contents

xinetd, 129 How Linux Works—What Every Super-User Should Know Chapter 1 190–191 - The Basics xmkmf, Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

Index

How Linux Works: What Every Super-User Should Know

Y

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

yacc,177

by Brian Ward No Starch Press © 2004 (347 pages)

Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

ISBN:1593270356

Index

How Linux Works: What Every Super-User Should Know

Z

This guide describes the inner workings of a Linux system beginning with the file system and boot process and covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

.Z,27

by Brian Ward No Starch Press © 2004 (347 pages)

zcat,27

Table of Contents

zip, 27 Works—What Every Super-User Should Know How Linux Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

ISBN:1593270356

Linux Works: What Every Super-User Should Know List ofHow Figures by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) describes the inner workings of a Linux system beginning with the file system and boot process and ChapterThis 1:guide The Basics covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Figure 1-1: The pieces of a file mode Table of Contents

Chapter 4: Essential System Files, Servers, and Utilities - The Basics

How Linux Works—What Every Super-User Should Know Chapter 1 Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Figure 4-1:Linux An entry Chapter 3 - How Boots

in the password file.

Figure 4-2: An entry in the group file.

Chapter 6

- Network Services Figure 4-3: An entry in the crontab file.

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 5: Configuring Your - Compiling Software From Source Code Network

Chapter 9

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Devices Figure 5-1: A typical local area Peripheral network with an

Internet link.

Chapter 12 - Printing Chapter 13 - Backups Figure 5-2: A

typical PPP link.

Chapter 14 - Sharing Files with Samba

Figure 5-3: A File twisted-pair Chapter 15 - Network Transfer

Ethernet local area network.

Chapter 16 - User Environments

Figure 5-4: Two subnets joined with a router.

Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions

Figure 5-5: Three subnets.

Appendix A - Command Classification Bibliography

Chapter 10: Maintaining the Kernel

Index

List of Figures List of Figure Tables

10-1: The make menuconfig kernel configuration menu.

List of Sidebars

Chapter 13: Backups Figure 13-1: Files and file marks on a tape. Figure 13-2: The tape head at the beginning of a tape. Figure 13-3: The tape containing three archive files with the head at the start of a new file. Figure 13-4: The tape head at the end of file 0. Figure 13-5: The tape head at the beginning of file 1.

Chapter 17: Buying Hardware for Linux Figure 17-1: Costs of several processors. Figure 17-2: Performance value.

Linux Works: What Every Super-User Should Know List ofHow Tables by Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) describes the inner workings of a Linux system beginning with the file system and boot process and ChapterThis 1:guide The Basics covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Table 1-1: Special Characters Table of Contents

Table 1-2: Command-Line Keystrokes How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Table 1-3: Online Manual Sections

Chapter 3

Boots Table- How 1-4:Linux Absolute Permission Modes

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 2: Devices, Disks, Filesystems, and the Kernel - Network Services

Chapter 6 Chapter 7

- Introduction to Shell Scripts

Chapter 8 - Development Table 2-1: SampleTools Device Chapter 9

Assignments

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel

Chapter 4: Essential System Files, Servers, and Utilities

Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Table 4-1: Essential

Configuration Files

Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer

Chapter 5: Configuring Your Network

Chapter 16 - User Environments

Chapter 17 - Buying Hardware for Linux

Table 5-1: Subnet Masks Chapter 18 - Further Directions Appendix A - Command Classification

Table 5-2: Private Networks Defined by RFC 1918

Bibliography Index

Table 5-3:iptables Command Options

List of Figures List of Table Tables

5-4:iptables Packet Specification Options

List of Sidebars

Table 5-5:iwconfig Parameters

Chapter 6: Network Services Table 6-1: OpenSSH Key Files Table 6-2:netstat Options Table 6-3:tcpdump Primitives

Chapter 7: Introduction to Shell Scripts Table 7-1: File Type Operators Table 7-2: File Permissions Operators Table 7-3: Arithmetic Comparison Operators

Chapter 13: Backups Table 13-1: Block Sizes for Common Archiving Programs

Appendix A: Command Classification Table A-1: File Management Commands Table A-2: Text Processing and Scripting Commands Table A-3: Online Documentation Commands

Table A-4: Process and System Utility Commands Table A-5: System Information Commands How Linux Works: What Every Super-User Should Know by Brian Ward

ISBN:1593270356

Table A-6: Archival and Compression Commands No Starch Press © 2004 (347 pages) This guide describes the inner workings of a Linux system beginning with the file system and boot process and

Table A-7: Miscellaneous Utility Commands covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

Table A-8: Development Commands Table of Contents

Table A-9: Shells

How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

How Linux Works: What Every Super-User Should Know

List ofbySidebars Brian Ward

ISBN:1593270356

No Starch Press © 2004 (347 pages) guide describes the inner workings of a Linux system beginning with the file system and boot process and ChapterThis 10: Maintaining the Kernel covering advanced topics such as networking, firewalls, development tools, device management, shell scripts, and sharing printers with Samba.

When Should You Compile a Driver as a Module? Table of Contents How Linux Works—What Every Super-User Should Know Chapter 1

- The Basics

Chapter 2

- Devices, Disks, Filesystems, and the Kernel

Chapter 3

- How Linux Boots

Chapter 4

- Essential System Files, Servers, and Utilities

Chapter 5

- Configuring Your Network

Chapter 6

- Network Services

Chapter 7

- Introduction to Shell Scripts

Chapter 8

- Development Tools

Chapter 9

- Compiling Software From Source Code

Chapter 10 - Maintaining the Kernel Chapter 11 - Configuring and Manipulating Peripheral Devices Chapter 12 - Printing Chapter 13 - Backups Chapter 14 - Sharing Files with Samba Chapter 15 - Network File Transfer Chapter 16 - User Environments Chapter 17 - Buying Hardware for Linux Chapter 18 - Further Directions Appendix A - Command Classification Bibliography Index List of Figures List of Tables List of Sidebars

View more...

Comments

Copyright © 2017 PDFSECRET Inc.