-
Notifications
You must be signed in to change notification settings - Fork 174
Getmacs_and_rnetboot_enhancement
Table of Contents
{{:Design Warning}}
1. Getmacs
Syntax:
getmacs [-h| --help]
getmacs [-v| --version]
getmacs noderange [-F filter]
getmacs [-V| --verbose] noderange [-f][-d][-D [-S server] [-G gateway] [-C client]]
Description:
The output of getmacs has been changed in xCAT 2.3. Following is an example:
bash-3.2# getmacs xcat04,xcat05
xcat04:
#Type MAC_Address Phys_Port_Loc Adapter Port_Group Phys_Port Logical_Port VLan
VSwitch Curr_Conn_Speed
virtualio 7607DA0A1502 N/A N/A N/A N/A N/A 1 ETHERNET0 N/A
hea 00145EB55787 T6 23000014 1 N/A 5 N/A N/A 1000
xcat05:
#Type MAC_Address Phys_Port_Loc Adapter Port_Group Phys_Port Logical_Port VLan
VSwitch Curr_Conn_Speed
virtualio 7607DFB07F02 N/A N/A N/A N/A N/A 1 ETHERNET0 N/A
virtualio 7607DFB07F04 N/A N/A N/A N/A N/A 1 ETHERNET0 N/A
hea 00145EB55788 T6 23000014 1 N/A 6 N/A N/A 1000
hea 00145EB55790 T7 23000014 1 1 14 N/A N/A auto
The background for this output change is that before the change, getmacs will open a console for
each node and connect to open firmware of that node, dump all the adapters, read the mac address.
This way takes long time and introduce the performance issues especially in scaling cluster.
Now the way to get the mac address is that getmacs will connect to hmc and call lshwres on hmc
to read the mac addresses of the nodes that managed by this hmc. This way reduce lots of efforts
and time than before. The above output of getmacs is got from output of lshwres on hmc.
-F option provides the capability to users to specify some filters which could select the right
adapter user want. Following is an example of –F option:
bash-3.2# getmacs xcat05 -F Type=hea,Phys_Port_Loc=T6
xcat05:
#Type MAC_Address Phys_Port_Loc Adapter Port_Group Phys_Port Logical_Port VLan
VSwitch Curr_Conn_Speed
hea 00145EB55788 T6 23000014 1 N/A 6 N/A N/A 1000
You should find that only one adapter is found according to the filters specified by user and this
adapter will be written into xcat database.
BTW, for all the ouput of getmacs, the first adapter listed will be written into xcat database(of
course, if –d option provided, getmacs only display the mac addresses, no any adapter could be
written into database).
All the above explained the behavior of getmacs without any option and with –F option, next is
about the –D [-S server] [-G gateway] [-C client].
As always been complained before, getmacs doesn’t support ping test for multiple nodes, the old
way to do ping test was that: getmacs xcat05 –S 192.168.0.10 –G 192.168.0.10 –C 192.168.0.11.
User must specify all the network attributes for ping test, it means user can only specify one client
IP for one node in each ping test command.
Now the way to perform ping test can be anyone in the followings:
getmacs xcat04,xcat05 –D
getmacs xcat04,xcat05 –D –S 192.168.0.10
getmacs xcat04,xcat05 –D –G 192.168.0.10
getmacs xcat04,xcat05 –D –S 192.168.0.10 –G 192.168.0.10
-D option tells getmacs to do ping test, if no –S, -G or –C specified, getmacs will read these
attributes from xcat database and name server. So getmacs could support ping test for multiple
nodes now.
2. rnetboot
Syntax:
rnetboot <noderange> [-s net|hd] [-f] [-V|--verbose]
rnetboot [-h|--help|-v|--version]
Description:
The same as before, -f is to still to force lpar immediately shutdown(Specify –i option in
chsysstate command on hmc to that lpar).
-s net|hd is newly added. Before we added it, the work flow of rnetboot is that: 1. shutdown the
lpar, 2. boot the lpar to open firmware, 3. dump all the adapters, 4. do ping test to find the pingable
adapter, 5. boot from that adapter.
-s option didn’t change the workflow of rnetboot, but it added two actions. 1, if –s hd specified,
before boot the lpar to open firmware, boot the lpar to sms first and then switch to open firmware
mode. It is used to find the hard drives in sms(hard drive is the first hard drive of the node). 2.
between step (4) and (5), rnetboot will set the boot device order if user specified –s option, -s hd
means set first boot device to hard disk, -s net means set the first boot device to etnwork which is
used to boot the lpar in step (5), -s hd,net means set the first boot device to hard driver, and set the
second boot device to network. –s net,hd means set first boot device to network, second boot
device to hard drive.
We could get two benefits from this option:
1. rnetboot has performance issues in scaling cluster, because of the 5 steps that rnetboot did. If
we have –s option, the first time we can use rnetboot to boot the lpar, besides set the boot device,
so next time, user just need to use rpower to reboot the system(the boot device already been set in
rnetboot). rpower is much quicker than rnetbot, since it just needs to login to hmc, and call
chsysstat, don’t need to connect to hmc and dump the adapters and do ping test. This is much
helpful especially for diskless node which have to run rnetboot to reboot the system every time
before.
2. We have a thought that if lpar set to always boot from network, management node could also
control the boot method of the compute node with rpower command from bootp/dhcp response.
But we met one issue in this implementation on AIX, so I think don’t need to look into the details
now for it now.
Anyway, the new implemtation of rnetboot with –s option should help the performance in scaling
cluster for diskless nodes, in some case, helpful for diskful node.
Interface change and UX impact:
a. for getmacs command, add --arp option to indicate user wants to use apr protocal to get the mac address.
--arp cannot exist with -D option since -D is used to do ping test.
Code change:
a. check if the options are valid or not. --arp cannot exit with -D
b. if arp specified, in PPC.pm, do:
ping all the nodes, and use apr command to read the mac address.
Interface change and UX impact:
None
Code change:
a. in PPC.pm, add signal handler.
b. in PPCmac.pm and PPCboot.pm, add signal handler (lpar_netboot).
c. in lpar_netboot.expect, add signal handler to kill the spawned processes(hmc).
d. makeconservercf should kill all the hmc connections first since makeconservercf is supposed to initialize all the connections.
- Nov 13, 2024: xCAT 2.17 released.
- Mar 08, 2023: xCAT 2.16.5 released.
- Jun 20, 2022: xCAT 2.16.4 released.
- Nov 17, 2021: xCAT 2.16.3 released.
- May 25, 2021: xCAT 2.16.2 released.
- Nov 06, 2020: xCAT 2.16.1 released.
- Jun 17, 2020: xCAT 2.16 released.
- Mar 06, 2020: xCAT 2.15.1 released.
- Nov 11, 2019: xCAT 2.15 released.
- Mar 29, 2019: xCAT 2.14.6 released.
- Dec 07, 2018: xCAT 2.14.5 released.
- Oct 19, 2018: xCAT 2.14.4 released.
- Aug 24, 2018: xCAT 2.14.3 released.
- Jul 13, 2018: xCAT 2.14.2 released.
- Jun 01, 2018: xCAT 2.14.1 released.
- Apr 20, 2018: xCAT 2.14 released.
- Mar 14, 2018: xCAT 2.13.11 released.
- Jan 26, 2018: xCAT 2.13.10 released.
- Dec 18, 2017: xCAT 2.13.9 released.
- Nov 03, 2017: xCAT 2.13.8 released.
- Sep 22, 2017: xCAT 2.13.7 released.
- Aug 10, 2017: xCAT 2.13.6 released.
- Jun 30, 2017: xCAT 2.13.5 released.
- May 19, 2017: xCAT 2.13.4 released.
- Apr 14, 2017: xCAT 2.13.3 released.
- Feb 24, 2017: xCAT 2.13.2 released.
- Jan 13, 2017: xCAT 2.13.1 released.
- Dec 09, 2016: xCAT 2.13 released.
- Dec 06, 2016: xCAT 2.9.4 (AIX only) released.
- Nov 11, 2016: xCAT 2.12.4 released.
- Sep 30, 2016: xCAT 2.12.3 released.
- Aug 19, 2016: xCAT 2.12.2 released.
- Jul 08, 2016: xCAT 2.12.1 released.
- May 20, 2016: xCAT 2.12 released.
- Apr 22, 2016: xCAT 2.11.1 released.
- Mar 11, 2016: xCAT 2.9.3 (AIX only) released.
- Dec 11, 2015: xCAT 2.11 released.
- Nov 11, 2015: xCAT 2.9.2 (AIX only) released.
- Jul 30, 2015: xCAT 2.10 released.
- Jul 30, 2015: xCAT migrates from sourceforge to github
- Jun 26, 2015: xCAT 2.7.9 released.
- Mar 20, 2015: xCAT 2.9.1 released.
- Dec 12, 2014: xCAT 2.9 released.
- Sep 5, 2014: xCAT 2.8.5 released.
- May 23, 2014: xCAT 2.8.4 released.
- Jan 24, 2014: xCAT 2.7.8 released.
- Nov 15, 2013: xCAT 2.8.3 released.
- Jun 26, 2013: xCAT 2.8.2 released.
- May 17, 2013: xCAT 2.7.7 released.
- May 10, 2013: xCAT 2.8.1 released.
- Feb 28, 2013: xCAT 2.8 released.
- Nov 30, 2012: xCAT 2.7.6 released.
- Oct 29, 2012: xCAT 2.7.5 released.
- Aug 27, 2012: xCAT 2.7.4 released.
- Jun 22, 2012: xCAT 2.7.3 released.
- May 25, 2012: xCAT 2.7.2 released.
- Apr 20, 2012: xCAT 2.7.1 released.
- Mar 19, 2012: xCAT 2.7 released.
- Mar 15, 2012: xCAT 2.6.11 released.
- Jan 23, 2012: xCAT 2.6.10 released.
- Nov 15, 2011: xCAT 2.6.9 released.
- Sep 30, 2011: xCAT 2.6.8 released.
- Aug 26, 2011: xCAT 2.6.6 released.
- May 20, 2011: xCAT 2.6 released.
- Feb 14, 2011: Watson plays on Jeopardy and is managed by xCAT!
- xCAT OS And Hw Support Matrix
- Oct 22, 2010: xCAT 2.5 released.
- Apr 30, 2010: xCAT 2.4 is released.
- Oct 31, 2009: xCAT 2.3 released. xCAT's 10 year anniversary!
- Apr 16, 2009: xCAT 2.2 released.
- Oct 31, 2008: xCAT 2.1 released.
- Sep 12, 2008: Support for xCAT 2 can now be purchased!
- June 9, 2008: xCAT breaths life into (at the time) the fastest supercomputer on the planet
- May 30, 2008: xCAT 2.0 for Linux officially released!
- Oct 31, 2007: IBM open sources xCAT 2.0 to allow collaboration among all of the xCAT users.
- Oct 31, 1999: xCAT 1.0 is born!
xCAT started out as a project in IBM developed by Egan Ford. It was quickly adopted by customers and IBM manufacturing sites to rapidly deploy clusters.