Quanta Cloud Technology, QuantaGrid D44N-1U 811237 SPECjbb2015-MultiJVM max-jOPS
348514 SPECjbb2015-MultiJVM critical-jOPS
Tested by: Quanta Computer Inc. Test Sponsor: Quanta Computer Inc. Test location: Taoyuan, TW, R.O.C Test date: Oct 5, 2023
SPEC license #: 9050 Hardware Availability: Nov-2023 Software Availability: Jul-2023 Publication: Thu Nov 30 22:47:46 EST 2023
Benchmark Results Summary
 
Overall Throughput RT curve
Overall SUT (System Under Test) Description
VendorQuanta Cloud Technology
Vendor URLhttp://qct.io
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
NameQuantaGrid D44N-1U
VendorQuanta Cloud Technology
Vendor URLhttp://qct.io
AvailableNov-2023
ModelQuantaGrid D44N-1U
Form Factor1U
CPU NameAMD EPYC 9654
CPU Characteristics96 core, 2.4GHz, 384MB L3 Cache (Max. Boost Clock up to 3.7GHz)
Number of Systems1
Nodes Per System1
Chips Per System2
Cores Per System192
Cores Per Chip96
Threads Per System384
Threads Per Core2
Version3A02 released Sep-2023
CPU Frequency (MHz)2400
Primary Cache32 KB I + 32 KB D on chip per core
Secondary Cache1024 KB I+D on chip per core
Tertiary Cache384 MB (I+D) on chip per chip
Other CacheNone
Disk1 x 960 GB NVMe SSD
File SystemXFS
Memory Amount (GB)1536
# and size of DIMM(s)24 x 64 GB
Memory Details64GB 2Rx4 PC5-38400R , running at 4800 MHz
# and type of Network Interface Cards (NICs)Intel 10 Gigabit Ethernet X710-AT2 2-port
Power Supply Quantity and Rating (W)1 x 1600
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 SP4
VendorSUSE
Vendor URLhttp://suse.com/
Version5.14.21-150400.22-default
AvailableJun-2022
Bitness64
NotesNone
Java Virtual Machine jvm_1
NameOracle Java SE 17.0.8
VendorOracle
Vendor URLhttp://www.oracle.com
VersionJava HotSpot 64-bit Server VM, version 17.0.8
AvailableJul-2023
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
  • L1 Stream HW Prefetcher : Disabled
  • L2 Stream HW Prefetcher : Disabled
  • NUMA Nodes Per Socket : NPS4
  • L3 cache as NUMA Domain : Enabled
  • Determinism Slider : Power Determinism
  • ACPI CST C2 Latency : 18
  • PPT Control : 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
  • echo 950000 > /proc/sys/kernel/sched_rt_runtime_us
  • echo 150000000 > /proc/sys/kernel/sched_latency_ns
  • echo 80000 > /proc/sys/kernel/sched_migration_cost_ns
  • echo 300000 > /proc/sys/kernel/sched_min_granularity_ns
  • echo 300000 > /proc/sys/kernel/sched_wakeup_granularity_ns
  • 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/vm/numa_stat
  • echo 0 > /proc/sys/kernel/numa_balancing
  • UserTasksMax=970000
  • DefaultTasksMax=970000
  • echo always > /sys/kernel/mm/transparent_hugepage/enabled
  • echo always > /sys/kernel/mm/transparent_hugepage/defrag
  • ulimit -n 1024000
Notes None
JVM Instance jvm_Ctr_1
Parts of Benchmark Controller
JVM Instance Description jvm_1
Command Line -Xms8g -Xmx8g -Xmn6g -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 physcical cores in a NUMA node.

  • numactl --physcpubind=0-7,192-199 --localalloc
  • numactl --physcpubind=8-15,200-207 --localalloc
  • numactl --physcpubind=16-23,208-215 --localalloc
  • numactl --physcpubind=24-31,216-223 --localalloc
  • numactl --physcpubind=32-39,224-231 --localalloc
  • numactl --physcpubind=40-47,232-239 --localalloc
  • numactl --physcpubind=48-55,240-247 --localalloc
  • numactl --physcpubind=56-63,248-255 --localalloc
  • numactl --physcpubind=64-71,256-263 --localalloc
  • numactl --physcpubind=72-79,264-271 --localalloc
  • numactl --physcpubind=80-87,272-279 --localalloc
  • numactl --physcpubind=88-95,280-287 --localalloc
  • numactl --physcpubind=96-103,288-295 --localalloc
  • numactl --physcpubind=104-111,296-303 --localalloc
  • numactl --physcpubind=112-119,304-311 --localalloc
  • numactl --physcpubind=120-127,312-319 --localalloc
  • numactl --physcpubind=128-135,320-327 --localalloc
  • numactl --physcpubind=136-143,328-335 --localalloc
  • numactl --physcpubind=144-151,336-343 --localalloc
  • numactl --physcpubind=152-159,344-351 --localalloc
  • numactl --physcpubind=160-167,352-359 --localalloc
  • numactl --physcpubind=168-175,360-367 --localalloc
  • numactl --physcpubind=176-183,368-375 --localalloc
  • numactl --physcpubind=184-191,376-383 --localalloc
Notes None
JVM Instance jvm_TxInjector_1
Parts of Benchmark TxInjector
JVM Instance Description jvm_1
Command Line -Xms8g -Xmx8g -Xmn6g -XX:+UseParallelGC -XX:ParallelGCThreads=1 -XX:CICompilerCount=2
Tuning

Used numactl to affinitize each Backend JVM to physcical cores in a NUMA node.

  • numactl --physcpubind=0-7,192-199 --localalloc
  • numactl --physcpubind=8-15,200-207 --localalloc
  • numactl --physcpubind=16-23,208-215 --localalloc
  • numactl --physcpubind=24-31,216-223 --localalloc
  • numactl --physcpubind=32-39,224-231 --localalloc
  • numactl --physcpubind=40-47,232-239 --localalloc
  • numactl --physcpubind=48-55,240-247 --localalloc
  • numactl --physcpubind=56-63,248-255 --localalloc
  • numactl --physcpubind=64-71,256-263 --localalloc
  • numactl --physcpubind=72-79,264-271 --localalloc
  • numactl --physcpubind=80-87,272-279 --localalloc
  • numactl --physcpubind=88-95,280-287 --localalloc
  • numactl --physcpubind=96-103,288-295 --localalloc
  • numactl --physcpubind=104-111,296-303 --localalloc
  • numactl --physcpubind=112-119,304-311 --localalloc
  • numactl --physcpubind=120-127,312-319 --localalloc
  • numactl --physcpubind=128-135,320-327 --localalloc
  • numactl --physcpubind=136-143,328-335 --localalloc
  • numactl --physcpubind=144-151,336-343 --localalloc
  • numactl --physcpubind=152-159,344-351 --localalloc
  • numactl --physcpubind=160-167,352-359 --localalloc
  • numactl --physcpubind=168-175,360-367 --localalloc
  • numactl --physcpubind=176-183,368-375 --localalloc
  • numactl --physcpubind=184-191,376-383 --localalloc
Notes None
max-jOPS = jOPS passed before the First Failure
Pass/Fail Pass Pass Pass Fail Fail
jOPS 794337 802787 811237 819688 828138
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 232386 289426 375197 426744 477447 348514
  Percentile
  10-th 50-th 90-th 95-th 99-th 100-th
500us 16901 / 25351 8450 / 16901 - / 8450 - / 8450 - / 8450 - / 8450
1000us 101405 / 109855 16901 / 25351 8450 / 16901 8450 / 16901 8450 / 16901 - / 8450
5000us 540825 / 549275 236611 / 245061 160557 / 169008 152107 / 160557 126756 / 135206 25351 / 16901
10000us 566176 / 574627 507023 / 515474 312664 / 321115 287313 / 295764 228161 / 236611 25351 / 16901
25000us 574627 / 583077 549275 / 557726 490123 / 498573 439420 / 447871 295764 / 270412 25351 / 16901
50000us 583077 / 591527 557726 / 566176 515474 / 523924 490123 / 498573 388718 / 354916 25351 / 16901
75000us 591527 / 599978 566176 / 574627 532375 / 540825 507023 / 515474 430970 / 422519 25351 / 16901
100000us 599978 / 608428 574627 / 583077 540825 / 549275 532375 / 540825 490123 / 464771 25351 / 16901
200000us 642230 / 650680 599978 / 608428 566176 / 574627 557726 / 566176 540825 / 549275 338016 / 76054
500000us 794337 / 802787 684482 / 692932 633779 / 642230 625329 / 633779 608428 / 616878 473222 / 321115
1000000us 811237 / - 811237 / - 760535 / 768985 743634 / 752085 709833 / 718283 591527 / 321115
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 10 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170 256 170
specjbb.comm.connect.selector.runner.count 0 10 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 5 20 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 150 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200 256 200
specjbb.comm.connect.worker.pool.min 1 16 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1 32 1
specjbb.controller.maxir.maxFailedPoints 3 1
specjbb.customerDriver.threads 64 {probe=130, saturate=300, service=160}
specjbb.forkjoin.workers 384 {Tier1=800, Tier2=45, Tier3=160}
specjbb.group.count 1 24
specjbb.mapreducer.pool.size 384 10
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 845039 IR
High-bound (settled) is 818540 IR