=head1 NAME B - Create profiled nodes by importing hostinfo file. =head1 SYNOPSIS B [-h| --help | -v | --version] B file= networkprofile= imageprofile= hostnameformat= [hardwareprofile=] [groups=] =head1 DESCRIPTION The B command creates nodes by importing a hostinfo file which is following stanza format. In this hostinfo file, we can define node's hostname, ip, mac, switch name, switch port and host location infomation like rack, chassis, start unit, server height...etc After nodes imported, the configuration files related with these nodes will be updated automatically. For example: /etc/hosts, dns configuration, dhcp configuration. And the kits node plugins will also be triggered automatically to update kit related configuration/services. =head1 OPTIONS B<-h|--help> Display usage message. B<-v|--version> Command Version. B> Specifies the node information file, where is the full path and file name of the node information file. B> Sets the new image profile name used by the node, where is the new image profile. An image profile defines the provisioning method, OS information, kit information, and provisioning parameters for a node. If the "__ImageProfile_imgprofile" group already exists in the nodehm table, then "imgprofile" is used as the image profile name. B> Sets the new network profile name used by the node, where is the new network profile. A network profile defines the network, NIC, and routes for a node. If the "__NetworkProfile_netprofile" group already exists in the nodehm table, then "netprofile" is used as the network profile name. B> Sets the new hardware profile name used by the node, where is the new hardware management profile used by the node. If a "__HardwareProfile_hwprofile" group exists, then "hwprofile" is the hardware profile name. A hardware profile defines hardware management related information for imported nodes, including: IPMI, HMC, CEC, CMM. B> Sets the node name format for all nodes discovered, where is a supported format. The two types of formats supported are prefix#NNNappendix and prefix#RRand#NNappendix, where wildcard #NNN and #NN are replaced by a system generated number that is based on the provisioning order. Wildcard #RR represents the rack number and stays constant. For example, if the node name format is compute-#NN, the node name is generated as: compute-00, compute-01, ... , compute-99. If the node name format is blade#NNN-x64, the node name is generated as: blade001-x64, blade002-x64, ... , blade999-x64 For example, if the node name format is compute-#RR-#NN and the rack number is 2, the node name is generated as: compute-02-00, compute-02-01, ..., compute-02-99. If node name format is node-#NN-in-#RR and rack number is 1, the node name is generated as: node-00-in-01, node-01-in-01, ... , node-99-in-01 B> Sets the node groups that the imported node belongs to, where is a comma-separated list of node groups. =head1 RETURN VALUE 0 The command completed successfully. 1 An error has occured while validating parameters. 2 An error has occured while parsing hostinfo file. =head1 EXAMPLES To import nodes using a profile, follow the following steps: 1. Find all node groups and profiles, run the following command "tabdump nodegroups". For detailed profile information run "lsdef -t group ". Example of detailed profile information: # tabdump nodegroup #groupname,grouptype,members,membergroups,wherevals,comments,disable "compute","static",,,,, "__HardwareProfile_default_ipmi","static","static",,,, "__NetworkProfile_default_mn","static","static",,,, "__NetworkProfile_default_cn","static",,,,, "__ImageProfile_rhels6.2-x86_64-install-compute","static","static",,,, # lsdef -t group __NetworkProfile_default_cn Object name: __NetworkProfile_default_cn grouptype=static installnic=eth0 members=compute-000,compute-001 netboot=xnba nichostnamesuffixes=eth0:-eth0 nicnetworks=eth0:provision nictypes=eth0:Ethernet primarynic=eth0 2. Prepare a node information file. Example of a node information file, a blade and a rack server defined: # hostinfo begin # This entry defines a blade. __hostname__: mac=b8:ac:6f:37:59:24 ip=192.168.1.20 chassis=chassis01 # This entry defines a rack server. __hostname__: mac=b8:ac:6f:37:59:25 ip=192.168.1.20 rack=rack01 height=1 unit=2 # hostinfo end. Another example of a node infomation file, a PureFlex X/P node defined: # hostinfo begin # To define a PureFlex P/X node, chassis and slot id must be specified. # The chassis must be a PureFlex chassis. __hostname__: mac=b8:ac:6f:37:59:25 chassis=cmm01 slotid=1 # hostinfo end. Example of a node information file, a switch auto discovery node defined: # hostinfo begin # This entry defines a blade. __hostname__: switches=eth0!switch1!1,eth0!switch2!1!eth1 Example of a node information file that specifies a CEC-based rack-mounted Power node that uses direct FSP management: # Node information file begins # This entry defines a Power rack-mount node. __hostname__: mac=b8:ac:6f:37:59:28 cec=mycec # Node information file ends. The node information file includes the following items: B<__hostname__:> This is a mandatory item. Description: The name of the node, where __hostname__ is automatically generated by the node name format. You can also input a fixed node name, for example “compute-node”. B> This is a mandatory item. Description: Specify the MAC address for the NIC used by the provisionging node, where is the NICs MAC address. B> This is a mandatory item, when define switch, switchport and node nic name relationship. Description: Specify nic name, switch name and switch port to define node and switch relationship. We can define multi nic-switch-port relations here, looks like: switches=eth0!switch1!1,eth1!switch1,2 B> This is a mandatory item while define a PureFlex node. Description: The node position in the PureFlex Chassis. B> This is a mandatory option for defining Power rack-mounted nodes. Description: Specifies the name of a Power rack-mount central electronic complex (CEC). B> This is an optional item. Description: Specify the IP address used for provisioning a node, where is in the form xxx.xxx.xxx.xxx. If this item is not included, the IP address used to provision the node is generated automatically according to the Network Profile used by the node. B> This is an optional item. Description: Lists the IP address for each network interface configuration (NIC) used by the node, excluding the provisioning network, where is in the form !,!,.... For example, if you have 2 network interfaces configured, the nicips attribute should list both network interfaces: nicips=eth1!10.10.10.11,bmc!192.168.10.3. If the nicips attribute is not specified, the IP addresses are generated automatically according to the network profile. B> This is an optional item. Description: node location info. Specify the rack name which this node will be placed into. If not specify this item, there will be no node location info set for this node. this item must be specified together with height + unit. B> This is an optional item. Description: node location info, for blade(or PureFlex) only. Specify the chasiss name which this blade will be placed into. this item can not be specified together with rack. B> This is an optional item. Description: node location info, for rack server only. Specify the server height number, in U. this item must be specified together with rack and unit. B> This is an optional item. Description: node location info, for rack server only. Specify the node's start unit number in rack, in U. this item must be specified together with rack and height. 3. Import the nodes, by using the following commands. Note: If we want to import PureFlex X/P nodes, hardware profile must be set to a PureFlex hardware type. nodeimport file=/root/hostinfo.txt networkprofile=default_cn imageprofile=rhels6.3_packaged hostnameformat=compute-#NNN 4. After importing the nodes, the nodes are created and all configuration files used by the nodes are updated, including: /etc/hosts, DNS, DHCP. 5. Reboot the nodes. After the nodes are booted they are provisioned automatically. =head1 SEE ALSO L, L, L