Supermicro Hyper A+ Server AS -2126HS-TN 927637 SPECjbb2015-MultiJVM max-jOPS
493566 SPECjbb2015-MultiJVM critical-jOPS
Tested by: Supermicro Test Sponsor: Supermicro Test location: San Jose, California Test date: September 10, 2024
SPEC license #: 001176 Hardware Availability: Oct-2024 Software Availability: Jul-2024 Publication: Thu Oct 10 13:03:35 EDT 2024
Benchmark Results Summary
 
Overall Throughput RT curve
Overall SUT (System Under Test) Description
VendorSupermicro
Vendor URLhttps://www.supermicro.com
System SourceSingle Supplier
System DesignationServer Rack
Total Systems1
All SUT Systems IdenticalYES
Total Nodes1
All Nodes IdenticalYES
Nodes Per System1
Total Chips2
Total Cores192
Total Threads384
Total Memory Amount (GB)1536
Total OS Images1
SW EnvironmentNon-virtual
 
Hardware hw_1
NameHyper A+ Server AS -2126HS-TN
VendorSupermicro
Vendor URLhttps://www.supermicro.com
AvailableOct-2024
ModelH14DSH
Form Factor2U
CPU NameAMD EPYC 9655
CPU Characteristics96 core, 2.6GHz, 384MB L3 Cache (Max. Boost Clock up to 4.5GHz)
Number of Systems1
Nodes Per System1
Chips Per System2
Cores Per System192
Cores Per Chip96
Threads Per System384
Threads Per Core2
Version1.1 08/28/2024
CPU Frequency (MHz)2600
Primary Cache32KB(I)+48KB(D) per core
Secondary Cache1MB (I+D) per core
Tertiary Cache384MB (I+D) on chip per chip
Other CacheNone
Disk1 x 3.84 TB NVMe PCIe Gen5.0
File Systembtrfs
Memory Amount (GB)1536
# and size of DIMM(s)24 x 64GB
Memory Details64GB 2Rx4 DDR5 RDIMM 6400 MHz, running at 6000 MHz.
# and type of Network Interface Cards (NICs)1 x 1 GbE NIC
Power Supply Quantity and Rating (W)2 x 1600w
Other HardwareNone
Cabinet/Housing/EnclosureNone
Shared DescriptionNone
Shared CommentNone
Notes
  • NA: The test sponsor attests, as of date of publication, that CVE-2017-5754 (Meltdown) is mitigated in the system as tested and documented.
  • Yes: The test sponsor attests, as of date of publication, that CVE-2017-5753 (Spectre variant 1) is mitigated in the system as tested and documented.
  • Yes: The test sponsor attests, as of date of publication, that CVE-2017-5715 (Spectre variant 2) is mitigated in the system as tested and documented.
Other Hardware network_1
NameNone
VendorNone
Vendor URLNone
VersionNone
AvailableNone
BitnessNone
NotesNone
Operating System os_1
NameSUSE Linux Enterprise Server 15 SP6
VendorSUSE
Vendor URLhttp://suse.com/
Version6.4.0-150600.23.17-default
AvailableJun-2024
Bitness64
NotesNone
Java Virtual Machine jvm_1
NameOracle Java SE 22.0.2
VendorOracle
Vendor URLhttp://oracle.com/
VersionJava HotSpot 64-bit Server VM, version 22.0.2
AvailableJul-2024
Bitness64
NotesNone
Other Software other_1
NameNone
VendorNone
Vendor URLNone
VersionNone
AvailableNone
BitnessNone
NotesNone
Hardware
OS Images os_Image_1(1)
Hardware Description hw_1
Number of Systems 1
SW Environment non-virtual
Tuning

BIOS Settings:

  • NUMA nodes per socket = NPS4
  • Determinism Control = Manual
  • Determinism Enable = Power
  • xGMI Link Configuration = 4 xGMI Links
  • 4 Link xGMI max speed = 32Gbps
  • TDP Control = Manual
  • TDP = 400
  • Package Power Limit Control = Manual
  • Package Power Limit = 400

Notes None
OS Image os_Image_1
JVM Instances jvm_Ctr_1(1), jvm_Backend_1(24), jvm_TxInjector_1(24)
OS Image Description os_1
Tuning

  • cpupower -c all frequency-set -g performance
  • tuned-adm profile throughput-performance
  • ulimit -n 1024000

  • echo 960000 > /proc/sys/kernel/sched_rt_runtime_us
  • echo 800000000 > /proc/sys/kernel/sched_latency_ns
  • echo 40000 > /proc/sys/kernel/sched_migration_cost_ns
  • echo 910000000 > /proc/sys/kernel/sched_min_granularity_ns
  • echo 2000000 > /proc/sys/kernel/sched_wakeup_granularity_ns
  • echo 9000 > /proc/sys/kernel/sched_nr_migrate
  • echo 10000 > /proc/sys/vm/dirty_expire_centisecs
  • echo 1500 > /proc/sys/vm/dirty_writeback_centisecs
  • echo 40 > /proc/sys/vm/dirty_ratio
  • echo 10 > /proc/sys/vm/dirty_background_ratio
  • echo 10 > /proc/sys/vm/swappiness
  • echo 0 > /proc/sys/kernel/numa_balancing
  • echo 0 > /proc/sys/vm/numa_stat
  • echo always > /sys/kernel/mm/transparent_hugepage/enabled
  • echo always > /sys/kernel/mm/transparent_hugepage/defrag

Notes None
JVM Instance jvm_Ctr_1
Parts of Benchmark Controller
JVM Instance Description jvm_1
Command Line

-Xms3g -Xmx3g -Xmn2g -XX:+UseParallelGC -XX:ParallelGCThreads=1 -XX:CICompilerCount=2

Tuning

Used numactl to interleave memory on all CPUs

  • numactl --interleave=all

Notes None
JVM Instance jvm_Backend_1
Parts of Benchmark Backend
JVM Instance Description jvm_1
Command Line

-Xms31g -Xmx31g -Xmn29g -XX:AllocatePrefetchInstr=2 -XX:+UseParallelGC -XX:ParallelGCThreads=16 -XX:LargePageSizeInBytes=2m -XX:-UseAdaptiveSizePolicy -XX:+AlwaysPreTouch -XX:+UseLargePages -XX:SurvivorRatio=12 -XX:TargetSurvivorRatio=95 -XX:MaxTenuringThreshold=15 -XX:InlineSmallCode=11k -XX:MaxGCPauseMillis=100 -XX:LoopUnrollLimit=200 -XX:+UseTransparentHugePages -XX:TLABAllocationWeight=2 -XX:ThreadStackSize=140 -XX:CompileThresholdScaling=120 -XX:CICompilerCount=4 -XX:AutoBoxCacheMax=32 -XX:OnStackReplacePercentage=100 -XX:TLABSize=1m -XX:MinTLABSize=1m -XX:-ResizeTLAB -XX:TLABWasteTargetPercent=1 -XX:TLABWasteIncrement=1 -XX:YoungPLABSize=1m -XX:OldPLABSize=1m

Tuning

Used numactl to affinitize each Backend JVM to 8 Core / 16 Threads

  • Group1: --physcpubind=0-7,192-199 --localalloc
  • Group2: --physcpubind=8-15,200-207 --localalloc
  • Group3: --physcpubind=16-23,208-215 --localalloc
  • Group4: --physcpubind=24-31,216-223 --localalloc
  • Group5: --physcpubind=32-39,224-231 --localalloc
  • Group6: --physcpubind=40-47,232-239 --localalloc
  • Group7: --physcpubind=48-55,240-247 --localalloc
  • Group8: --physcpubind=56-63,248-255 --localalloc
  • Group9: --physcpubind=64-71,256-263 --localalloc
  • Group10: --physcpubind=72-79,264-271 --localalloc
  • Group11: --physcpubind=80-87,272-279 --localalloc
  • Group12: --physcpubind=88-95,280-287 --localalloc
  • Group13: --physcpubind=96-103,288-295 --localalloc
  • Group14: --physcpubind=104-111,296-303 --localalloc
  • Group15: --physcpubind=112-119,304-311 --localalloc
  • Group16: --physcpubind=120-127,312-319 --localalloc
  • Group17: --physcpubind=128-135,320-327 --localalloc
  • Group18: --physcpubind=136-143,328-335 --localalloc
  • Group19: --physcpubind=144-151,336-343 --localalloc
  • Group20: --physcpubind=152-159,344-351 --localalloc
  • Group21: --physcpubind=160-167,352-359 --localalloc
  • Group22: --physcpubind=168-175,360-367 --localalloc
  • Group23: --physcpubind=176-183,368-375 --localalloc
  • Group24: --physcpubind=184-191,376-383 --localalloc

Notes None
JVM Instance jvm_TxInjector_1
Parts of Benchmark TxInjector
JVM Instance Description jvm_1
Command Line

-Xms3g -Xmx3g -Xmn2g -XX:+UseParallelGC -XX:ParallelGCThreads=1 -XX:CICompilerCount=2

Tuning

Used numactl to affinitize each Transaction Injector JVM to 8 Core / 16 Threads

  • Group1: --physcpubind=0-7,192-199 --localalloc
  • Group2: --physcpubind=8-15,200-207 --localalloc
  • Group3: --physcpubind=16-23,208-215 --localalloc
  • Group4: --physcpubind=24-31,216-223 --localalloc
  • Group5: --physcpubind=32-39,224-231 --localalloc
  • Group6: --physcpubind=40-47,232-239 --localalloc
  • Group7: --physcpubind=48-55,240-247 --localalloc
  • Group8: --physcpubind=56-63,248-255 --localalloc
  • Group9: --physcpubind=64-71,256-263 --localalloc
  • Group10: --physcpubind=72-79,264-271 --localalloc
  • Group11: --physcpubind=80-87,272-279 --localalloc
  • Group12: --physcpubind=88-95,280-287 --localalloc
  • Group13: --physcpubind=96-103,288-295 --localalloc
  • Group14: --physcpubind=104-111,296-303 --localalloc
  • Group15: --physcpubind=112-119,304-311 --localalloc
  • Group16: --physcpubind=120-127,312-319 --localalloc
  • Group17: --physcpubind=128-135,320-327 --localalloc
  • Group18: --physcpubind=136-143,328-335 --localalloc
  • Group19: --physcpubind=144-151,336-343 --localalloc
  • Group20: --physcpubind=152-159,344-351 --localalloc
  • Group21: --physcpubind=160-167,352-359 --localalloc
  • Group22: --physcpubind=168-175,360-367 --localalloc
  • Group23: --physcpubind=176-183,368-375 --localalloc
  • Group24: --physcpubind=184-191,376-383 --localalloc

Notes None
max-jOPS = jOPS passed before the First Failure
Pass/Fail Pass Pass Pass Fail Fail
jOPS 907900 917769 927637 937506 947374
critical-jOPS = Geomean ( jOPS @ 10000; 25000; 50000; 75000; 100000; SLAs )
Response time percentile is 99-th
SLA (us) 10000 25000 50000 75000 100000 Geomean
jOPS 319081 420397 547700 616780 646385 493566
  Percentile
  10-th 50-th 90-th 95-th 99-th 100-th
500us 19737 / 29605 - / 9868 - / 9868 - / 9868 - / 9868 - / 9868
1000us 187501 / 197370 39474 / 49342 - / 9868 - / 9868 - / 9868 - / 9868
5000us 759873 / 769741 542766 / 552635 226975 / 236844 217107 / 226975 187501 / 197370 19737 / 29605
10000us 779610 / 789478 730268 / 740136 601977 / 611846 523029 / 532898 325660 / 305923 19737 / 29605
25000us 789478 / 799347 759873 / 769741 671057 / 680925 621714 / 631583 444082 / 404608 19737 / 29605
50000us 799347 / 809215 769741 / 779610 710531 / 720399 680925 / 671057 562503 / 532898 19737 / 29605
75000us 809215 / 819084 779610 / 789478 740136 / 750004 710531 / 720399 641451 / 592109 19737 / 29605
100000us 819084 / 828952 789478 / 799347 759873 / 769741 740136 / 750004 661188 / 631583 138159 / 59211
200000us 858558 / 868426 809215 / 819084 789478 / 799347 769741 / 779610 759873 / 720399 542766 / 148027
500000us 917769 / 927637 878295 / 888163 838821 / 848689 828952 / 838821 819084 / 828952 621714 / 305923
1000000us 927637 / - 917769 / 927637 898032 / 907900 898032 / 907900 878295 / 888163 789478 / 305923
Probes jOPS / Total jOPS
Request Mix Accuracy
Note
(Actual % in the Mix - Expected % in the Mix) must be within:
'Main Tx' limit of +/-5.0% for the requests whose expected % in the mix is >= 10.0%
'Minor Tx' limit of +/-1.0% for the requests whose expected % in the mix is < 10.0%
There were no non-critical failures in Response Time curve building
Delay between status pings
IR/PR Accuracy
This section lists properties only set by user
Property Name Default Controller Group1.Backend.beJVM Group1.TxInjector.txiJVM1 Group10.Backend.beJVM Group10.TxInjector.txiJVM1 Group11.Backend.beJVM Group11.TxInjector.txiJVM1 Group12.Backend.beJVM Group12.TxInjector.txiJVM1 Group13.Backend.beJVM Group13.TxInjector.txiJVM1 Group14.Backend.beJVM Group14.TxInjector.txiJVM1 Group15.Backend.beJVM Group15.TxInjector.txiJVM1 Group16.Backend.beJVM Group16.TxInjector.txiJVM1 Group17.Backend.beJVM Group17.TxInjector.txiJVM1 Group18.Backend.beJVM Group18.TxInjector.txiJVM1 Group19.Backend.beJVM Group19.TxInjector.txiJVM1 Group2.Backend.beJVM Group2.TxInjector.txiJVM1 Group20.Backend.beJVM Group20.TxInjector.txiJVM1 Group21.Backend.beJVM Group21.TxInjector.txiJVM1 Group22.Backend.beJVM Group22.TxInjector.txiJVM1 Group23.Backend.beJVM Group23.TxInjector.txiJVM1 Group24.Backend.beJVM Group24.TxInjector.txiJVM1 Group3.Backend.beJVM Group3.TxInjector.txiJVM1 Group4.Backend.beJVM Group4.TxInjector.txiJVM1 Group5.Backend.beJVM Group5.TxInjector.txiJVM1 Group6.Backend.beJVM Group6.TxInjector.txiJVM1 Group7.Backend.beJVM Group7.TxInjector.txiJVM1 Group8.Backend.beJVM Group8.TxInjector.txiJVM1 Group9.Backend.beJVM Group9.TxInjector.txiJVM1
specjbb.comm.connect.client.pool.size 256 128
specjbb.comm.connect.selector.runner.count 0 5
specjbb.comm.connect.timeouts.connect 60000 900000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000
specjbb.comm.connect.timeouts.read 60000 800000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000
specjbb.comm.connect.timeouts.write 60000 800000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000 60000
specjbb.comm.connect.worker.pool.max 256 120
specjbb.comm.connect.worker.pool.min 1 16 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32 32
specjbb.controller.maxir.maxFailedPoints 3 1
specjbb.customerDriver.threads 64 {probe=120, saturate=120, service=70}
specjbb.forkjoin.workers 384 {Tier1=260, Tier2=15, Tier3=25}
specjbb.group.count 1 24
specjbb.mapreducer.pool.size 384 5
specjbb.txi.pergroup.count 1 1
View table in csv format
 
Level: COMPLIANCE
Check Agent Result
Check properties on compliance All PASSED
 
Level: CORRECTNESS
Check Agent Result
Compare SM and HQ Inventory All PASSED
High-bound (max attempted) is 986848 IR
High-bound (settled) is 967652 IR