mirror of
https://git.openafs.org/openafs.git
synced 2025-01-22 00:41:08 +00:00
368 lines
18 KiB
HTML
368 lines
18 KiB
HTML
|
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 4//EN">
|
||
|
<HTML><HEAD>
|
||
|
<TITLE>Administration Reference</TITLE>
|
||
|
<!-- Begin Header Records ========================================== -->
|
||
|
<!-- /tmp/idwt3672/auarf000.scr converted by idb2h R4.2 (359) ID -->
|
||
|
<!-- Workbench Version (AIX) on 3 Oct 2000 at 16:18:30 -->
|
||
|
<META HTTP-EQUIV="updated" CONTENT="Tue, 03 Oct 2000 16:18:29">
|
||
|
<META HTTP-EQUIV="review" CONTENT="Wed, 03 Oct 2001 16:18:29">
|
||
|
<META HTTP-EQUIV="expires" CONTENT="Thu, 03 Oct 2002 16:18:29">
|
||
|
</HEAD><BODY>
|
||
|
<!-- (C) IBM Corporation 2000. All Rights Reserved -->
|
||
|
<BODY bgcolor="ffffff">
|
||
|
<!-- End Header Records ============================================ -->
|
||
|
<A NAME="Top_Of_Page"></A>
|
||
|
<H1>Administration Reference</H1>
|
||
|
<HR><P ALIGN="center"> <A HREF="../index.htm"><IMG SRC="../books.gif" BORDER="0" ALT="[Return to Library]"></A> <A HREF="auarf002.htm#ToC"><IMG SRC="../toc.gif" BORDER="0" ALT="[Contents]"></A> <A HREF="auarf097.htm"><IMG SRC="../prev.gif" BORDER="0" ALT="[Previous Topic]"></A> <A HREF="#Bot_Of_Page"><IMG SRC="../bot.gif" BORDER="0" ALT="[Bottom of Topic]"></A> <A HREF="auarf099.htm"><IMG SRC="../next.gif" BORDER="0" ALT="[Next Topic]"></A> <A HREF="auarf284.htm#HDRINDEX"><IMG SRC="../index.gif" BORDER="0" ALT="[Index]"></A> <P>
|
||
|
<P>
|
||
|
<H2><A NAME="HDRBOS_CREATE" HREF="auarf002.htm#ToC_112">bos create</A></H2>
|
||
|
<A NAME="IDX4477"></A>
|
||
|
<A NAME="IDX4478"></A>
|
||
|
<A NAME="IDX4479"></A>
|
||
|
<A NAME="IDX4480"></A>
|
||
|
<A NAME="IDX4481"></A>
|
||
|
<A NAME="IDX4482"></A>
|
||
|
<A NAME="IDX4483"></A>
|
||
|
<A NAME="IDX4484"></A>
|
||
|
<A NAME="IDX4485"></A>
|
||
|
<A NAME="IDX4486"></A>
|
||
|
<P><STRONG>Purpose</STRONG>
|
||
|
<P>Defines a new process in the <B>/usr/afs/local/BosConfig</B> file and
|
||
|
starts it running
|
||
|
<P><STRONG>Synopsis</STRONG>
|
||
|
<PRE><B>bos create -server</B> <<VAR>machine name</VAR>> <B>-instance</B> <<VAR>server process name</VAR>>
|
||
|
<B>-type</B> <<VAR>server type</VAR>> <B>-cmd</B> <<VAR>command lines</VAR>><SUP>+</SUP>
|
||
|
[<B>-notifier</B> <<VAR>Notifier program</VAR>>] [<B>-cell</B> <<VAR>cell name</VAR>>]
|
||
|
[<B>-noauth</B>] [<B>-localauth</B>] [<B>-help</B>]
|
||
|
|
||
|
<B>bos c -s</B> <<VAR>machine name</VAR>> <B>-i</B> <<VAR>server process name</VAR>> <B>-t</B> <<VAR>server type</VAR>>
|
||
|
<B>-cm</B> <<VAR>command lines</VAR>><SUP>+</SUP> [<B>-not</B> <<VAR>Notifier program</VAR>>] [<B>-ce</B> <<VAR>cell name</VAR>>]
|
||
|
[<B>-noa</B>] [<B>-l</B>] [<B>-h</B>]
|
||
|
</PRE>
|
||
|
<P><STRONG>Description</STRONG>
|
||
|
<P>The <B>bos create</B> command creates a server process entry in the
|
||
|
<B>/usr/afs/local/BosConfig</B> file on the server machine named by the
|
||
|
<B>-server</B> argument, sets the process's status to <B>Run</B>
|
||
|
in the <B>BosConfig</B> file and in memory, and starts the process.
|
||
|
<P>A server process's entry in the <B>BosConfig</B> file defines its
|
||
|
name, its type, the command that initializes it, and optionally, the name of a
|
||
|
notifier program that runs when the process terminates.
|
||
|
<P><STRONG>Options</STRONG>
|
||
|
<DL>
|
||
|
<P><DT><B><B>-server</B>
|
||
|
</B><DD>Indicates the server machine on which to define and start the new
|
||
|
process. Identify the machine by IP address or its host name (either
|
||
|
fully-qualified or abbreviated unambiguously). For details, see the
|
||
|
introductory reference page for the <B>bos</B> command suite.
|
||
|
<P><DT><B><B>-instance</B>
|
||
|
</B><DD>Names the process to define and start. Any name is acceptable, but
|
||
|
for the sake of simplicity it is best to use the last element of the
|
||
|
process's binary file pathname, and to use the same name on every server
|
||
|
machine. The conventional names, as used in all AFS documentation,
|
||
|
are:
|
||
|
<DL>
|
||
|
<P><DT><B><B>buserver</B>
|
||
|
</B><DD>The Backup Server process
|
||
|
<A NAME="IDX4487"></A>
|
||
|
<A NAME="IDX4488"></A>
|
||
|
<P><DT><B><B>fs</B>
|
||
|
</B><DD>The process that combines the File Server, Volume Server, and Salvager
|
||
|
processes (<B>fileserver</B>, <B>volserver</B>, and
|
||
|
<B>salvager</B>)
|
||
|
<A NAME="IDX4489"></A>
|
||
|
<A NAME="IDX4490"></A>
|
||
|
<P><DT><B><B>kaserver</B>
|
||
|
</B><DD>The Authentication Server process
|
||
|
<A NAME="IDX4491"></A>
|
||
|
<A NAME="IDX4492"></A>
|
||
|
<P><DT><B><B>ptserver</B>
|
||
|
</B><DD>The Protection Server process
|
||
|
<A NAME="IDX4493"></A>
|
||
|
<A NAME="IDX4494"></A>
|
||
|
<P><DT><B><B>runntp</B>
|
||
|
</B><DD>The controller process for the Network Time Protocol Daemon
|
||
|
<A NAME="IDX4495"></A>
|
||
|
<A NAME="IDX4496"></A>
|
||
|
<P><DT><B><B>upclientbin</B>
|
||
|
</B><DD>The client portion of the Update Server process that retrieves binary
|
||
|
files from the <B>/usr/afs/bin</B> directory of the binary distribution
|
||
|
machine for this machine's CPU/operating system type. (The name of
|
||
|
the binary is <B>upclient</B>, but the <B>bin</B> suffix distinguishes
|
||
|
this process from <B>upclientetc</B>.)
|
||
|
<A NAME="IDX4497"></A>
|
||
|
<A NAME="IDX4498"></A>
|
||
|
<P><DT><B><B>upclientetc</B>
|
||
|
</B><DD>The client portion of the Update Server process that retrieves
|
||
|
configuration files from the <B>/usr/afs/etc</B> directory of the system
|
||
|
control machine. Do not run this process in cells that use the
|
||
|
international edition of AFS. (The name of the binary is
|
||
|
<B>upclient</B>, but the <B>etc</B> suffix distinguishes this process
|
||
|
from <B>upclientbin</B>.)
|
||
|
<P><DT><B><B>upserver</B>
|
||
|
</B><DD>The server portion of the Update Server process
|
||
|
<A NAME="IDX4499"></A>
|
||
|
<A NAME="IDX4500"></A>
|
||
|
<P><DT><B><B>vlserver</B>
|
||
|
</B><DD>The Volume Location (VL) Server process
|
||
|
<A NAME="IDX4501"></A>
|
||
|
<A NAME="IDX4502"></A>
|
||
|
</DL>
|
||
|
<P><DT><B><B>-type</B>
|
||
|
</B><DD>Specifies the process's type. The acceptable values are:
|
||
|
<P>
|
||
|
<DL>
|
||
|
<P><DT><B><B>cron</B>
|
||
|
</B><DD>Use this value for cron-type processes that the BOS Server starts only at
|
||
|
a defined daily or weekly time, rather than whenever it detects that the
|
||
|
process has terminated. AFS does not define any such processes by
|
||
|
default, but makes this value available for administrator use. Define
|
||
|
the time for command execution as part of the <B>-cmd</B> argument to the
|
||
|
<B>bos create</B> command.
|
||
|
<P><DT><B><B>fs</B>
|
||
|
</B><DD>Use this value only for the <B>fs</B> process, which combines the File
|
||
|
Server, Volume Server and Salvager processes. If one of the component
|
||
|
processes terminates, the BOS Server shuts down and restarts the processes in
|
||
|
the appropriate order.
|
||
|
<P><DT><B><B>simple</B>
|
||
|
</B><DD>Use this value for all processes listed as acceptable values to the
|
||
|
<B>-instance</B> argument, except for the <B>fs</B> process.
|
||
|
There are no interdependencies between simple processes, so the BOS Server can
|
||
|
stop and start them independently as necessary.
|
||
|
</DL>
|
||
|
<P><DT><B><B>-cmd</B>
|
||
|
</B><DD>Specifies each command the BOS Server runs to start the process.
|
||
|
Specify no more than six commands (which can include the command's
|
||
|
options, in which case the entire string is surrounded by double quotes);
|
||
|
any additional commands are ignored.
|
||
|
<P>For a simple process, provide the complete pathname of the process's
|
||
|
binary file on the local disk (for example, <B>/usr/afs/bin/ptserver</B>
|
||
|
for the Protection Server). If including any of the initialization
|
||
|
command's options, surround the entire command in double quotes (<B>"
|
||
|
"</B>). The <B>upclient</B> process has a required argument, and
|
||
|
the commands for all other processes take optional arguments.
|
||
|
<A NAME="IDX4503"></A>
|
||
|
<P>For the <B>fs</B> process, provide the complete pathname of the local
|
||
|
disk binary file for each of the component processes:
|
||
|
<B>fileserver</B>, <B>volserver</B>, and <B>salvager</B>, in that
|
||
|
order. The standard binary directory is <B>/usr/afs/bin</B>.
|
||
|
If including any of an initialization command's options, surround the
|
||
|
entire command in double quotes (<B>" "</B>).
|
||
|
<A NAME="IDX4504"></A>
|
||
|
<P>For a <B>cron</B> process, provide two parameters:
|
||
|
<A NAME="IDX4505"></A>
|
||
|
<UL>
|
||
|
<P><LI>The complete local disk pathname of either an executable file or a command
|
||
|
from one of the AFS suites (complete with all of the necessary
|
||
|
arguments). Surround this parameter with double quotes (<B>" "</B>)
|
||
|
if it contains spaces.
|
||
|
<P><LI>A specification of when the BOS Server executes the file or command
|
||
|
indicated by the first parameter. There are three acceptable
|
||
|
values:
|
||
|
<UL>
|
||
|
<P><LI>The string <B>now</B>, which directs the BOS Server to execute the
|
||
|
file or command immediately and only once. It is usually simpler to
|
||
|
issue the command directly or issue the <B>bos exec</B> command.
|
||
|
<P><LI>A time of day. The BOS Server executes the file or command daily at
|
||
|
the indicated time. Separate the hours and minutes with a colon
|
||
|
(<I>hh</I>:<I>MM</I>), and use either 24-hour format, or a value
|
||
|
in the range from <B>1:00</B> through <B>12:59</B> with
|
||
|
the addition of <B>am</B> or <B>pm</B>. For example, both
|
||
|
<B>14:30</B> and <B>"2:30 pm"</B> indicate 2:30 in
|
||
|
the afternoon. Surround this parameter with double quotes (<B>"
|
||
|
"</B>) if it contains a space.
|
||
|
<P><LI>A day of the week and time of day, separated by a space and surrounded
|
||
|
with double quotes (<B>" "</B>). The BOS Server executes the file
|
||
|
or command weekly at the indicated day and time. For the day, provide
|
||
|
either the whole name or the first three letters, all in lowercase letters
|
||
|
(<B>sunday</B> or <B>sun</B>, <B>thursday</B> or <B>thu</B>,
|
||
|
and so on). For the time, use the same format as when specifying the
|
||
|
time alone.
|
||
|
</UL>
|
||
|
</UL>
|
||
|
<P><DT><B><B>-notifier</B>
|
||
|
</B><DD>Specifies the complete pathname on the local disk of a program that the
|
||
|
BOS Server invokes when the process terminates. The AFS distribution
|
||
|
does not include any notifier programs, but this argument is available for
|
||
|
administrator use. See the <B>Related Information</B>
|
||
|
section.
|
||
|
<P><DT><B><B>-cell</B>
|
||
|
</B><DD>Names the cell in which to run the command. Do not combine this
|
||
|
argument with the <B>-localauth</B> flag. For more details, see the
|
||
|
introductory <B>bos</B> reference page.
|
||
|
<P><DT><B><B>-noauth</B>
|
||
|
</B><DD>Assigns the unprivileged identity <B>anonymous</B> to the
|
||
|
issuer. Do not combine this flag with the <B>-localauth</B>
|
||
|
flag. For more details, see the introductory <B>bos</B> reference
|
||
|
page.
|
||
|
<P><DT><B><B>-localauth</B>
|
||
|
</B><DD>Constructs a server ticket using a key from the local
|
||
|
<B>/usr/afs/etc/KeyFile</B> file. The <B>bos</B> command
|
||
|
interpreter presents the ticket to the BOS Server during mutual
|
||
|
authentication. Do not combine this flag with the <B>-cell</B> or
|
||
|
<B>-noauth</B> options. For more details, see the introductory
|
||
|
<B>bos</B> reference page.
|
||
|
<P><DT><B>-help
|
||
|
</B><DD>Prints the online help for this command. All other valid options
|
||
|
are ignored.
|
||
|
</DL>
|
||
|
<P><STRONG>Examples</STRONG>
|
||
|
<P>The following command defines and starts the simple process
|
||
|
<B>kaserver</B> on the machine <B>fs3.abc.com</B>:
|
||
|
<PRE> % <B>bos create -server fs3.abc.com -instance kaserver -type simple</B> \
|
||
|
<B>-cmd /usr/afs/bin/kaserver</B>
|
||
|
|
||
|
</PRE>
|
||
|
<P>The following command defines and starts the simple process
|
||
|
<B>upclientbin</B> on the machine
|
||
|
<B>fs4.abc.com</B>. It references
|
||
|
<B>fs1.abc.com</B> as the source for updates to binary
|
||
|
files, checking for changes to the <B>/usr/afs/bin</B> directory every 120
|
||
|
seconds.
|
||
|
<PRE> % <B>bos create -server fs4.abc.com -instance upclientbin -type simple</B> \
|
||
|
<B>-cmd "/usr/afs/bin/upclient fs1.abc.com -clear -t 120</B> \
|
||
|
<B>/usr/afs/bin"</B>
|
||
|
|
||
|
</PRE>
|
||
|
<P>The following command creates the fs process <B>fs</B> on the machine
|
||
|
<B>fs4.abc.com</B>. Type the command on a single
|
||
|
line.
|
||
|
<PRE> % <B>bos create -server fs4.abc.com -instance fs -type fs</B> \
|
||
|
<B>-cmd /usr/afs/bin/fileserver /usr/afs/bin/volserver</B> \
|
||
|
<B>/usr/afs/bin/salvager</B>
|
||
|
|
||
|
</PRE>
|
||
|
<P>The following command creates a <B>cron</B> process called
|
||
|
<B>userbackup</B> on the machine <B>fs5.abc.com</B>, so
|
||
|
that the BOS Server issues the indicated <B>vos backupsys</B> command each
|
||
|
day at 3:00 a.m. (the command creates a backup version of
|
||
|
every volume in the file system whose name begins with
|
||
|
<B>user</B>). Note that the issuer provides the complete pathname
|
||
|
to the <B>vos</B> command, includes the <B>-localauth</B> flag on it,
|
||
|
and types the entire <B>bos create</B> command on one line.
|
||
|
<PRE> % <B>bos create -server fs5.abc.com -instance userbackup -type cron</B> \
|
||
|
<B>-cmd "/usr/afs/bin/vos backupsys -prefix user -localauth" 03:00</B>
|
||
|
|
||
|
</PRE>
|
||
|
<P><STRONG>Privilege Required</STRONG>
|
||
|
<P>The issuer must be listed in the <B>/usr/afs/etc/UserList</B> file on
|
||
|
the machine named by the <B>-server</B> argument, or must be logged onto a
|
||
|
server machine as the local superuser <B>root</B> if the
|
||
|
<B>-localauth</B> flag is included.
|
||
|
<P><STRONG>Related Information</STRONG>
|
||
|
<P>If the <B>-notifier</B> argument is included when this command is used
|
||
|
to define and start a process, the BOS Server invokes the indicated
|
||
|
<I>notifier program</I> when the process exits. The intended use of
|
||
|
a notifier program is to inform administrators when a process exits
|
||
|
unexpectedly, but it can be used to perform any appropriate actions.
|
||
|
The following paragraphs describe the <B>bnode</B> and
|
||
|
<B>bnode_proc</B> structures in which the BOS Server records information
|
||
|
about the exiting process. The list of AFS commands related to this one
|
||
|
follows.
|
||
|
<P>The BOS Server constructs and sends on the standard output stream one
|
||
|
<B>bnode</B> and one <B>bnode_proc</B> structure for each exiting
|
||
|
process associated with the notifier program. It brackets each
|
||
|
structure with appropriate <TT>BEGIN</TT> and <TT>END</TT> statements
|
||
|
(<TT>BEGIN bnode</TT> and <TT>END bnode</TT>, <TT>BEGIN bnode_proc</TT>
|
||
|
and <TT>END bnode_proc</TT>), which immediately follow the preceding newline
|
||
|
character with no intervening spaces or other characters. If the
|
||
|
notifier program does not need information from a structure, it can scan ahead
|
||
|
in the input stream for the <TT>END</TT> statement.
|
||
|
<P>In general, each field in a structure is a string of ASCII text terminated
|
||
|
by the newline character. The format of the information within a
|
||
|
structure possibly varies slightly depending on the type of process associated
|
||
|
with the notifier program.
|
||
|
<P>The C code for the <B>bnode</B> and <B>bnode_proc</B> structures
|
||
|
follows. Note that the structures sent by the BOS Server do not
|
||
|
necessarily include all of the fields described here, because some are used
|
||
|
only for internal record keeping. The notifier process must robustly
|
||
|
handle the absence of expected fields, as well as the presence of unexpected
|
||
|
fields, on the standard input stream.
|
||
|
<P>For proper performance, the notifier program must continue processing the
|
||
|
input stream until it detects the end-of-file (EOF). The BOS Server
|
||
|
closes the standard input file descriptor to the notifier process when it has
|
||
|
completed delivery of the data, and it is the responsibility of the notifier
|
||
|
process to terminate properly.
|
||
|
<P><B>struct bnode contents</B>
|
||
|
<PRE> struct bnode {
|
||
|
struct bnode *next; /* next pointer in top-level's list */
|
||
|
char *name; /* instance name */
|
||
|
long nextTimeout; /* next time this guy should be awakened */
|
||
|
long period; /* period between calls */
|
||
|
long rsTime; /* time we started counting restarts */
|
||
|
long rsCount; /* count of restarts since rsTime */
|
||
|
struct bnode_type *type; /* type object */
|
||
|
struct bnode_ops *ops; /* functions implementing bnode class */
|
||
|
long procStartTime; /* last time a process was started */
|
||
|
long procStarts; /* number of process starts */
|
||
|
long lastAnyExit; /* last time a process exited for any reason */
|
||
|
long lastErrorExit; /* last time a process exited unexpectedly */
|
||
|
long errorCode; /* last exit return code */
|
||
|
long errorSignal; /* last proc terminating signal */
|
||
|
char *lastErrorName; /* name of proc that failed last */
|
||
|
short refCount; /* reference count */
|
||
|
short flags; /* random flags */
|
||
|
char goal; /* 1=running or 0=not running */
|
||
|
char fileGoal; /* same, but to be stored in file */
|
||
|
};
|
||
|
|
||
|
</PRE>
|
||
|
<P><B>format of struct bnode explosion</B>
|
||
|
<PRE> printf("name: %s\n",tp->name);
|
||
|
printf("rsTime: %ld\n", tp->rsTime);
|
||
|
printf("rsCount: %ld\n", tp->rsCount);
|
||
|
printf("procStartTime: %ld\n", tp->procStartTime);
|
||
|
printf("procStarts: %ld\n", tp->procStarts);
|
||
|
printf("lastAnyExit: %ld\n", tp->lastAnyExit);
|
||
|
printf("lastErrorExit: %ld\n", tp->lastErrorExit);
|
||
|
printf("errorCode: %ld\n", tp->errorCode);
|
||
|
printf("errorSignal: %ld\n", tp->errorSignal);
|
||
|
printf("lastErrorName: %s\n", tp->lastErrorName);
|
||
|
printf("goal: %d\n", tp->goal);
|
||
|
|
||
|
</PRE>
|
||
|
<P><B>struct bnode_proc contents</B>
|
||
|
<PRE> struct bnode_proc {
|
||
|
struct bnode_proc *next; /* next guy in top-level's list */
|
||
|
struct bnode *bnode; /* bnode creating this process */
|
||
|
char *comLine; /* command line used to start this process */
|
||
|
char *coreName; /* optional core file component name */
|
||
|
long pid; /* pid if created */
|
||
|
long lastExit; /* last termination code */
|
||
|
long lastSignal; /* last signal that killed this guy */
|
||
|
long flags; /* flags giving process state */
|
||
|
};
|
||
|
|
||
|
</PRE>
|
||
|
<P><B>format of struct bnode_proc explosion</B>
|
||
|
<PRE> printf("comLine: %s\n", tp->comLine);
|
||
|
printf("coreName: %s\n", tp->coreName);
|
||
|
printf("pid: %ld\n", tp->pid);
|
||
|
printf("lastExit: %ld\n", tp->lastExit);
|
||
|
printf("lastSignal: %ld\n", tp->lastSignal);
|
||
|
|
||
|
</PRE>
|
||
|
<P><A HREF="auarf016.htm#HDRBOSCONFIG">BosConfig</A>
|
||
|
<P><A HREF="auarf023.htm#HDRKEYFILE">KeyFile</A>
|
||
|
<P><A HREF="auarf035.htm#HDRUSERLIST">UserList</A>
|
||
|
<P><A HREF="auarf093.htm#HDRBOS_INTRO">bos</A>
|
||
|
<P><A HREF="auarf125.htm#HDRBUSERVER">buserver</A>
|
||
|
<P><A HREF="auarf129.htm#HDRFILESERVER">fileserver</A>
|
||
|
<P><A HREF="auarf198.htm#HDRKASERVER">kaserver</A>
|
||
|
<P><A HREF="auarf227.htm#HDRPTSERVER">ptserver</A>
|
||
|
<P><A HREF="auarf230.htm#HDRRUNNTP">runntp</A>
|
||
|
<P><A HREF="auarf232.htm#HDRSALVAGER">salvager</A>
|
||
|
<P><A HREF="auarf240.htm#HDRUPCLIENT">upclient</A>
|
||
|
<P><A HREF="auarf241.htm#HDRUPSERVER">upserver</A>
|
||
|
<P><A HREF="auarf249.htm#HDRVLSERVER">vlserver</A>
|
||
|
<P><A HREF="auarf251.htm#HDRVOLSERVER">volserver</A>
|
||
|
<P><A HREF="auarf256.htm#HDRVOS_BACKUPSYS">vos backupsys</A>
|
||
|
<P>
|
||
|
<HR><P ALIGN="center"> <A HREF="../index.htm"><IMG SRC="../books.gif" BORDER="0" ALT="[Return to Library]"></A> <A HREF="auarf002.htm#ToC"><IMG SRC="../toc.gif" BORDER="0" ALT="[Contents]"></A> <A HREF="auarf097.htm"><IMG SRC="../prev.gif" BORDER="0" ALT="[Previous Topic]"></A> <A HREF="#Top_Of_Page"><IMG SRC="../top.gif" BORDER="0" ALT="[Top of Topic]"></A> <A HREF="auarf099.htm"><IMG SRC="../next.gif" BORDER="0" ALT="[Next Topic]"></A> <A HREF="auarf284.htm#HDRINDEX"><IMG SRC="../index.gif" BORDER="0" ALT="[Index]"></A> <P>
|
||
|
<!-- Begin Footer Records ========================================== -->
|
||
|
<P><HR><B>
|
||
|
<br>© <A HREF="http://www.ibm.com/">IBM Corporation 2000.</A> All Rights Reserved
|
||
|
</B>
|
||
|
<!-- End Footer Records ============================================ -->
|
||
|
<A NAME="Bot_Of_Page"></A>
|
||
|
</BODY></HTML>
|