This chapter looks at what happens during a Linux boot. It examines the processes that take place
and the configuration files that are read. Booting is a critical part of the operation of a server. The
boot process brings all of the network hardware online and starts all of the network daemon
processes when the system is powered−up. If the server will not boot, it is unavailable to all of the
users and computers that depend on it. For this reason, it is essential that the administrator of a
network server understand the boot process and the configuration files involved in that process.
After all, you're the person who maintains those configuration files and who is responsible for
recovering the system when it won't boot.
The termbootcomes frombootstrap loader, which in turn comes from the old saying "pull yourself
up by your bootstraps." The meaning of this expression is that you must accomplish everything on
your own without any outside help. This is an apt term for a system that must start from nothing and
finish running a full operating system. When the boot process starts, there is nothing in RAM—no
program to load the system. The loader that begins the process resides in non−volatile memory. On
PC systems, this means that the loader is part of the ROM BIOS.
Booting a Linux PC is a multistep procedure. It involves basic PC functions as well as Linux
processes. This complex process begins in the PC ROM BIOS; it starts with the ROM BIOS
program that loads the boot sector from the boot device. The boot sector either contains or loads a
Linux boot loader, which then loads the Linux kernel. Finally, the kernel starts the init process, which
loads all of the Linux services. The next few sections discuss this process in detail.
492 trang |
Chia sẻ: banmai | Lượt xem: 2543 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Linux network servers, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ct]
confTO_CONTROL Sets the maximum amount of time allowed for a control socket
transaction to complete. The default is two minutes (2m). [Timeout.control]
confTO_DATABLOCK Sets the maximum time to wait for a block during DATA
phase. Defaults to 1h. [Timeout.datablock]
confTO_DATAFINAL Sets the maximum time to wait for a response to the
terminating ".". Defaults to 1h. [Timeout.datafinal]
confTO_DATAINIT Sets the maximum time to wait for a DATA command response.
Defaults to 5m. [Timeout.datainit]
confTO_FILEOPEN Sets the maximum time to wait for a file open. Defaults to 60s.
[Timeout.fileopen]
confTO_HELO Sets the maximum time to wait for a HELO or EHLO response.
Defaults to 5m. [Timeout.helo]
confTO_HOSTSTATUS Sets the timer for stale host status information. Defaults to
30m. [Timeout.hoststatus]
confTO_ICONNECT Sets the maximum time to wait for the very first connect
attempt to a host. [Timeout.iconnect]
confTO_IDENT Sets the maximum time to wait for an IDENT query response.
Defaults to 30s. [Timeout.ident]
confTO_INITIAL Sets the maximum time to wait for the initial connect response.
Defaults to 5m. [Timeout.initial]
confTO_MAIL Sets the maximum time to wait for a MAIL command response.
Defaults to 10m. [Timeout.mail]
confTO_MISC Sets the maximum time to wait for other SMTP command responses.
Defaults to 2m. [Timeout.misc]
confTO_QUEUERETURN_NONURGENT Sets the "Undeliverable mail" timeout for
low−priority messages. [Timeout.queuereturn.non−urgent]
confTO_QUEUERETURN_NORMAL Sets the "Undeliverable mail" timeout for
normal−priority messages. [Timeout.queuereturn.normal]
confTO_QUEUERETURN_URGENT Sets the "Undeliverable mail" timeout for
459
urgent−priority messages. [Timeout.queuereturn.urgent]
confTO_QUEUERETURN Sets the time until a message is returned from the queue
as undeliverable. Defaults to 5d. [Timeout.queuereturn]
confTO_QUEUEWARN_NONURGENT Sets the time until a "still queued" warning
is sent for low−priority messages. [Timeout.queuewarn.non−urgent]
confTO_QUEUEWARN_NORMAL Sets the time until a "still queued" warning is
sent for normal priority messages. [Timeout.queuewarn.normal]
confTO_QUEUEWARN_URGENT Sets the time until a "still queued" warning is
sent for urgent priority messages. [Timeout.queuewarn.urgent]
confTO_QUEUEWARN Sets the time until a "still queued" warning is sent about a
message. Defaults to 4h. [Timeout.queuewarn]
confTO_QUIT Sets the maximum time to wait for a QUIT command response.
Defaults to 2m. [Timeout.quit]
confTO_RCPT Sets the maximum time to wait for a RCPT command response.
Defaults to 1h. [Timeout.rcpt]
confTO_RESOLVER_RETRANS Defines, in seconds, the retransmission timer for
all resolver lookups. [Timeout.resolver.retrans]
confTO_RESOLVER_RETRANS_FIRST Defines, in seconds, the retransmission
t imer for the resolver lookup for the f i rst at tempt to del iver a message.
[Timeout.resolver.retrans.first]
confTO_RESOLVER_RETRANS_NORMAL Def ines , in seconds, the
retransmission timer for all resolver lookups after the first attempt to deliver a
message. [Timeout.resolver.retrans.normal]
confTO_RESOLVER_RETRY Defines the total number of times to retry a resolver
query. [Timeout.resolver.retry]
confTO_RESOLVER_RETRY_FIRST Defines the number of times the resolver
query for the first delivery attempt is retried. [Timeout.resolver.retry.first]
confTO_RESOLVER_RETRY_NORMAL Defines the number of times to retry
resolver queries after the first delivery attempt. [Timeout.resolver.retry.normal]
confTO_RSET Sets the maximum time to wait for a RSET command response.
Defaults to 5m. [Timeout.rset]
confTRUSTED_USER Defines the user who controls the sendmail daemon, and
owns the f i l es c rea ted by sendmai l . Do no t con fuse th i s op t ion w i th
confTRUSTED_USERS. [TrustedUser]
confTRUSTED_USERS Defines trusted usernames to add to root, uucp, and
daemon.
460
confTRY_NULL_MX_LIST Connects to the remote host directly if the MX points to
the local host and it is set to True. Defaults to False. [TryNullMXList]
confUNSAFE_GROUP_WRITES Doesn't reference programs or files from
group−wr i tab le : inc lude: and . forward f i les i f True. Defau l ts to Fa lse.
[UnsafeGroupWrites]
c o n f U S E R D B _ S P E C D e f i n e s t h e p a t h o f t h e u s e r d a t a b a s e f i l e .
[UserDatabaseSpec]
confUSE_ERRORS_TO Delivers errors using the Errors−To: header if True.
Defaults to False. [UserErrorsTo]
confUUCP_MAILER Defines the default UUCP mailer. Defaults to uucp−old.
confWORK_CLASS_FACTOR Defines the factor used to favor high−priority jobs.
Defaults to 1800. [ClassFactor]
confWORK_RECIPIENT_FACTOR Defines the factor used to lower the priority of a
job for each additional recipient. Defaults to 30000. [RecipientFactor]
confWORK_TIME_FACTOR Defines the factor used to lower the priority of a job for
each delivery attempt. Defaults to 90000. [RetryFactor]
define macros are the most common macros in the m4 source files. The next most commonly used
macro is the FEATURE macro.
FEATURE
The FEATURE macro processes m4 source code from the feature directory. Source files in that
directory define optional sendmail features. The syntax of the FEATURE macro is
FEATURE(name, [argument])
The argument is optional. If an argument is passed to the source file, it is used by the source file to
generate code for the sendmail.cf file. For example, the following generates the code for accessing
the mailertable, and defines that table as being a dbm database located in the file /usr/
lib/mailertable:
FEATURE(mailertable, dbm /usr/lib/mailertable)
The available features and their purposes are listed in Table C.2.
Table C.2: Optional sendmail Features
Name Purpose
accept_unqualified_senders Allows network mail from addresses that do not include
a valid hostname.
accept_unresolvable_domains Accepts mail from hosts that are unknown to DNS.
access_db Enables the use of the access database.
461
allmasquerade Also masquerades recipient addresses.
always_add_domain Adds the local hostname to all locally delivered mail.
bestmx_is_local Accepts mail addressed to a host that lists the local
system as its MX server as local.
bitdomain Uses a table to map Bitnet hosts to Internet addresses.
blacklist_recipients Filters incoming mail based on values set in the access
database.
delay_checks Delay the check_mail and check_relay rulesets until
check_rcpt is called.
dnsbl Reject mail from hosts listed in a DNS−based rejection
list. Replaces rbl.
domaintable Uses a domain table for domain name mapping.
generics_entire_domain Map domain names identified in class G through the
genericstable.
genericstable Uses a table to rewrite local addresses.
ldap_routing Enable LDAP−based e−mail routing.
limited_masquerade Only masquerade hosts listed in $=M.
local_lmtp Uses mail.local with LMTP support.
local_procmail Uses procmail as the local mailer.
loose_relay_check Disables validity checks for addresses that use the %
hack.
mailertable Routes mail using a mailer table.
masquerade_entire_domain Masquerades all hosts within the masquerading
domains.
masquerade_envelope Masquerades the envelope sender address in addition
to the header sender address.
no_default_msa Allows the default configuration of the Message
Submission Agent to be overridden by the
DAEMON_OPTIONS macro.
nocanonify Doesn't convert names with $[ ... $] syntax.
nodns Doesn't include DNS support.
nouucp Doesn't include UUCP address processing.
nullclient Forwards all mail to a central server.
Name Purpose
promiscuous_relay Relays mail from any site to any site.
rbl Enables use of the Realtime Blackhole List server.
Replaced by dnsbl.
redirect Supports the .REDIRECT pseudo−domain.
relay_based_on_MX Relays mail for any site whose MX points to this server.
relay_entire_domain Relays mail for any host in your domain.
relay_host_only Relays mail only for hosts listed in the access database.
relay_local_from Relays mail if the source is a local host.
relay_mail_from Relays mail if the sender is listed as RELAY in the
access database.
smrsh Uses smrsh as the prog mailer.
462
stickyhost Treats user differently from user@local.host.
use_ct_file Loads $=t from the file defined by confCT_FILE.
use_cw_file Loads $=w from the file defined by confCW_FILE.
uucpdomain Uses a table to map UUCP hosts to Internet addresses.
virtuser_entire_domain Maps entire domain names through the virtusertable.
virtusertable Maps virtual domain names to real mail addresses.
The use_cw_file and the use_ct_file features are equivalent to Fw/etc/mail/local−host−names and
Ft/etc/mail/trusted−users commands in the sendmail.cf file. See Chapter 5 for descriptions of host
aliases ($=w) and trusted users ($=t). The redirect feature is also covered in Chapter 5.
Several FEATURE macros remove unneeded lines from the sendmail.cf file. nouucp removes the
code that handles UUCP addresses for systems that do not have access to UUCP networks, and
nodns removes the code for DNS lookups for systems that do not have access to DNS, or do not
want to use DNS. nocanonify disables the code that converts nicknames and IP addresses into
hostnames. Finally, the nullclient feature strips everything out of the configuration, except for the
capability to forward mail to a single mail server via a local SMTP link. The name of that mail server
is provided as the argument on the nullclient command line, for example, FEATURE(nullclient,
big.isp.net) forwards all mail to big.isp.net without any local mail processing.
Several features relate to mail relaying and masquerading. They are stickyhost, allmasquerade,
limited_masquerade, and masquerade_entire_domain. All of these features are covered in the
DOMAIN section later in this appendix.
Several of the features define databases that are used to perform special address processing. All of
these features accept an optional argument that defines the database. (See the sample mailertable
command at the beginning of this section for an example of defining the database with the optional
argument.) If the optional argument is not provided, the database description always defaults to
hash −o /etc/filename, where filename matches the name of the feature. For example, mailertable
defaults to the definition hash −o /etc/mailertable. The database features are as follows:
access_db Controls mail−relaying and delivery. The access file contains two fields:
an e−mail address, which is the key, and an action taken for mail containing that
address. The access database is covered in Chapter 11, "More Mail Services."
mailertable Maps host and domain names to specific mailer:host pairs. The mailer,
host, user triple is returned by ruleset parse based on the delivery address. The
mailertable file allows you to define the mailer and the host of the delivery triple
based on the domain name in the delivery address. If the host or domain name in the
delivery addresses matches a key field in the mailertable database, it returns the
mailer and host for that address. The format of a mailertable entry is
domain−name mailer:host
where domain−name is either a full hostname (host plus domain) or a domain name.
If a domain name is used, it must start with a dot (.), and it will match every host in
the specified domain. mailer is the internal sendmail.cf mailer name of the mailer that
handles mail for the specified domain, and host is the hostname of the mailer server
that handles mail for that domain.
domaintable Converts an old domain name to a new domain name. The old name
463
is the key, and the new name is the value returned for the key.
bitdomain Converts a Bitnet hostname to an Internet hostname. The Bitnet name is
the key, and the Internet hostname is the value returned. The bitdomain program that
comes with the sendmail distribution can be used to build this database. Bitnet is
obsolete.
uucpdomain Converts a UUCP name to an Internet hostname. The key is the
UUCP hostname, and the value returned is the Internet hostname. This is useful only
if you still have users who address e−mail using old UUCP addresses.
genericstable Converts a sender e−mail address. The key to the database is either
a username or a full e−mail address (username and hostname). The value returned
by the database is the new e−mail address. (See Chapter 5 for an example of using
the genericstable.) If you use the genericstable and you don't use masquerading, use
generics_domain and generics_ domain_file to get the same functions normally
provided by masquerade_domain and masquerade_domain_file.
virtusertable Aliases incoming e−mail addresses. Essentially, this is an extended
alias database for aliasing addresses that are not local to this host. The key to the
database is a full e−mail address or a domain name. The value returned by the
database is the recipient address to which the mail is delivered. If a domain name is
used as a key, it must begin with an at sign (@). Mail addressed to any user in the
specified domain is sent to the recipient defined by the virtusertable database. Any
hostname used as a key in the virtusertable database must also be defined in class
w.
Some features are important in the fight against spam because they help control the mail a server
d e l i v e r s o r f o r w a r d s o n f o r d e l i v e r y . T h e s e a r e a c c e p t _ u n q u a l i f i e d _ s e n d e r s ,
accept_unresolvable_domains, access_db, blacklist_recipients, and dnsbl. All of these are covered
in the section on controlling spam in Chapter 11.
Two of the remaining FEATURE commands relate to domains. The always_add_domain macro
makes sendmail add the local domain name to all locally delivered mail, even to those pieces of
mail that would normally have just a username as an address. The bestmx_is_local feature accepts
mail addressed to a host that lists the local host as its preferred MX server as if the mail were local
mail. If this feature is not used, mail bound for a remote host is sent directly to the remote host even
if its MX record lists the local host as its preferred MX server. The bestmx_is_local feature should
not be used if you use a wildcard MX record for your domain.
The last two features are used to select optional programs for the local and the prog mailers. local_
procmail selects procmail as the local mailer. Provide the path to procmail as the argument in the
FEATURE command. The smrsh feature selects the SendMail Restricted SHell (smrsh) as the prog
mailer. smrsh provides improved security over /bin/sh, which is often used as the prog mailer.
Provide the path to smrsh as the argument in the FEATURE command.
The FEATURE commands discussed in this section and the define macros discussed previously
are used to build the m4 source files. The next few sections of this appendix describe the purpose
and structure of the OSTYPE, DOMAIN, and MAILER source files.
464
OSTYPE
OSTYPE points to the m4 source file that contains the operating system specific information for this
configuration. This required file is examined in detail in Chapter 5.
Although all m4 macros can be used in OSTYPE source files, Table C.3 lists the define parameters
most frequently associated with the OSTYPE file and the function of each parameter. If the
parameter has a default value, it is shown enclosed in square brackets after the parameter's
functional description.
Table C.3: OSTYPE defines
Parameter Function
ALIAS_FILE Name of the alias file. [/etc/aliases]
CYRUS_BB_MAILER_ARGS cyrusbb mailer arguments. [deliver
−e −m $u]
CYRUS_BB_MAILER_FLAGS Flags added to lsDFMnP for the cyrusbb mailer.
CYRUS_MAILER_ARGS cyrus mailer arguments. [deliver −e −m $h −− $u]
CYRUS_MAILER_FLAGS Flags added to lsDFMnP for the cyrus mailer.
[A5@]
CYRUS_MAILER_MAX Maximum size message for the cyrus mailer.
CYRUS_MAILER_PATH Path to the cyrus mailer. [/usr/cyrus/bin/ deliver]
CYRUS_MAILER_USER User and group used to the cyrus mailer.
[cyrus:mail]
DSMTP_MAILER_ARGS dsmtp mailer arguments. [IPC $h]
ESMTP_MAILER_ARGS esmtp mailer arguments. [IPC $h]
FAX_MAILER_ARGS FAX mailer arguments. [mailfax $u
$h $f]
FAX_MAILER_MAX Maximum size of a FAX. [100000]
FAX_MAILER_PATH Path to the FAX program. [/usr/local/lib/fax/
mailfax]
HELP_FILE Name of the help file. [/usr/lib/sendmail.hf]
LOCAL_MAILER_ARGS Arguments for local mail delivery. [mail
−d $u]
LOCAL_MAILER_CHARSET Character set for local 8−bit MIME mail.
LOCAL_MAILER_DSN_DIAGNOSTIC_ CODE The delivery status notification code used for local
mail. [X−Unix]
LOCAL_MAILER_EOL The end−of−line character for local mail.
LOCAL_MAILER_FLAGS Local mailer flags added to lsDFM. [rmn]
LOCAL_MAILER_MAX Maximum size of local mail.
LOCAL_MAILER_MAXMSG The maximum number of messages delivered with
a single connection.
LOCAL_MAILER_PATH The local mail delivery program. [/bin/mail]
LOCAL_SHELL_ARGS Arguments for the prog mail. [sh −c $u]
LOCAL_SHELL_DIR Directory that the shell should run. [$z:/]
LOCAL_SHELL_FLAGS Flags added to lsDFM for the shell mailer. [eu]
465
LOCAL_SHELL_PATH Shell used to deliver piped e−mail. [/bin/sh]
MAIL11_MAILER_ARGS mail11 mailer arguments. [mail11 $g $x $h $u]
MAIL11_MAILER_FLAGS Flags for the mail11 mailer. [nsFx]
Parameter Function
MAIL11_MAILER_PATH Path to the mail11 mailer. [/usr/etc/mail11]
PH_MAILER_ARGS phquery mailer arguments.
[phquery −− $u]
PH_MAILER_FLAGS Flags for the phquery mailer. [ehmu]
PH_MAILER_PATH Path to the phquery program. [/usr/local/etc/
phquery]
POP_MAILER_ARGS POP mailer arguments. [pop $u]
POP_MAILER_FLAGS Flags added to lsDFM for the POP mailer. [Penu]
POP_MAILER_PATH Path of the POP mailer. [/usr/lib/
mh/spop]
PROCMAIL_MAILER_ARGS procmail mailer arguments. [procmail −m $h $f $u]
PROCMAIL_MAILER_FLAGS Flags added to DFMmn for the procmail mailer.
[Shu]
PROCMAIL_MAILER_MAX Maximum size message for the procmail mailer.
PROCMAIL_MAILER_PATH Path to the procmail program. [/usr/local/bin/
procmail]
QPAGE_MAILER_ARGS qpage mailer arguments. [qpage −10
−m −P$u]
QPAGE_MAILER_FLAGS Flags for the qpage mailer. [mDFMs]
QPAGE_MAILER_MAX Maximum qpage mailer message size. [4096]
QPAGE_MAILER_PATH Path of the qpage mailer. [/usr/local/bin/qpage]
QUEUE_DIR Directory containing queue files. [/var/spool/
mqueue]
RELAY_MAILER_ARGS relay mailer arguments. [IPC $h]
RELAY_MAILER_FLAGS Flags added to mDFMuX for the relay mailer.
RELAY_MAIL_MAXMSG The maximum number of messages for the relay
mailer delivered by a single connection.
SMTP8_MAILER_ARGS smtp8 mailer arguments. [IPC $h]
SMTP_MAILER_ARGS smtp mailer arguments. [IPC $h]
SMTP_MAILER_CHARSET Character set for SMTP 8−bit MIME mail.
SMTP_MAILER_FLAGS Flags added to mDFMUX for all smtp mailers.
SMTP_MAILER_MAX Maximum size of messages for all smtp mailers.
SMTP_MAIL_MAXMSG The maximum number of smtp messages delivered
by a single connection.
STATUS_FILE Name of the status file. [/etc/sendmail.st]
USENET_MAILER_ARGS Arguments for the usenet mailer. [−m −h −n]
USENET_MAILER_FLAGS usenet mailer flags. [rlsDFMmn]
USENET_MAILER_MAX Maximum size of usenet mail messages. [100000]
USENET_MAILER_PATH Program used for news. [/usr/lib/
news/inews]
UUCP_MAILER_ARGS
466
UUCP mailer arguments. [uux − −r −z −a$g −gC
$h!rmail ($u)]
UUCP_MAILER_CHARSET Character set for UUCP 8−bit MIME mail.
UUCP_MAILER_FLAGS Flags added to DFMhuU for the UUCP mailer.
UUCP_MAILER_MAX Maximum size for UUCP messages. [100000]
UUCP_MAILER_PATH Path to the UUCP mail program. [/usr/bin/uux]
DOMAIN
The DOMAIN macro identifies the m4 source file that contains configuration information specific to
the local domain. Chapter 5 provides a detailed example of creating a domain source file and then
calling that file with the DOMAIN macro.
Table C.4 lists the define macros that commonly appear in DOMAIN source files. All of these define
mail relay hosts. The value provided for each parameter is either a hostname (that is, the name of a
mail relay server); or a mailer:hostname pair, where mailer is an internal mailer name and hostname
is the name of the mail relay server. If only a hostname is used, the mailer defaults to relay, which is
the name of the SMTP relay mailer.
Table C.4: Mail Relay defines
Parameter Function
UUCP_RELAY Server for UUCP−addressed e−mail.
BITNET_RELAY Server for BITNET−addressed e−mail.
DECNET_RELAY Server for DECNET−addressed e−mail.
FAX_RELAY Server for mail to the .FAX pseudo−domain. The fax mailer overrides this
value.
LOCAL_RELAY Server for unqualified names. This is obsolete.
LUSER_RELAY Server for local names that really aren't local.
MAIL_HUB Server for all incoming mail.
SMART_HOST Server for all outgoing mail.
The precedence of the relays defined by these parameters is from the most specific to the least
specific. If both the UUCP_RELAY and the SMART_HOST relay are defined, the UUCP_ RELAY is
used for outgoing UUCP mail, even though the SMART_HOST relay is defined as handling "all"
outgoing mail. If you define both LOCAL_RELAY and MAIL_HUB, use the FEATURE(stickyhost)
command. When the stickyhost feature is specified, LOCAL_RELAY handles all local addresses
that do not have a host part, and MAIL_HUB handles all local addresses that do have a host part. If
stickyhost is not specified, and both relays are defined, the LOCAL_RELAY is ignored, and
MAIL_HUB handles all local addresses.
In addition to the defines shown in Table C.3, macros that relate to masquerading and relaying also
appear in the DOMAIN source file. The macros are as follows:
EXPOSED_USER(username) Disables masquerading when the user portion of the
sender address matches username. Some usernames, such as root, occur on many
systems, and therefore are not unique across a domain. For those usernames,
converting the host portion of the address makes it impossible to sort out where the
467
message really came from, and makes replies impossible. This command prevents
the MASQUERADE_AS macro from having an effect on the sender addresses for
specific users. This is the same as setting the values in class E in the sendmail.cf
file.
LOCAL_USER(usernames) Defines local usernames that should not be relayed,
even if LOCAL_RELAY or MAIL_HUB are defined. This command is the same as
adding usernames to class L in the sendmail.cf file.
MASQUERADE_AS(host.domain) Converts the host portion of the sender address
on outgoing mail to the specified domain name. Sender addresses that have no
hostname or that have a hostname found in the w class are converted. This has the
same e f fec t as the M macro in the sendmai l .c f f i le . See examples o f
MASQUERADE_AS and macro M in Chapter 5.
MASQUERADE_DOMAIN(otherhost.domain) Converts the host portion of the
sender address on outgo ing mai l to the domain name def ined by the
MASQUERADE_AS command if the host portion of the sender address matches the
va lue de f ined here . Th is command must be used in con junc t ion w i th
MASQUERADE_AS. Its effect is the same as adding hostnames to class M in the
sendmail.cf file. See Chapter 5.
MASQUERADE_DOMAIN_FILE(filename) Loads class M hostnames from the
specified file. This can be used in place of multiple MASQUERADE_DOMAIN
commands. Its effect is the same as using the FMfilename command in the
sendmail.cf file.
MASQUERADE_EXCEPTION(host.domain) This macro defines a host that is not
masqueraded, even if it belongs to a domain that is being masqueraded. This allows
you to masquerade an entire domain with the MASQUERADE_DOMAIN macro and
then exempt a few hosts that should be exposed to the outside world.
RELAY_DOMAIN(otherhost.domain) This macro identifies a host for which mail
should be relayed. The host identified in this manner is added to class R.
RELAY_DOMAIN_FILE(filename) This macro identifies a file that contains a list of
hosts for which mail should be relayed. This macro loads class R from the specified
file.
There are also several features that affect relaying and masquerading. One, FEATURE (stickyhost),
was already discussed. Others are the following:
FEATURE(masquerade_envelope) Causes envelope addresses to be
masqueraded in the same way that sender addresses are masqueraded. See
Chapter 5 for an example of this command.
FEATURE(allmasquerade) Causes recipient addresses to be masqueraded in the
same way that sender addresses are masqueraded. Thus, if the host portion of the
recipient address matches the requirements of the MASQUERADE_AS command, it
is converted. Don't use this feature unless you are positive that every alias known to
the local system is also known to the mail server that handles mail for the
masquerade domain.
468
FEATURE(limited_masquerade) Limits masquerading to those hosts defined in
class M. The hosts defined in class w are not masqueraded.
FEATURE(masquerade_entire_domain) Causes MASQUERADE_DOMAIN to be
interpreted as referring to all hosts within an entire domain. If this feature is not used,
only an address that exactly matches the value defined by MASQUERADE_DOMAIN
is converted. If this feature is used, then all addresses that end with the value defined
by MASQUERADE_DOMAIN are converted. For example, assume that
M A S Q U E R A D E _ A S ( f o o b i r d s . o r g ) a n d
M A S Q U E R A D E _ D O M A I N ( s w a n s . f o o b i r d s . o r g ) a r e d e f i n e d . I f
FEATURE(masquerade_ ent i re_domain) is set , every hostname in the
swans.foobirds.org domain is converted to foobirds.org on outgoing e−mail.
Otherwise, only a host named swans.foobirds.org is converted.
Some features define how the server handles mail if it is the mail relay server. These features,
which are also described in Chapter 11, are the following:
access_db Maps a user, a domain name, or an IP address to a keyword that tells
sendmail how to handle relaying for the host, domain, or network. This database is
used in Chapter 11.
blacklist_recipient Uses the access database to control delivery of mail based on
the recipient address. The basic access_db feature controls relaying and delivery
based on the source of the message. This feature adds to the capability to control
mail relaying and delivery based on the destination.
dnsbl Controls mail delivery based on a DNS blacklist. Source addresses and
destination addresses listed in the DNS database may be denied mail delivery or
relay services.
promiscuous_relay Relays from any site to any site. Normally, sendmail does not
relay mail. Using this feature is a bad idea because it makes you a possible relay
server for spammers.
relay_entire_domain Relays from any domain defined in class M to any site.
relay_hosts_only Relays mail from any host defined in the access database or
class R.
relay_based_on_MX Relays mail from any site for which your system is the MX
server.
relay_local_from Relays mail with a sender address that contains your local
domain name.
The DOMAIN source file is also used for features and macros that directly relate to DNS. These
features and macros include the following:
FEATURE(accept_unqualified_senders) Accepts mail from the network even if the
sender address does not include a hostname. Normally, only mail from a user
directly logged on to the system is accepted without a hostname. This is a dangerous
feature that should be used only on an isolated network.
469
FEATURE(accept_unresolvable_domains) Accepts mail from hostnames that
cannot be resolved by DNS. This is a dangerous feature that is used only on systems
that lack full−time DNS service, such as mobile laptops.
FEATURE(always_add_domain) Adds the hostname of the system to all local mail.
With this feature enabled on a server named ibis.foobirds.org, mail from the local
use r c ra i g t o t he l oca l use r ka thy wou ld be de l i ve red as ma i l f r om
craig@ibis.foobirds.org to kathy@ibis.foobirds.org.
FEATURE(bestmx_is_local) Accepts mail addressed to any host that lists the
sendmail server as its MX server as local mail.
CANONIFY_DOMAIN(domain) Defines a domain name that will be passed to DNS
for conversion to its canonical form, even if the nocanonify feature is in use. This
macro is generally used to enable canonification of the local domain when
nocanonify is in use.
CANONIFY_DOMAIN_FILE(filename) Identifies a file containing a list of domain
names that should be converted to canonical form, even if nocanonify has been
selected.
LOCAL_DOMAIN(alias−hostname) Defines an alias for the local host. Mail
addressed to the alias will be accepted as if it were addressed directly to the local
host.
The macros and features described in this section are not limited to the DOMAIN source file. They
can appear in any m4 source file, and, in fact, are often found in the macro control file. They are
listed here because they are most naturally associated with the DOMAIN file.
MAILER
The MAILER command identifies an m4 source file that contains the configuration commands that
define a sendmail mailer. A least one MAILER command must appear in the configuration file.
Generally more than one MAILER command is used.
It is possible that you will need to customize a file location in an OSTYPE file, or that you will need
to define domain−specific information in a DOMAIN file. Unless you develop your own mail−delivery
program, however, you will not need to create a MAILER source file. Instead, you will need to
invoke one or more existing files in your macro configur−ation file.
Table C.5 lists each MAILER name and its function. These are invoked using the MAILER(name)
command in the macro configuration (.mc) file.
Table C.5: MAILER Values
Name Function
local The local and prog mailers.
smtp All SMTP mailers: smtp, esmtp, smtp8, dsmtp, and relay.
uucp All UUCP mailers: uucp−old (uucp) and uucp−new (suucp).
usenet Usenet news support.
470
fax FAX support using FlexFAX software.
pop Post Office Protocol (POP) support.
procmail An interface for procmail.
mail11 The DECnet mail11 mailer.
phquery The phquery program for CSO phone book.
qpage The QuickPage mailer used to send e−mail to a pager.
cyrus The cyrus and cyrusbb mailers.
Your macro configuration file should have a MAILER(local) and a MAILER(smtp) entry. Selecting
local and smtp provides everything you need for a standard TCP/IP installation. None of the
remaining mailers is widely used. The other mailers are the following:
uucp Provides UUCP mail support for systems directly connected to UUCP
networks. The uucp−old mailer supports standard UUCP mail, and the uucp−new
mailer is used for remote sites that can handle multiple recipients in one transfer.
Specify MAILER(uucp) after the MAILER(smtp) entry if your system has both TCP/IP
and UUCP connections.
usenet Sends local mail that contains .usenet in the recipient name to the program
inews. Use a user mail agent that supports Usenet news. Don't hack sendmail to
handle it.
fax Experimental support for HylaFAX.
pop On Linux systems, POP support is provided by the popd, so the MAILER(pop)
command is not used.
procmail Provides a procmail interface for the mailertable.
mail11 Used only on DECNET mail networks that use the mail11 mailer.
phquery Provides CSO phone book (ph) directory service.
qpage This mailer provides an interface from e−mail to pagers using the QuickPage
program.
cyrus Provides a local mail delivery program that uses a mailbox architecture. cyrus
and cyrusbb mailers are not widely used.
Local Code
There are several m4 macros that allow you to directly modify the sendmail.cf file with unadulterated
sendmail.cf configuration commands. These macros are placed at the beginning of a block of
sendmail.cf code, and they tell m4 where to put that code in the output file. These macros are as
follows:
LOCAL_RULE LOCAL_RULE_n heads a section of code to be added to ruleset n,
where n is 0, 1, 2, or 3. The code that follows the LOCAL_RULE command is
sendmail.cf rewrite rules.
471
LOCAL_CONFIG LOCAL_CONFIG heads a section of code to be added to the
sendmail.cf file after the local information section and before the rewrite rules. The
section of code contains standard sendmail.cf configuration commands.
LOCAL_RULESETS This macro heads a section of code that contains a complete
ruleset that is to be added to the sendmail.cf file. Generally, these are named as
opposed to numbered rulesets.
LOCAL_NET_CONFIG This macro heads a section of sendmail.cf rewrite rules that
defines how mail addressed to systems on the local network is handled.
MAILER_DEFINITIONS This macro is placed before a sendmail.cf M command,
which is a mailer definition.
DAEMON_OPTIONS
The DAEMON_OPTIONS macro defines parameters for the sendmail daemon. When sendmail
accepts mail from a local e−mail program, it is acting as a Mail Submission Agent (MSA). When it
transfers that mail to a remote server, it is acting as a Mail Transfer Agent (MTA). The
DAEMON_OPTIONS macro sets options for both of sendmail's "personalities."
Two DAEMON_OPTIONS commands are needed to set the parameters for both the MTA and the
MSA. The sendmail configuration defaults to the following values:
DAEMON_OPTIONS(`Port=25, Name=MTA')
DAEMON_OPTIONS(`Port=587, Name=MSA, M=E')
These two lines assign the standard ports to the MTA and the MSA, and a modifier to the MSA. Use
the no_default_msa feature to clear the MSA defaults before you set new MSA values with the
DAEMON_OPTIONS macro. And then use two DAEMON_OPTIONS commands: the first one for
the MTA and the second one for the MSA.
DAEMON_OPTIONS parameters are assigned using keyword=value pairs. The possible keywords
and values are:
Port The Port keyword assigns a network port number to the daemon. The standard
port for an MTA is 25, and the standard port for an MSA is 587. Changing these
standard ports means that clients will have difficulty locating the service. The port
numbers are therefore rarely changed.
Name The Name keyword identifies the aspect of the sendmail daemon for which
the parameters are being set. There are four documented values:
MTA This identifies the traditional Mail Transport Agent interface of
sendmail that is used to deliver mail.
MSA This identifies the Mail Submission Agent interface of sendmail
that can be used by external MUAs to submit mail. In practice, this
function is identical to the MTA function, except for port number,
because both aspects of sendmail ensure that all mail, no matter how
it arrives, is processed through all necessary rulesets, filters, and
472
databases.
MTA−v4 This is the same as the MTA interface, and is designed to
handle e−mail delivery to hosts with standard 32−bit IPv4 addresses.
MTA−v6 MTA−v6 is an interface designed to handle delivery to hosts
that use the 128−bit IPv6 addresses.
Family The Family keyword defines the address family. By default, this is inet, which
means that standard IPv4 addresses should be used. An alternate value is inet6,
which requests IPv6 addressing.
M The M keyword is a modifier that requests optional processing. M=E turns off the
ESMTP ETRN command. This setting is the default for the MSA because it is
required by the MSA standard. The M=a setting requires authentication by a trusted
authentication method before the MSA will accept the mail message.
LDAP Mail Routing
In addition to the various databases built into sendmail, a Lightweight Directory Access Protocol
(LDAP) server can be used with sendmail. If your site uses LDAP for other purposes, you may find
some benefit in using it with sendmail. LDAP support is added to sendmail using the following
defines, features, and macros:
define(`confLDAP_DEFAULT_SPEC', `ldap−arguments') Sets arguments that are
required for the LDAP map definition. At a minimum, the name of the LDAP server
(−h server) and the base distinctive name (−b o=org,c=country) must be provided.
For example:
define(`confLDAP_DEFAULT_SPEC', `−h egret.foobirds.org −b o=foobirds.org,c=us')
FEATURE(`ldap_routing') Adds the necessary support for LDAP routing to the
configuration.
LDAPROUTE_DOMAIN(domainname) Adds a domain to the class {LDAPRoute}.
Mail routing information for domains in that class is looked up via the LDAP server.
LDAPROUTE_DOMAIN_FILE(filename) Identifies the file from which the
{LDAPRoute} class is loaded. The file contains a list of the domains for which mail
routing information should be obtained from the LDAP server.
This concludes the discussion of m4 macros. The output of all of the files and commands that go
into the m4 processor is a sendmail.cf file. The bulk of information about sendmail configuration is
found in Chapter 5.
473
List of Figures
Chapter 1: The Boot Process
Figure 1.1: The boot process flow
Figure 1.2: The SYSV Runlevel Manager Window
Chapter 2: The Network Interface
Figure 2.1: Red Hat's Network Configuration tool
Figure 2.2: The RS−232 hardware handshake
Figure 2.3: kudzu installing a modem driver
Figure 2.4: The Internet Connections window
Chapter 3: Login Services
Figure 3.1: The anonymous FTP RPM
Chapter 4: Linux Name Services
Figure 4.1: A caching−only DNS server RPM
Chapter 5: Configuring a Mail Server
Figure 5.1: sendmail rulesets
Figure 5.2: Contents of the sendmail−cf RPM
Chapter 6: The Apache Web Server
Figure 6.1: Linux binaries at the Apache website
Figure 6.2: Enabling Apache with tksysv
Figure 6.3: Apache installation web page
Figure 6.4: A fancy index for /usr/share/doc
Figure 6.5: An invalid certificate warning
Figure 6.6: The CAs built−in Netscape 6.1
Figure 6.7: The Apache server−status display
Chapter 7: Network Gateway Services
Figure 7.1: Circuit switching versus packet switching
Figure 7.2: Routing through networks
Figure 7.3: Contents of the Zebra RPM
Figure 7.4: Installing gated with gnorpm
Chapter 9: File Sharing
Figure 9.1: The Red Hat NFS RPM
Figure 9.2: The Red Hat Samba RPM
Chapter 10: Printer Services
Figure 10.1: Selecting a print queue type
474
Figure 10.2: The active local printer port
Figure 10.3: Selecting a printer driver
Figure 10.4: Editing a printer configuration
Figure 10.5: Configuring a remote SMB printer
Figure 10.6: Configuring a remote Unix printer
Chapter 11: More Mail Services
Figure 11.1: RPM query of the IMAP package
Figure 11.2: Configuring the mail client
Figure 11.3: Defining Netscape filter rules
Chapter 12: Security
Figure 12.1: Searching the Bugtraq Archives
Figure 12.2: Linux exploits found at
Figure 12.3: Locating software updates from a vulnerability report
Figure 12.4: Red Hat provides security reports online.
Figure 12.5: The OpenSSH RPM
Chapter 13: Troubleshooting
Figure 13.1: The Kernel Configuration window
Figure 13.2: Network device support configuration options
Figure 13.3: Selecting processor types and features
Appendix A: Installing Linux
Figure A.1: Disk Druid's main screen
Figure A.2: Adding a partition in Disk Druid
Figure A.3: Red Hat firewall configuration
Figure A.4: The Authentication Configuration screen
Figure A.5: Final X configuration window
475
List of Tables
Chapter 1: The Boot Process
Table 1.1: Valid Action Values
Chapter 2: The Network Interface
Table 2.1: Escape Sequences and Their Meanings
Chapter 4: Linux Name Services
Table 4.1: named.conf Configuration Statements
Table 4.2: DNS Database Record Types
Table 4.3: rndc Commands
Table 4.4: Databases Controlled by nsswitch.conf
Chapter 5: Configuring a Mail Server
Table 5.1: Pattern Matching Symbols
Table 5.2: Rewrite Template Symbols
Chapter 6: The Apache Web Server
Table 6.1: DSO Modules Loaded in the Red Hat Configuration
Table 6.2: Server Side Includes Commands
Chapter 7: Network Gateway Services
Table 7.1: Default gated Preference Values
Chapter 8: Desktop Configuration Servers
Table 8.1: pump Command−Line Options
Chapter 9: File Sharing
Table 9.1: Linux mount Command Options
Table 9.2: More mount Options
Table 9.3: smb.conf Variables
Chapter 10: Printer Services
Table 10.1: lpc Commands
Chapter 11: More Mail Services
Table 11.1: POP3 Commands
Table 11.2: IMAP4 Commands
Table 11.3: Access Database Actions
Table 11.4: procmail Recipe Flags
476
Chapter 12: Security
Table 12.1: Wrapper Variables
Table 12.2: ssh Client Configuration Options
Chapter 13: Troubleshooting
Table 13.1: TCP Protocol States
Table 13.2: tcpdump Packet Filters
Appendix A: Installing Linux
Table A.1: Common Partitions
Table A.2: Single−Character fdisk Commands
Appendix B: BIND Reference
Table B.1: BIND 8 Configuration Options
Table B.2: New BIND 9 Options
Table B.3: BIND 8 Logging Categories
Appendix C: The m4 Macros for sendmail
Table C.1: The sendmail m4 Macros
Table C.2: Optional sendmail Features
Table C.3: OSTYPE defines
Table C.4: Mail Relay defines
Table C.5: MAILER Values
477
List of Listings
Chapter 1: The Boot Process
Listing 1.1: The Default GRUB Configuration
Listing 1.2: A Sample lilo.conf File
Listing 1.3: Adding Password Protection to LILO
Listing 1.4: The inittab File
Listing 1.5: Runlevel Initialization Scripts
Listing 1.6: The init.d Script Files
Listing 1.7: Listing Loaded Modules
Chapter 2: The Network Interface
Listing 2.1: Loadable Network Device Drivers
Listing 2.2: An Ethernet Card Configuration Created by kudzu
Listing 2.3: A Sample pap−secrets File
Listing 2.4: A Sample chap−secrets File
Listing 2.5: A Sample chat Script
Chapter 3: Login Services
Listing 3.1: An Excerpt of the /etc/protocols File
Listing 3.2: An Excerpt from /etc/services
Listing 3.3: Excerpts from an inetd.conf File
Listing 3.4: Services Disabled by inetd
Listing 3.5: The xinetd.conf File
Listing 3.6: The /etc/xinetd.d/wu−ftpd File
Listing 3.7: Using chkconfig to Control xinetd
Listing 3.8: A Sample /etc/passwd File
Listing 3.9: Available Login Shells
Listing 3.10: Examples from the /etc/group File
Listing 3.11: The Effect of the useradd Command
Listing 3.12: Using the usermod Command
Listing 3.13: Contents of the /etc/default/useradd File
Listing 3.14: Contents of the /etc/login.defs File
Listing 3.15: The userdel Command
Listing 3.16: Excerpts of the Red Hat ftpaccess File
Chapter 4: Linux Name Services
Listing 4.1: A Sample Host Table
Listing 4.2: A Sample /etc/resolv.conf File
Listing 4.3: A Sample zone Statement
Listing 4.4: A Common Caching−Only Configuration
Listing 4.5: The Red Hat named.conf File
Listing 4.6: The Red Hat localhost.zone File
Listing 4.7: The named Hints File
Listing 4.8: The named.local File
Listing 4.9: A DNS Slave Server Configuration
Listing 4.10: A DNS Master Server Configuration
Listing 4.11: A Sample DNS Zone File
478
Listing 4.12: A DNS Reverse Zone File
Listing 4.13: The Red Hat rndc.conf File
Listing 4.14: A Complete host.conf File
Listing 4.15: A Sample nsswitch.conf File
Chapter 5: Configuring a Mail Server
Listing 5.1: A Sample aliases File
Listing 5.2: Sample of the sendmail.cf Local Info Section
Listing 5.3: Sample sendmail.cf Options
Listing 5.4: sendmail.cf Header Commands
Listing 5.5: Sample mailer Definitions
Listing 5.6: Testing the Default sendmail Configuration
Listing 5.7: Testing sendmail Masquerading
Listing 5.8: The tcpproto.mc File
Listing 5.9: The linux.m4 OSTYPE File
Listing 5.10: The generic.m4 DOMAIN File
Listing 5.11: A Customized DOMAIN File
Listing 5.12: A Customized Macro Control File
Listing 5.13: A Sample genericstable
Listing 5.14: Testing Address Rewriting
Chapter 6: The Apache Web Server
Listing 6.1: Starting and Checking httpd
Listing 6.2: Listing Statically Linked httpd Modules
Listing 6.3: Active Directory Containers in Red Hat's httpd.conf File
Listing 6.4: Apache Access Controls
Listing 6.5: User Authentication for Web Access
Listing 6.6: Using mod_auth_db for User Authentication
Listing 6.7: Adding Users with dbmmanage
Listing 6.8: Red Hat's SSL Apache Server Configuration
Listing 6.9: Examining a Certificate with the openssl Command
Listing 6.10: Creating an Apache Certificate Signature Request
Listing 6.11: Examining a Certificate Signature Request with openssl
Listing 6.12: The Server−Status Location Container
Chapter 7: Network Gateway Services
Listing 7.1: Viewing the arp Cache
Listing 7.2: Viewing a Single arp Table Entry
Listing 7.3: A Simple Routing Table
Listing 7.4: A sample /etc/gateways file
Listing 7.5: Sample zebra.conf File
Listing 7.6: Examining zebra.conf through the vtysh Interface
Listing 7.7: The Port Numbers Used by the Zebra Suite
Listing 7.8: Reconfiguring zebra.conf through the vtysh Interface
Listing 7.9: A Sample ripd.conf File
Listing 7.10: A zebra.conf File for a Linux Host
Listing 7.11: A zebra.conf File for a RIP/OSPF Router
Listing 7.12: A ripd.conf File for a RIP/OSPF Router
Listing 7.13: A Sample ospfd.conf File
479
Listing 7.14: A Sample bgpd.conf File
Listing 7.15: A gated RIPv2 Configuration
Listing 7.16: A gated OSPF/RIPv2 Interior Router Configuration
Listing 7.17: A gated OSPF/BGP Exterior Router Configuration
Chapter 8: Desktop Configuration Servers
Listing 8.1: A Sample dhcpd.conf File
Listing 8.2: A Sample dhcpcd−eth0.info File
Listing 8.3: A Sample ifcfg−eth0 File
Listing 8.4: A Sample pump.conf File
Listing 8.5: A Sample dhclient.conf File
Chapter 9: File Sharing
Listing 9.1: Examining File Permissions with ls
Listing 9.2: Displaying RPC Ports
Listing 9.3: A Sample /etc/exports File
Listing 9.4: The showmount Command
Listing 9.5: Sample Mount Commands
Listing 9.6: A Sample fstab File
Listing 9.7: A Sample /etc/mtab File
Listing 9.8: A Sample lmhosts File
Listing 9.9: Active Lines in the Red Hat smb.conf File
Listing 9.10: Samba File Shares
Listing 9.11: Using smbclient
Listing 9.12: Checking /proc/filesystems
Listing 9.13: An smbmount Example
Chapter 10: Printer Services
Listing 10.1: Listing the Printer Ports
Listing 10.2: A Sample printcap File
Listing 10.3: Using lpc Interactively
Listing 10.4: Viewing and Reordering a Print Queue
Listing 10.5: Removing Jobs from the Print Queue
Listing 10.6: smb.conf with Printer Sharing
Listing 10.7: The script.cfg File for a Samba Printer
Chapter 11: More Mail Services
Listing 11.1: Using the POP Protocol with telnet
Listing 11.2: Testing IMAP with telnet
Listing 11.3: Permitting Mail Relaying
Listing 11.4: Testing the dnsbl Feature
Listing 11.5: A Sample Access Database for sendmail
Listing 11.6: Adding the Access Database to the Configuration
Listing 11.7: A Local_check_mail Example
Listing 11.8: An Example of Creating a Local Ruleset
Listing 11.9: A sample .procmailrc file
Chapter 12: Security
480
Listing 12.1: The tcpd Security Log
Listing 12.2: An xinetd Configuration File
Listing 12.3: xinetd.conf Access Controls
Listing 12.4: Sample iptables Commands
Listing 12.5: Linux Rejects Weak Passwords
Listing 12.6: Excerpts from the Shadow Password File
Listing 12.7: Modifying /etc/shadow with usermod
Listing 12.8: Generating OPIE Password Phrases
Listing 12.9: A Sample ssh Login
Listing 12.10: An Example of the ssh−keygen Command
Listing 12.11: The Red Hat sshd_config file
Listing 12.12: The Red Hat ssh_config file
Chapter 13: Troubleshooting
Listing 13.1: Adding the New Kernel to lilo.conf
Listing 13.2: Adding a New Kernel to grub.conf
Listing 13.3: Red Hat Network Interface Configuration Files
Listing 13.4: Displaying the Configuration with ifconfig
Listing 13.5: Viewing the ARP Table
Listing 13.6: The arpwatch arp.dat File
Listing 13.7: Sample arpwatch E−mail Reports
Listing 13.8: Testing a PPP Link with minicom
Listing 13.9: A Successful ping Test
Listing 13.10: A Failed ping Test
Listing 13.11: Displaying the Routing Table
Listing 13.12: Testing a Route with traceroute
Listing 13.13: Displaying Network Socket Connections
Listing 13.14: Display All Sockets
Listing 13.15: A telnet Handshake as Seen by tcpdump
Listing 13.16: Monitoring Traffic with tcpdump
Listing 13.17: Testing DNS with nslookup
Listing 13.18: Testing Continues
Listing 13.19: Testing DNS with the host Command
Listing 13.20: Testing DNS with dig
Appendix A: Installing Linux
Listing A.1: Using rawrite
Listing A.2: Creating Floppy Disks with dd
Listing A.3: Partitioning with fdisk
Listing A.4: Adding Logical Partitions
Listing A.5: Assigning Filesystem Types
Appendix B: BIND Reference
Listing B.1: The BIND 8 options Statement Syntax
Listing B.2: The BIND 9 options Statement Syntax
Listing B.3: BIND 8 logging Command Syntax
Listing B.4: BIND 9 logging Command Syntax
Listing B.5: BIND 8 zone Statement Syntax
Listing B.6: BIND 9 zone Statement Syntax
481
Listing B.7: The BIND 8 server Statement Syntax
Listing B.8: The BIND 9 server Statement Syntax
Listing B.9: The key Statement Syntax
Listing B.10: The acl Statement Syntax
Listing B.11: The trusted−keys Statement Syntax
Listing B.12: BIND 8 controls Statement Syntax
Listing B.13: BIND 9 controls Statement Syntax
Listing B.14: The view Statement Syntax
482
List of Sidebars
Introduction
Sidebars
Chapter 2: The Network Interface
Address Mask, Subnet Mask, or Network Mask?
Chapter 4: Linux Name Services
Resolver Timeouts
Chapter 7: Network Gateway Services
Proxy ARP
Counting to Infinity
Chapter 8: Desktop Configuration Servers
Using dhcpd with Old Linux Kernels
Placing DHCP Servers
Chapter 9: File Sharing
Hidden Bits
Coordinating UIDs and GIDs
Clear−Text Password
Chapter 11: More Mail Services
Spam, Spam, Spam, Spam, and Spam
Chapter 12: Security
Realistic Wrapper Rules
Password Dos and Don'ts
The OPIE Transition Mechanism
Chapter 13: Troubleshooting
Adapter Card Configuration
Appendix A: Installing Linux
Working with a Windows Partition
Symbolic Links
483
Các file đính kèm theo tài liệu này:
- 3.pdf