Keep real world performance numbers » History » Version 11
Ward Vandewege, 08/12/2020 02:52 PM
1 | 1 | Ward Vandewege | h1. Keep real world performance numbers |
---|---|---|---|
2 | |||
3 | 6 | Ward Vandewege | h2. AWS/S3 numbers |
4 | |||
5 | Here are some benchmark numbers against AWS S3, as measured in July 2020. They were generated with the _keep-exercise_ tool in an Arvados installation with one dedicated Keepstore node (c5n.2xlarge) and one dedicated node for running _keep-exercise_ (c5n.2xlarge). The Keepstore node was backed by one S3 bucket, in a VPC with an S3 endpoint installed. Versioning, Server Access logging, Static website hosting, Object-level logging and Default encryption were disabled. Object lock, Transfer acceleration and Requester pays were also disabled. There were no Active notifications. Each test consisted of 4 one minute runs, which were averaged into one number. The tests were repeated 3 times, and of those 3 runs, the highest average speed was selected and included in the table below. |
||
6 | |||
7 | 11 | Ward Vandewege | The *goamz* driver is the default Keep S3 driver as of Arvados 2.0. In Arvados 2.1, a new S3 driver is added based on the *aws-sdk-go-v2* driver. It offers better read performance but has not had as much production use. To enable the *aws-sdk-go-v2* driver, set the *UseAWSS3v2Driver* flag to true in config.yml, as described on the "Arvados documentation: S3 configuration":https://doc.arvados.org/master/install/configure-s3-object-storage.html page. |
8 | 6 | Ward Vandewege | |
9 | 10 | Ward Vandewege | |_. threads|_. goamz |_. aws-sdk-go-v2 |_. command line| |
10 | |single read|32.53 MiB/s|79.48 MiB/s|keep-exercise -repeat 4 -run-time 60s -vary-request -use-index -rthreads 1 -wthreads 1| |
||
11 | |single write|39.75 MiB/s|41.05 MiB/s|keep-exercise -repeat 4 -run-time 60s -vary-request -use-index -rthreads 1 -wthreads 1| |
||
12 | 6 | Ward Vandewege | |
13 | When using 20 concurrent read or write threads, the numbers from both drivers are: |
||
14 | |||
15 | 10 | Ward Vandewege | |_. threads|_. goamz |_. aws-sdk-go-v2 |_. command line| |
16 | |20 read|585.60 MiB/s|898.93 MiB/s|keep-exercise -repeat 4 -run-time 60s -vary-request -use-index -rthreads 20 -wthreads 0| |
||
17 | |20 write|610.40 MiB/s|688.25 MiB/s|keep-exercise -repeat 4 -run-time 60s -vary-request -use-index -rthreads 0 -wthreads 20| |
||
18 | 6 | Ward Vandewege | |
19 | 8 | Ward Vandewege | When using 40 concurrent read or write threads, the numbers from both drivers are: |
20 | |||
21 | 10 | Ward Vandewege | |_. threads|_. goamz |_. aws-sdk-go-v2 |_. command line|_. comment| |
22 | |40 read|1005.30 MiB/s|1005.35 MiB/s|keep-exercise -repeat 4 -run-time 60s -vary-request -use-index -rthreads 40 -wthreads 0|| |
||
23 | |40 write|653.05 MiB/s|974.925 MiB/s|keep-exercise -repeat 4 -run-time 60s -vary-request -use-index -rthreads 0 -wthreads 40|goamz is cpu bound on the keepstore (800%)| |
||
24 | 8 | Ward Vandewege | |
25 | 6 | Ward Vandewege | h2. Historical AWS/S3 numbers |
26 | 1 | Ward Vandewege | |
27 | 5 | Tom Morris | |Name|Network performance|CPU|RAM|Keepstore|Data Payload Throughput|CPU load|Date tested|Tested by| |
28 | 4 | Ward Vandewege | |c5.9xlarge|10 Gigabit|36 cores|72 GiB|0.1.20171212165144.296aa66-1|Saturates RX and TX (1+ GiB/sec)|~4|2018-01-18|Ward| |
29 | 1 | Ward Vandewege | |r4.8xlarge|10 Gigabit|32 cores|244 GiB|0.1.20171212165144.296aa66-1|Saturates RX and TX (1+ GiB/sec)|~4|2018-01-17|Ward| |
30 | 3 | Ward Vandewege | |r4.large|"up to" 10 Gigabit|2 cores|15 GiB|0.1.20171212165144.296aa66-1|~400 MiB/sec but long periods of cap at ~90 MiB/sec||2018-01-16|Ward| |