lpar2rrd
VP-to-entitlement ratio
Ideally the ratio should be 2.5 or less. Anything above 4.0 is performance unfriendly, especially on multi-node systems (770 and above).
How to estimate the number of virtual processors per uncapped shared LPAR:
The first step would be to monitor the utilization of each partition and for any partition where the average utilization is ~100%, then add one virtual )processors. (use capacity of the already configured virtual processors before adding more
If the peak utilization is well below 50%, then look at the ratio of virtual processors to configured entitlement and if the ratio is > 1, then consider reducing the ratio. (In any case if there are too many virtual processors configured, AIX can “fold” those processors.)
AIX monitors the utilization of each virtual processor and the utilization of an PLPAR, and if utilization goes below 50%, AIX will start folding down the virtual CPUs so that fewer virtual CPUs will be dispatched. (If utilization goes beyond 50% AIX starts unfolding virtual CPUs.)
Considerations for Virtual Processor (VP) and Entitled Capacity:
- Lpars that require high performance (such as critical database) can be forced to get the best resources by activating the critical LPAR first prior to activating any other LPARs including VIO Server.
- The best practice for LPAR entitlement would be setting entitlement close to average utilization and let the peak addressed by additional uncapped capacity. (exceptions could be LPARs with higher priority)
- For each shared LPAR the number of VPs must be less than (or equal) to the number of cores of the shared pool
- Shared uncapped LPARS with too low VPs will not cover Production Need (VP number is a limit for uncapped LPARs)
- When AIX folding is turned off it can happen that PhysC (physical cores used) is high, but AIX shows high percentage of idle time. (This is because unused Virtual Processors are also assigned to cores, but they are not doing any work at all.)
Checking how many Virtual Processors are active:
root@bb_lpar:/ # lparstat -i | grep Virt Online Virtual CPUs : 2 <--we have 2 virtual processors configured Maximum Virtual CPUs : 8 Minimum Virtual CPUs : 1 Desired Virtual CPUs : 2 root@bb_lpar:/ # bindprocessor -q The available processors are: 0 1 2 3 4 5 6 7 <--this shows smt=4 active (4 threads/virtual processor) root@bb_lpar:/ # echo vpm | kdb ... 0 0 ACTIVE 0 AWAKE 0000000000000000 00000000 00 1 0 ACTIVE 0 AWAKE 0000000000000000 00000000 00 2 0 ACTIVE 0 AWAKE 0000000000000000 00000000 00 3 0 ACTIVE 0 AWAKE 0000000000000000 00000000 00 4 0 DISABLED 0 AWAKE 0000000000000000 00000000 00 <--4 lines are DISABLED, so 1 Virt. proc. is inactive (folding) 5 11 DISABLED 0 SLEEPING 00000000515B4478 29DBE3CA 02 6 11 DISABLED 0 SLEEPING 00000000515B4477 2C029174 02 7 11 DISABLED 0 SLEEPING 00000000515B4477 2C0292A1 02
SMT
threads = VP x (SMT threads par processeur) = logical CPUs
Soit la partoche ci-dessous :
root@partoche:/root # lparstat -i |grep Virtual Online Virtual CPUs : 3 Maximum Virtual CPUs : 6 Minimum Virtual CPUs : 1 Desired Virtual CPUs : 3
root@partoche:/root # smtctl This system is SMT capable. This system supports up to 4 SMT threads per processor. SMT is currently enabled. SMT boot mode is not set. SMT threads are bound to the same virtual processor. proc0 has 4 SMT threads. Bind processor 0 is bound with proc0 Bind processor 1 is bound with proc0 Bind processor 2 is bound with proc0 Bind processor 3 is bound with proc0 proc4 has 4 SMT threads. Bind processor 4 is bound with proc4 Bind processor 5 is bound with proc4 Bind processor 6 is bound with proc4 Bind processor 7 is bound with proc4 proc8 has 4 SMT threads. Bind processor 8 is bound with proc8 Bind processor 9 is bound with proc8 Bind processor 10 is bound with proc8 Bind processor 11 is bound with proc8
Topas Monitor for host: partoche EVENTS/QUEUES FILE/TTY Fri Nov 27 15:50:05 2015 Interval: 2 Cswitch 1323 Readch 1815.1K Syscall 4913 Writech 612.6K CPU User% Kern% Wait% Idle% Physc Reads 574 Rawin 0 0 81.9 16.7 1.2 0.2 0.41 Writes 363 Ttyout 356 2 0.0 1.0 0.0 99.0 0.08 Forks 6 Igets 0 3 0.0 1.0 0.0 99.0 0.08 Execs 7 Namei 469 4 0.0 43.4 0.0 56.6 0.00 Runqueue 1.0 Dirblk 0 5 0.0 31.7 0.0 68.3 0.00 Waitqueue 0.0 1 0.0 0.9 0.0 99.1 0.08 MEMORY 6 0.0 0.3 0.0 99.7 0.00 PAGING Real,MB 24576 11 0.0 0.0 0.0 100.0 0.01 Faults 1554 % Comp 90 7 0.0 0.3 0.0 99.7 0.00 Steals 0 % Noncomp 1 8 0.0 74.6 0.0 25.4 0.01 PgspIn 0 % Client 1 9 0.0 2.3 0.0 97.7 0.01 PgspOut 0 10 0.0 0.0 0.0 100.0 0.01 PageIn 0 PAGING SPACE PageOut 0 Size,MB 25600 Network KBPS I-Pack O-Pack KB-In KB-Out Sios 0 % Used 2 Total 218.6 346.0 329.9 92.1 126.5 % Free 98 NFS (calls/sec) Disk Busy% KBPS TPS KB-Read KB-Writ SerV2 0 WPAR Activ 0 Total 2.4 2126.9 226.0 1640.6 486.4 CliV2 0 WPAR Total 0 SerV3 0 Press: "h"-help FileSystem KBPS TPS KB-Read KB-Writ CliV3 0 "q"-quit Total 2.2K 331.3 1.7K 486.3 SerV4 0 CliV4 0 Name PID CPU% PgSp Owner oracle 9830502 15.1 6.7 orair3 oracle 14483686 13.9 14.0 orair3 oracle 26411184 10.0 10.6 orair3 oracle 6684822 8.6 6.7 orair3 enserver 29425668 1.3 56.3 ir3adm oracle 16580828 0.6 26.8 ir3adm oracle 27132004 0.4 8.0 ir3adm bgscolle 11403318 0.2 3.3 bmcpor sapstart 16187400 0.2 22.3 ir3adm init 1 0.1 0.8 root PatrolAg 8454164 0.0 15.7 patrol syncd 3211376 0.0 0.6 root lrud 262152 0.0 0.6 root gil 1769526 0.0 0.9 root getty 4194474 0.0 0.6 root nfssync_ 3604592 0.0 0.7 root random 4587558 0.0 0.4 root vmmd 458766 0.0 0.8 root nfsd 4915360 0.0 1.8 root bdaemon 7471354 0.0 1.8 root