Overview
- This document contains the results of testing Data Import for MARC Bibliographic records with an update job on the Quesnelia [ECS] release on qcon environment.
- PERF-846Getting issue details... STATUS
Summary
- Data Import tests finished successfully on qcon environment using the PTF - Updates Success - 2 profile and file with 25k records.
- Comparing with previous testing results Poppy and Quesnelia releases
- Data Import processed all jobs including test on 3 tenants concurrently without errors for Quesnelia releases.
- Data Import durations stayed in the same time range in Average for Quesnelia releases but it works stable and without errors.
- During testing, we noticed that mod-permission did not have any spikes and used 12% CPU for Quesnelia releases. For Poppy releases we had error.
Test Runs
Test â„– | Scenario | Test Conditions | Results |
---|---|---|---|
1 | DI MARC Bib Create | 5K, 10K, 25K, 50K, 100K consequentially (with 5 min pause) | Completed |
CICO | 8 users | ||
2 | DI MARC Bib Update | 5K, 10K, 25K, 50K, 100K consequentially (with 5 min pause) |
|
CICO | 8 users |
Test Results
This table contains durations for Data Import.
Profile | MARC File | DI Duration Quesnelia (hh:mm:ss) | Check In, Check Out Response time (8 users) Quesnelia | |
---|---|---|---|---|
CI Average sec | CO Average sec | |||
DI MARC Bib Create (PTF - Create 2) | 5K.mrc | 0:03:21 | ||
10K.mrc | 0:06:51 | |||
25K.mrc | 0:12:41 | |||
50K.mrc | 0:23:19 | |||
100K.mrc | 0:51:24 | |||
DI MARC Bib Create (PTF - Updates Success - 2) | 5K.mrc | 0:04:12 | ||
10K.mrc | 0:08:15 | |||
25K.mrc | 0:20:38 | |||
50K.mrc | 0:43:06 | |||
100K.mrc | 1:29:09 |
Check-in/Check-out without DI
Scenario | Load level | Request | Response time, sec Quesnelia | |
---|---|---|---|---|
95 perc | average | |||
Circulation Check-in/Check-out (without Data import) | 8 users | Check-in | ||
Check-out |
Comparison
This table contains DI durations with CICO comparison between Poppy and Quesnelia releases.
Profile | MARC File | DI Durationwith CI/CO | DI Delta Poppy/Quesnelia (hh:mm:ss) | Check In, Check Out Response time (8 users) | Check In, Check Out Response time (8 users) | Delta, % | ||||
Poppy | Quesnelia | Poppy/Quesnelia | Poppy/Quesnelia | |||||||
Poppy | Quesnelia | CI Average sec | CO Average sec | CI Average sec | CO Average sec | CI | CO | |||
DI MARC Bib Create (PTF - Create 2) | 5K.mrc | 00:02:53 | 0:03:21 | |||||||
10K.mrc | 00:04:32 | 0:06:51 | ||||||||
25K.mrc | 00:11:14 | 0:12:41 | ||||||||
50K.mrc | 00:21:55 | 0:23:19 | ||||||||
100K.mrc | 00:47:02 | 0:51:24 | ||||||||
DI MARC Bib Create (PTF - Updates Success - 2) | 5K.mrc | 00:03:19 | 0:04:12 | |||||||
10K.mrc | 00:06:20 | 0:08:15 | ||||||||
25K.mrc | 00:14:04 | 0:20:38 | ||||||||
50K.mrc | 00:29:59 | 0:43:06 | ||||||||
100K.mrc | 01:03:03 | 1:29:09 |
Detailed CICO response time comparison without DI
Scenario | Load level | Request | Response time, sec Poppy | Response time, sec Quesnelia | ||
---|---|---|---|---|---|---|
95 perc | average | 95 perc | average | |||
Circulation Check-in/Check-out (without Data import) | 8 users | Check-in | ||||
Check-out |
Detailed CICO response time comparison for CICO with DI in Poppy
Request* | Response time (avg, sec) | ||
---|---|---|---|
Pure CICO | CICO + 100K MARC BIB Create | CICO + 100K MARC BIB Update | |
Check-Out Controller | 0.828 | 1.491 | 1.51 |
Check-In Controller | 0.431 | 1.018 | 0.908 |
POST_circulation/check-out-by-barcode (Submit_barcode_checkout) | 0.266 | 0.647 | 0.718 |
POST_circulation/check-in-by-barcode (Submit_barcode_checkin) | 0.187 | 0.57 | 0.477 |
GET_circulation/loans (Submit_barcode_checkout) | 0.128 | 0.233 | 0.215 |
GET_inventory/items (Submit_barcode_checkin) | 0.048 | 0.126 | 0.118 |
GET_inventory/items (Submit_barcode_checkout) | 0.046 | 0.125 | 0.117 |
GET_note-links (Submit_barcode_checkout) | 0.046 | 0.024 | 0.024 |
GET_users (Submit_patron_barcode) | 0.037 | 0.041 | 0.037 |
GET_circulation/loans (Submit_patron_barcode) | 0.028 | 0.03 | 0.049 |
GET_automated-patron-blocks (Submit_patron_barcode) | 0.024 | 0.026 | 0.024 |
GET_users (Get_check_in_page) | 0.023 | 0.054 | 0.051 |
*Top-10 requests were taken for analysis.
Resource utilization for Test â„–1
Service CPU Utilization
Here we can see that mod-data-import used 150% CPU in spikes.
Service Memory Utilization
Here we can see that all modules show a stable trend.
DB CPU Utilization
DB CPU was 92%.
DB Connections
Max number of DB connections was 1690.
DB load
Top SQL-queries
# | TOP 5 SQL statements |
---|---|
1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
Resource utilization for Test â„–2
Service CPU Utilization
Here we can see that mod-data-import used 130% CPU in spikes.
Service Memory Utilization
Here we can see that all modules show a stable trend.
DB CPU Utilization
DB CPU was 92%.
DB Connections
Max number of DB connections was 1685.
DB load
Top SQL-queries
# | TOP 5 SQL statements |
---|---|
1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
Appendix
Infrastructure
PTF - environment Quesnelia (qcon)
11 m6i.2xlarge EC2 instances located in US East (N. Virginia)us-east-1 [Number of ECS instances, instance type, location region]
1 instance of db.r6.xlarge database instance: Writer instance
OpenSearch
domain: fse
Number of nodes: 9
Version: OpenSearch_2_7_R20240502
MSK - tenat
4 kafka.m5.2xlarge brokers in 2 zones
Apache Kafka version 2.8.0
EBS storage volume per broker 300 GiB
auto.create.topics.enable=true
log.retention.minutes=480
default.replication.factor=3
Kafka consolidated topics enabled
Methodology/Approach
DI tests scenario (DI MARC Bib Create and Update) were started from UI on Quesnelia (qcon) env with file splitting features enabled on a ecs environment..
Test runs:
- Test 1: Manually tested 5K, 10K, 25K, 50K, 100K consequentially (with 5 min pause) records files, DI (DI MARC Bib Create ) started on College tenant(cs00000int_0001) only, and CICO with 8 users on background.
- Test 2: Manually tested 5K, 10K, 25K, 50K, 100K consequentially (with 5 min pause) records files, DI (DI MARC Bib Update) started on College tenant(cs00000int_0001) only, and CICO with 8 users on background.
At the time of the test run, Grafana was not available. As a result, response times for Check-In/Check-Out were parsed manually from a .jtl files, using the start and finish dates of the data import tests. These results were visualized in JMeter using a Listener (Response Times Over Time).