From 7a13c7b00ac3c8f142d86f1e2f4d0c21bc9fe6df Mon Sep 17 00:00:00 2001 From: bp-sawyers Date: Wed, 2 Apr 2008 21:42:29 +0000 Subject: [PATCH] Improved several man pages and deleted unused doc/configuration.pod and getnodecfg git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@969 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- doc/configuration.pod | 27 ------- perl-xCAT-2.0/db2man | 33 ++++++++- xCAT-client-2.0/bin/getnodecfg | 73 ------------------- xCAT-client-2.0/pods/man1/dumpxCATdb.1.pod | 25 +++---- xCAT-client-2.0/pods/man1/restorexCATdb.1.pod | 27 +++---- xCAT-client-2.0/pods/man1/rnetboot.1.pod | 27 +++---- xCAT-client-2.0/pods/man8/mkrrnodes.8.pod | 30 +++++++- 7 files changed, 92 insertions(+), 150 deletions(-) delete mode 100644 doc/configuration.pod delete mode 100755 xCAT-client-2.0/bin/getnodecfg diff --git a/doc/configuration.pod b/doc/configuration.pod deleted file mode 100644 index f1b73e80e..000000000 --- a/doc/configuration.pod +++ /dev/null @@ -1,27 +0,0 @@ -=pod - -=head1 xCAT configuration core architecture - -xCAT configuration spans a number of tables, some with records associated with particular nodes (such as nodelist and nodehm) and others that do not have a direct relationship with any given node. - -The tables not associated with a given node are straightforward, the data is stored and retrieved as-is from the database without interpretation, and without any configuration layer inheritance (though some calling code may have an internal concept of inheritance with such fields, the core configuration will have no facilities to explicitly aid this. - -The tables with records typically retrieved by node name have some extra features to enable a more template-based style to be used: - -=over - -=item * - -Any tagname can be used in lieu of a node name under the node field, and that record will then be taken to be applicable to any node with that tag. If a field is requested for a specific node, and either a record doesn't exist specifically for that nodename or a record exists, but has no definition for the requested field, that nodes tags are then used to search for general level records. If multiple records could apply from two different tags, the precedence is TBD. This is nearly identical to most xCAT 1.x tab file conventions. This is useful in tables such as noderes, where typical configurations have exactly the same field values for large sets of nodes. - -=item * - -xCAT 2 extends the above to be made useful where a field will vary for every node with a given tag, but in ways that would be trivial to describe. If a field is of the format /I/I/, it is taken to be a perl regular expression, to be performed on the nodename. For example, the bmc field of the ipmi table might be /\z/-bmc/ for a record with node=ipmi to specify that the BMC hostname is derived by appending -bmc to the end of the nodename of every node tagged ipmi. This is useful in tables such as ipmi. - -=item * - -As an extension to the above, a regular expression extended with arithmetic operators is available, by using the format |I|I|. This behaves similarly to the above, but () enclosed parts in I are taken to signify arithmetic operations and substituted in. All operations are integer arithmetic, so 5/4 would come out as 1. The typical perl positional variables are available in such expressions. For example, the mpa field of the mp table for node=blade might be |\D+(\d+)|bc((${1}-1)/14+1)|. Specifically in this case, if you had a node named blade572 tagged blade, the 572 would be set to ${1} by the left hand parentheses, and on the right hand, that would become bc((572-1/14+1)), and finally evaluated and returned as bc41. To complete the example, the id field of mp would be |\D+(\d+)|((${1}-1)%14+1)|, which upon evaluation indicates slot 12. This is useful for tables that call out infrastructure devices/port numbers, such as switch, nodehm (for terminal servers), and mp (for IBM Bladecenter configurations). - -=back - -An administrator may chose to ignore any and all of the functions. For example, an administrator may chose to only make use of the first mentioned feature, and preserve an xCAT 1.x layout for their tables. diff --git a/perl-xCAT-2.0/db2man b/perl-xCAT-2.0/db2man index 0e1fb160e..0e3937ba2 100755 --- a/perl-xCAT-2.0/db2man +++ b/perl-xCAT-2.0/db2man @@ -155,8 +155,37 @@ where mgmtnode is the hostname of the management node adapter on the cluster sid =back -xCAT also supports regular expressions in the tables. This enables one row to represent many -rows. For example, if you have many blades in your cluster and their hostnames have a regular +The xCAT database spans a number of tables, some with records associated with particular nodes +(such as nodelist and nodehm) and others that do not have a direct relationship with any given node. +The tables not associated with a given node are straightforward, the data is stored and retrieved +as-is from the database without interpretation, and without any generic inheritance +(though some calling code may implement inheritance for specific fields, for example +nodehm.power inheriting from nodehm.mgt). + +The tables with records typically retrieved by node name have some extra features to enable a more +template-based style to be used: + +Any group name can be used in lieu of a node name in the node field, and that record will then +be taken to be applicable to any node in that group. If a field is requested for a specific node, +and either a record doesn't exist specifically for that nodename or a record exists, but has no +definition for the requested field, that node's groups are then used to search for +records. If multiple records could apply from two different groups, the precedence is +the order the groups are specified in the nodelist table for that node. This is nearly identical to +most xCAT 1.x tab file conventions. This is useful in tables such as noderes, where typical +configurations have exactly the same field values for large sets of nodes. + +xCAT 2 extends the above to be made useful where a field will vary for every node with a given tag, +but in ways that would be trivial to describe. If a field is of the format /I/I/, +it is taken to be a perl regular expression, to be performed on the nodename. For example, the bmc field +of the ipmi table might be B for a record with node=ipmi to specify that the BMC hostname is derived +by appending B<-bmc> to the end of the nodename of every node in the ipmi group. + +As an extension to the above, a regular expression extended with arithmetic operators is available, +by using the format |I|I|. This behaves similarly to the above, but () enclosed parts +in I are taken to signify arithmetic operations and substituted in. All operations are integer +arithmetic, so 5/4 would come out as 1. The typical perl positional variables are available in such expressions. + +For example, if you have many blades in your cluster and their hostnames have a regular pattern of blade1, blade2, etc., and your BladeCenter management modules also have a hostname pattern of amm1, amm2, etc., then your B table could be expressed by the following single row: diff --git a/xCAT-client-2.0/bin/getnodecfg b/xCAT-client-2.0/bin/getnodecfg deleted file mode 100755 index 6937b1a3d..000000000 --- a/xCAT-client-2.0/bin/getnodecfg +++ /dev/null @@ -1,73 +0,0 @@ -#!/usr/bin/env perl -# IBM(c) 2007 EPL license http://www.eclipse.org/legal/epl-v10.html -BEGIN -{ - $::XCATROOT = $ENV{'XCATROOT'} ? $ENV{'XCATROOT'} : -d '/opt/xcat' ? '/opt/xcat' : '/usr'; -} -use lib "$::XCATROOT/lib/perl"; -use xCAT::Table; -use xCAT::NodeRange; -use IO::Socket::SSL; -use XML::Simple; -$XML::Simple::PREFERRED_PARSER='XML::Parser'; -use Data::Dumper; -use strict; -my $xcathost='localhost:3001'; -if ($ENV{XCATHOST}) { - $xcathost=$ENV{XCATHOST}; -} - -my $server = IO::Socket::SSL->new( - PeerAddr=>$xcathost, - SSL_key_file=>$ENV{HOME}."/.xcat/client-key.pem", - SSL_cert_file=>$ENV{HOME}."/.xcat/client-cert.pem", - SSL_ca_file => $ENV{HOME}."/.xcat/ca.pem", - SSL_use_cert => 1, - #SSL_verify_mode => 1, - ); -die "Connection failure: $!\n" unless ($server); -my $target=shift(@ARGV); -my %request=(); #Start building the hash to XML-ify -$request{command}='getnodeattributes'; -$request{noderange}=$target; - -for (@ARGV) { - my $temp; - my $table; - my $column; - my $value; - ($table,$column) = split('\.',$_,2); - $request{table}=$table; #build/reuse request specific elements - $request{attribute}=$column; - print $server XMLout(\%request,RootName => 'xcatrequest',NoAttr => 1); - alarm(30); - my $response; - while (<$server>) { - alarm(0); - $response .= $_; - if ($response =~ m/<\/xcatresponse>/) { - my $reply=XMLin($response); - $response=""; - if ($reply->{error}) { - printf "ERROR: ".$reply->{error}."\n"; - } - if ($reply->{warning}) { - printf "Warning: ".$reply->{warning}."\n"; - } - if ($reply->{attributes}{$column}) { - printf "$table.$column:".$reply->{attributes}{$column}."\n"; - } - if ($reply->{serverdone}) { - last; - } - } - } -} - - - - #my $tab = xCAT::Table->new($table,-create => 1); - #my $rec = $tab->getAttribs($key,$val,$column); - -# if ($rec->{$column}) { printf $rec->{$column}."\n"; } -#} diff --git a/xCAT-client-2.0/pods/man1/dumpxCATdb.1.pod b/xCAT-client-2.0/pods/man1/dumpxCATdb.1.pod index 85ee44301..ab1d96a0c 100644 --- a/xCAT-client-2.0/pods/man1/dumpxCATdb.1.pod +++ b/xCAT-client-2.0/pods/man1/dumpxCATdb.1.pod @@ -1,15 +1,12 @@ =head1 NAME - -B - dumps the xCAT db tables . - + +B - dumps the xCAT db tables . + =head1 SYNOPSIS - -I -I +B [{B<-p>|B<--path>} I] - -I +B [B<-h>|B<--help>] [B<-v>|B<--version>] =head1 DESCRIPTION @@ -21,9 +18,9 @@ The dumpxCATdb command creates .csv files for all xCAT database tables and puts B<-h> Display usage message. -B<-v> Command Version. +B<-v> Command Version. -B<-p> Path to the directory to dump the tables. +B<-p> Path to the directory to dump the tables. =head1 RETURN VALUE @@ -34,14 +31,14 @@ B<-p> Path to the directory to dump the tables. =head1 EXAMPLES -1. To dump the xCAT database into the /tmp/db directory, enter: +1. To dump the xCAT database into the /tmp/db directory, enter: -I +B =head1 FILES - + /opt/xcat/sbin/dumpxCATdb @@ -51,4 +48,4 @@ This command is part of the xCAT software product. See restorexCATdb - + diff --git a/xCAT-client-2.0/pods/man1/restorexCATdb.1.pod b/xCAT-client-2.0/pods/man1/restorexCATdb.1.pod index 03ea23cd3..daa2b83a3 100644 --- a/xCAT-client-2.0/pods/man1/restorexCATdb.1.pod +++ b/xCAT-client-2.0/pods/man1/restorexCATdb.1.pod @@ -1,29 +1,26 @@ =head1 NAME - -B - restores the xCAT db tables . - + +B - restores the xCAT db tables . + =head1 SYNOPSIS - -I -I +B [{B<-p>|B<--path>} I] - -I +B [B<-h>|B<--help>] [B<-v>|B<--version>] =head1 DESCRIPTION -The restorexCATdb command restores the xCAT database tables from the directory given by the -p flag. +The restorexCATdb command restores the xCAT database tables from the directory given by the -p flag. =head1 OPTIONS B<-h> Display usage message. -B<-v> Command Version. +B<-v> Command Version. -B<-p> Path to the directory containing the database restore files. +B<-p> Path to the directory containing the database restore files. =head1 RETURN VALUE @@ -34,14 +31,14 @@ B<-p> Path to the directory containing the database restore files. =head1 EXAMPLES -1. To restore the xCAT database from the /tmp/db directory, enter: +1. To restore the xCAT database from the /tmp/db directory, enter: -I +B =head1 FILES - + /opt/xcat/sbin/restorexCATdb @@ -51,4 +48,4 @@ This command is part of the xCAT software product. See dumpxCATdb - + diff --git a/xCAT-client-2.0/pods/man1/rnetboot.1.pod b/xCAT-client-2.0/pods/man1/rnetboot.1.pod index bc1342224..57169960a 100644 --- a/xCAT-client-2.0/pods/man1/rnetboot.1.pod +++ b/xCAT-client-2.0/pods/man1/rnetboot.1.pod @@ -1,29 +1,28 @@ =head1 NAME -B - Will force an unattended network install for a range of nodes. +B - Cause the range of nodes to boot to network. =head1 SYNOPSIS -I +B [B<-V>|B<--verbose>] I -I - -I +B [B<-h>|B<--help>] [B<-v>|B<--version>] =head1 DESCRIPTION -The rnetboot command will force an unattended network install for a range of nodes. +The rnetboot command will do what is necessary to make each type of node in the given noderange +boot from the network. This is usually used to boot the nodes stateless or to network install +system p nodes. =head1 OPTIONS +B<-V> Verbose output. B<-h> Display usage message. B<-v> Command Version. -B<-V> Verbose output. - =head1 RETURN VALUE @@ -34,14 +33,10 @@ B<-V> Verbose output. =head1 EXAMPLES - rnetboot 1,3 - rnetboot 14-56,70-203 - rnetboot 1,3,14-56,70-203 - rnetboot all,-129-256 - - - - +B +B +B +B diff --git a/xCAT-client-2.0/pods/man8/mkrrnodes.8.pod b/xCAT-client-2.0/pods/man8/mkrrnodes.8.pod index d54dd5c5c..70ca3edbc 100644 --- a/xCAT-client-2.0/pods/man8/mkrrnodes.8.pod +++ b/xCAT-client-2.0/pods/man8/mkrrnodes.8.pod @@ -1,11 +1,11 @@ =head1 NAME -B - Adds or deletes nodes in the xCAT cluster database. +B - Sample tool for adding or deleting many nodes in the xCAT cluster database. =head1 SYNOPSIS -B [-d ]| [-C a|b|,...,r] -R [startrange,endrange] +B [B<-d> ]| [B<-C> I] B<-R> I B [B<-h> | B<--help>] @@ -13,13 +13,37 @@ B [B<-h> | B<--help>] =head1 DESCRIPTION -The mkrrnodes add or delete (-d) the nodes requested by inputting the CU name (-C) flag and the start and end range (-R) flag. It will also automatically define required nodegroups. +The B command is a sample tool that adds or deletes (-d) nodes according to a specific +naming convention. You can input the connected unit name (CU, a subset of the cluster, usually in its own +subnet and managed by an xCAT service node) using the -C flag, and you can input the start and end +range using the -R flag. It will also automatically define required nodegroups. + +In this example tool, the node names will have the format: + +BI + +where: + x is a-z, indicating the CU name + 048 is the node number within that CU + y is a-c, indicating which of 3 blades within the "triblade" group it is =head1 OPTIONS =over 10 +=item B<-C> I + +A single letter designating which CU (connected unit). + +=item B<-R> I + +The numeric start and end of the range of nodes to create. + +=item B<-d> + +Delete the nodes instead of adding them. + =item B<-h|--help> Display usage message.