Supermicro Hyper A+ Server AS -2126HS-TN 624803 SPECjbb2015-MultiJVM max-jOPS
366212 SPECjbb2015-MultiJVM critical-jOPS
Tested by: Supermicro Test Sponsor: Supermicro Test location: San Jose, California Test date: September 27, 2024
SPEC license #: 001176 Hardware Availability: Oct-2024 Software Availability: Jul-2024 Publication: Thu Oct 17 11:43:39 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 Chips1
Total Cores192
Total Threads384
Total Memory Amount (GB)768
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 9965
CPU Characteristics192 core, 2.25GHz, 384MB L3 Cache (Max. Boost Clock up to 3.7GHz)
Number of Systems1
Nodes Per System1
Chips Per System1
Cores Per System192
Cores Per Chip192
Threads Per System384
Threads Per Core2
Version1.1 09/09/2024
CPU Frequency (MHz)2250
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)768
# and size of DIMM(s)12 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
  • TDP Control = Manual
  • TDP = 500
  • Package Power Limit Control = Manual
  • Package Power Limit = 500

Notes None
OS Image os_Image_1
JVM Instances jvm_Ctr_1(1), jvm_Backend_1(12), jvm_TxInjector_1(12)
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 999000000 > /proc/sys/kernel/sched_latency_ns
  • echo 40000 > /proc/sys/kernel/sched_migration_cost_ns
  • echo 999000000 > /proc/sys/kernel/sched_min_granularity_ns
  • echo 999000000 > /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

-Xms5g -Xmx5g -Xmn4g -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=32 -XX:LargePageSizeInBytes=2m -XX:-UseAdaptiveSizePolicy -XX:+AlwaysPreTouch -XX:+UseLargePages -XX:SurvivorRatio=35 -XX:TargetSurvivorRatio=95 -XX:MaxTenuringThreshold=15 -XX:InlineSmallCode=11k -XX:MaxGCPauseMillis=100 -XX:LoopUnrollLimit=200 -XX:+UseTransparentHugePages -XX:TLABAllocationWeight=2 -XX:CompileThresholdScaling=120 -XX:CICompilerCount=4 -XX:AutoBoxCacheMax=32 -XX:OnStackReplacePercentage=100 -XX:TLABSize=64k -XX:MinTLABSize=64k -XX:-ResizeTLAB -XX:TLABWasteTargetPercent=1 -XX:TLABWasteIncrement=1 -XX:YoungPLABSize=64k -XX:OldPLABSize=64k

Tuning

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

  • Group1: numactl --physcpubind=0-15,192-207 --localalloc
  • Group2: numactl --physcpubind=16-31,208-223 --localalloc
  • Group3: numactl --physcpubind=32-47,224-239 --localalloc
  • Group4: numactl --physcpubind=48-63,240-255 --localalloc
  • Group5: numactl --physcpubind=64-79,256-271 --localalloc
  • Group6: numactl --physcpubind=80-95,272-287 --localalloc
  • Group7: numactl --physcpubind=96-111,288-303 --localalloc
  • Group8: numactl --physcpubind=112-127,304-319 --localalloc
  • Group8: numactl --physcpubind=128-143,320-335 --localalloc
  • Group10: numactl --physcpubind=144-159,336-351 --localalloc
  • Group11: numactl --physcpubind=160-175,352-367 --localalloc
  • Group12: numactl --physcpubind=176-191,368-383 --localalloc

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

-Xms5g -Xmx5g -Xmn4g -XX:+UseParallelGC -XX:ParallelGCThreads=1 -XX:CICompilerCount=2

Tuning

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

  • Group1: numactl --physcpubind=0-15,192-207 --localalloc
  • Group2: numactl --physcpubind=16-31,208-223 --localalloc
  • Group3: numactl --physcpubind=32-47,224-239 --localalloc
  • Group4: numactl --physcpubind=48-63,240-255 --localalloc
  • Group5: numactl --physcpubind=64-79,256-271 --localalloc
  • Group6: numactl --physcpubind=80-95,272-287 --localalloc
  • Group7: numactl --physcpubind=96-111,288-303 --localalloc
  • Group8: numactl --physcpubind=112-127,304-319 --localalloc
  • Group8: numactl --physcpubind=128-143,320-335 --localalloc
  • Group10: numactl --physcpubind=144-159,336-351 --localalloc
  • Group11: numactl --physcpubind=160-175,352-367 --localalloc
  • Group12: numactl --physcpubind=176-191,368-383 --localalloc

Notes None
max-jOPS = jOPS passed before the First Failure
Pass/Fail Pass Pass Pass Fail Fail
jOPS 610603 617703 624803 631903 639003
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 242584 323051 401152 443752 472152 366212
  Percentile
  10-th 50-th 90-th 95-th 99-th 100-th
500us 7100 / 14200 - / 7100 - / 7100 - / 7100 - / 7100 - / 7100
1000us 418902 / 426002 21300 / 28400 7100 / 14200 7100 / 14200 - / 7100 - / 7100
5000us 553802 / 560902 511202 / 518302 383402 / 355001 248501 / 255601 156201 / 163301 7100 / 14200
10000us 560902 / 568002 525402 / 532502 440202 / 447302 390502 / 397602 248501 / 213001 7100 / 14200
25000us 568002 / 575102 539602 / 546702 475702 / 482802 447302 / 454402 319501 / 326601 7100 / 14200
50000us 568002 / 575102 546702 / 553802 497002 / 504102 475702 / 482802 397602 / 404702 7100 / 14200
75000us 582202 / 589302 553802 / 560902 511202 / 518302 489902 / 497002 440202 / 447302 120701 / 21300
100000us 582202 / 589302 560902 / 568002 525402 / 532502 504102 / 511202 468602 / 475702 184601 / 21300
200000us 596403 / 603503 568002 / 575102 546702 / 553802 539602 / 546702 511202 / 518302 362102 / 213001
500000us 624803 / - 603503 / 610603 575102 / 582202 575102 / 582202 560902 / 568002 440202 / 411802
1000000us 624803 / - 624803 / - 610603 / 617703 610603 / 617703 603503 / 610603 525402 / 511202
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 Group2.Backend.beJVM Group2.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 150 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320
specjbb.comm.connect.selector.runner.count 0 8 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 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
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
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
specjbb.comm.connect.worker.pool.max 256 150 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320 320
specjbb.comm.connect.worker.pool.min 1 16 32 32 32 32 32 32 32 32 32 32 32 32
specjbb.controller.maxir.maxFailedPoints 3 1
specjbb.customerDriver.threads 64 {probe=80, saturate=170, service=90}
specjbb.forkjoin.workers 384 {Tier1=555, Tier2=20, Tier3=80}
specjbb.group.count 1 12
specjbb.mapreducer.pool.size 384 8
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 710003 IR
High-bound (settled) is 647075 IR