mirror of
				https://github.com/xcat2/xcat-core.git
				synced 2025-10-24 16:05:41 +00:00 
			
		
		
		
	Added class b network support for compute nodes in xcatsetup
git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@7647 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
		| @@ -48,9 +48,21 @@ Run nodeset and rpower/rnetboot to boot up the nodes. | ||||
| =back | ||||
|  | ||||
| The B<xcatsetup> command is intended as a quick way to fill out the database for a cluster that has very regular | ||||
| naming patterns.  The only thing is done is fill in database attributes.  If your cluster does not follow consistent | ||||
| naming patterns.  The only thing it does is fill in database attributes.  If your cluster does not follow consistent | ||||
| naming patterns, or has some other special configuration, you should define attribute values manually instead of using | ||||
| B<xcatsetup>. | ||||
| B<xcatsetup>.  The cluster config file is meant to be an easy way to prime the database; it is not meant to be a | ||||
| long living file that you update as the cluster changes.  If you do want to run xcatsetup again at a later time, | ||||
| because, for example, you added a lot of nodes, you should put the total list of nodes in the config file, not just | ||||
| the new ones.  This is because xcatsetup uses some regular expressions for groups (e.g. frame, cec, compute) that would | ||||
| be calculated incorrectly if the config file told xcatsetup about only the new nodes. | ||||
|  | ||||
| Speaking of regular expressions, xcatsetup creates some pretty complicated regular expressions in the database. | ||||
| These are useful because they keep most of the tables small, even for large clusters.  But if you want to | ||||
| tweak them, they may be hard to understand.  If after running xcatsetup, you want to convert your database to | ||||
| use individual rows for every node, you can do the following: | ||||
|  | ||||
|   lsdef -z all >tmp.stanza | ||||
|   cat tmp.stanza | chdef -z | ||||
|  | ||||
| Note:  currently the B<xcatsetup> command has only been implemented and tested for system p servers. | ||||
|  | ||||
| @@ -123,7 +135,7 @@ in L<xcatstanzafile(5)|xcatstanzafile.5>.  Here is a sample file: | ||||
|     mtm=9A00-100 | ||||
|     side=A | ||||
|  | ||||
| The supernode-list file lists what supernode numbers should be given to each CEC in each frame. | ||||
| The B<supernode-list> file lists what supernode numbers should be given to each CEC in each frame. | ||||
| Here is a sample file: | ||||
|  | ||||
|   bpc01: 0, 1, 16 | ||||
|   | ||||
| @@ -556,7 +556,6 @@ sub writecompute { | ||||
| 	my $range = shift; | ||||
| 	infomsg('Defining compute nodes...'); | ||||
| 	my $nodes = [noderange($range, 0)]; | ||||
| 	my ($startnum) = $$nodes[0] =~/^\D+(\d+)$/;		# save this value for later | ||||
| 	if (scalar(@$nodes)) { | ||||
| 		$tables{'nodelist'}->setNodesAttribs($nodes, { groups => 'compute,all' }); | ||||
| 	} | ||||
| @@ -564,9 +563,14 @@ sub writecompute { | ||||
| 	# Write regex for: hosts.node, hosts.ip | ||||
| 	my $startip = $STANZAS{'xcat-lpars'}->{'compute-node-starting-ip'}; | ||||
| 	if ($startip) { | ||||
| 		my ($ipbase, $ipstart) = $startip =~/^(\d+\.\d+\.\d+)\.(\d+)$/; | ||||
| 		my ($ipbase, $ip3rd, $ip4th) = $startip =~/^(\d+\.\d+)\.(\d+)\.(\d+)$/; | ||||
| 		# take the number from the nodename, and as it increases, increase the ip addr | ||||
| 		my $regex = '|\D+(\d+)|' . "$ipbase.($ipstart+" . '$1' . "-$startnum)|"; | ||||
| 		my $nodehash = parsenoderange($range); | ||||
| 		my $startnum = $$nodehash{'primary-start'}; | ||||
| 		# Math for 4th field:  (ip4th-1+nodenum-startnum)%254 + 1 | ||||
| 		# Math for 3rd field:  (ip4th-1+nodenum-startnum)/254 + ip3rd | ||||
| 		my $regex = '|\D+(\d+)|' . "$ipbase.((${ip4th}-1+" . '$1' . "-$startnum)/254+$ip3rd).((${ip4th}-1+" . '$1' . "-$startnum)%254+1)|"; | ||||
| 		#my $regex = '|\D+(\d+)|' . "$ipbase.($ipstart+" . '$1' . "-$startnum)|"; | ||||
| 		my %hash = (ip => $regex); | ||||
| 		my $otherint = $STANZAS{'xcat-lpars'}->{'compute-node-otherinterfaces'}; | ||||
| 		if ($otherint) { | ||||
| @@ -574,8 +578,9 @@ sub writecompute { | ||||
| 			my @ifs = split(/[\s,]+/, $otherint); | ||||
| 			foreach my $if (@ifs) { | ||||
| 				my ($nic, $startip) = split(/:/, $if); | ||||
| 				($ipbase, $ipstart) = $startip =~/^(\d+\.\d+\.\d+)\.(\d+)$/; | ||||
| 				$if = "$nic:$ipbase.($ipstart+" . '$1' . "-$startnum)"; | ||||
| 				($ipbase, $ip3rd, $ip4th) = $startip =~/^(\d+\.\d+)\.(\d+)\.(\d+)$/; | ||||
| 				#$if = "$nic:$ipbase.($ipstart+" . '$1' . "-$startnum)"; | ||||
| 				$if = "$nic:$ipbase.((${ip4th}-1+" . '$1' . "-$startnum)/254+$ip3rd).((${ip4th}-1+" . '$1' . "-$startnum)%254+1)|"; | ||||
| 			} | ||||
| 			$regex = '|\D+(\d+)|' . join(',', @ifs) . '|'; | ||||
| 			#print "regex=$regex\n"; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user