Skip to end of banner
Go to start of banner

RCON [Ramsons] ECS - Acquisition Audit Log Performance testing

Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 12 Next »

O

verview

  • This document contains the results of Central Ordering testing scenarios to create order with PO lines plus Change instance connection and Receive all pieces for Ramsons [ECS] environments. 

PERF-1027 - Getting issue details... STATUS  

Summary

  • All tests were successfully completed, and all API calls were executed without errors.
  • Response time for Change Instance Connection for Test №2 increased by 45% compared to Test №1 and for Test №3 Response time increased by 125% compared to Test 1. It appears that the Find or Create New Holdings action performed multiple operations, which explains the extended response time for this action.
  • In Test 3, the Create Order operation involved creating orders with 50 Order Lines, compared to 1 Order Lines in Test 1 and 10 Order Lines in Test 2. This explains the significant increase in response times for the Open Order and Unopen Order operations:

    • Open Order: Response times increased nearly 10x in Test 3 compared to Test 1 due to the higher load (50 items per order).
    • Unopen Order: Similarly, response times grew approximately 4-5x in Test 3.

    For other operations (Create Order, Create Order Line, Receive Pieces, and Change Instance Connection), response times increased moderately but remained within acceptable ranges as the load increased.

    Conclusion: The increase in item count per order directly impacted the performance of Open Order and Unopen Order, highlighting their sensitivity to load.

  • In Test №2, the Create New Holdings operation for Change Instance Connection triggered the reindex function. As a result, we observed that mod-search initiated reindexing, as evidenced by SQL queries N1 and N4 appearing in the TOP 5 SQL Statements table. This process placed a significant load on the database and continued for over 3 hours after the tests were completed.


Test Runs 

Test №

Date

Test Conditions

Results

1

12/12/24, 9:48 AM UTC

PO with PO Lines (1) + locations (5) + Change instance connection (Move holdings)

Completed
212/12/24, 11:32 AM UTC

PO with PO Lines (10) + locations (3) + Change instance connection (Create new holdings)

Completed
3

12/12/24, 1:21 PM UTC

PO with PO Lines (50) + locations (3) + Change instance connection (Move holdings, Find or Create new holdings)

Completed

Test Results

Test №1

PO with PO Lines (1) + locations (5) + Change instance connection (Move holdings)



Transactions

Response Time (milliseconds)
Data size 500k


Data size 1 million


Data size 5 million


Averagepct90pct95pct99Averagepct90pct95pct99Averagepct90pct95pct99
TC_open order 10813251325132513872252625262526894265026502650
TC_open order 50446687731735453687796800469647775775
TC_open order 100737134313431343739134613461346814172217221722
TC_open order 10006708841149114965785810091009680838877880
TC_open order line 10136331593159315914683464346434641560408340834083
TC_open order line 50913134317121730925159119101910936145816261632
TC_open order line 100118117841981198111701978199619961235224225662566
TC_open order line 1000119715341819193711921485163516991213152919762092
TC_open pieces 10126826432643264312492621262126211269264526452645
TC_open pieces 50880106518711913881125414751499915136817291739
TC_open pieces 100111118441869186911261531157916681144181118451845
TC_open pieces 1000106212861426146211101305163118031092148916341639
TC_view order history 10541165216521652558161316131613544138813881388
TC_view order history 50254383474477249314384387265380537537
TC_view order history 100477805829858486886886886505849856856
TC_view order history 1000452647787787445528591591464681775968
TC_view order line history 10754161016101610738156415641564823197419741974
TC_view order line history 50452619816816449587629634489788788788
TC_view order line history 100695106812741307677103711321132718968968968
TC_view order line history 100073390097398876012071207120774692611511151
TC_view pieces history 10753143314331433745142214221422782180118011801
TC_view pieces history 50452701774783449632797869454626692695
TC_view pieces history 100670100811131133656108611401140701108111601160
TC_view pieces history 1000710945945945701109510951095694862906910



Transactions

Response Time (milliseconds)
Data size 500kData size 1 millionData size 5 millionData size 500kData size 1 millionData size 5 million
AverageAverageAveragepct90pct90pct90
GET audit-data/acquisition/order/[order_10]272834727489
GET audit-data/acquisition/order-line/[po_line_id_10]292729777090
GET audit-data/acquisition/piece/]pieces_10]/status-change-history282827646869
GET audit-data/acquisition/order/[order_50]181618584748
GET audit-data/acquisition/order-line/[po_line_id_50]2023405360344
GET audit-data/acquisition/piece/]pieces_50]/status-change-history172019445151
GET audit-data/acquisition/order/[order_100]222023625966
GET audit-data/acquisition/order-line/[po_line_id_100]272532656375
GET audit-data/acquisition/piece/]pieces_100]/status-change-history222123616260
GET audit-data/acquisition/order/[order_1000]4752481009881
GET audit-data/acquisition/order-line/[po_line_id_1000]122126132212231222
GET audit-data/acquisition/piece/]pieces_1000]/status-change-history60505311710596


Comparison

Test №1-№2-№3

The following table compares the results between tests №1,  №2 and №3. 

  • Open Order: Response times increased nearly 10x in Test 3 compared to Test 1 due to the higher load (50 items per order).
  • Unopen Order: Similarly, response times grew approximately 4-5x in Test 3.


Resource utilization for Test #1-2-3

 Resource utilization table
CPU  RAM  
mod-inventory-b1.40%mod-inventory-b75%
mod-search-b0.20%mod-finance-b68%
mod-inventory-storage-b0.10%mod-orders-b55%
mod-orders-storage-b0.10%mod-orders-storage-b44%
mod-orders-b0.10%mod-audit-b39%
mod-audit-b0.10%mod-search-b39%
mod-finance-b0.10%mod-finance-storage-b32%
mod-finance-storage-b0.10%mod-inventory-storage-b23%

Service CPU Utilization

Here we can see that mod-search initiated reindexing for Test #2.

Service Memory Utilization

Here we can see that all modules show a stable trend.

Kafka metrics


OpenSearch Data Nodes metrics

DB CPU Utilization

DB CPU in the average were 20% for Scenario 1, 30% for Scenario 2 and 40% for Scenario 3

.

DB Connections

Max DB connections was 1560.

DB load

                                                                                                                     

Top SQL-queries



#TOP 5 SQL statements
1
SELECT i.json
  || jsonb_build_object('tenantId', i.tenant_id,
                        'shared', i.shared,
                        'isBoundWith', i.is_bound_with,
                        'holdings', COALESCE(jsonb_agg(DISTINCT h.json || jsonb_build_object('tenantId', h.tenant_id)) FILTER (WHERE h.json IS NOT NULL), '[]'::jsonb),
                        'items', COALESCE(jsonb_agg(it.json || jsonb_build_object('tenantId', it.tenant_id)) FILTER (WHERE it.json IS NOT NULL), '[]'::jsonb)) as json
FROM cs00000int_mod_search.instance i
  LEFT JOIN cs00000int_mod_search.holding h on h.instance_id = i.id
  LEFT JOIN cs00000int_mod_search.item it on it.holding_id = h.id
  WHERE i.id IN ($1::uuid)
  GROUP BY i.id
2
SELECT * FROM cs00000int_mod_orders_storage.internal_lock WHERE lock_name = $1 FOR UPDATE
3
SELECT jsonb FROM cs00000int_mod_orders_storage.po_line WHERE lower(f_unaccent(po_line.jsonb->>'locations')) LIKE lower(f_unaccent('%b4585aae-b502-43e6-95c6-4de1c038f6af%')) 
LIMIT 2147483647 OFFSET 0
4
SELECT i.json
  || jsonb_build_object('tenantId', i.tenant_id,
                        'shared', i.shared,
                        'isBoundWith', i.is_bound_with,
                        'holdings', COALESCE(jsonb_agg(DISTINCT h.json || jsonb_build_object('tenantId', h.tenant_id)) FILTER (WHERE h.json IS NOT NULL), '[]'::jsonb),
                        'items', COALESCE(jsonb_agg(it.json || jsonb_build_object('tenantId', it.tenant_id)) FILTER (WHERE it.json IS NOT NULL), '[]'::jsonb)) as json
FROM cs00000int_mod_search.instance i
  LEFT JOIN cs00000int_mod_search.holding h on h.instance_id = i.id
  LEFT JOIN cs00000int_mod_search.item it on it.holding_id = h.id
  WHERE i.id IN ($1::uuid,$2::uuid,$3::uuid,$4::uuid,$5::uuid,$6::uuid)
  GROUP BY i.id
5
SELECT cs00000int_mod_orders_storage.count_estimate('SELECT jsonb,id FROM cs00000int_mod_orders_storage.acquisitions_unit WHERE (CASE WHEN length(lower(f_unaccent(''false''))) 
<= 600 THEN left(lower(f_unaccent(acquisitions_unit.jsonb->>''isDeleted'')),600) LIKE lower(f_unaccent(''false'')) ELSE left(lower(f_unaccent(acquisitions_unit.jsonb->>''isDeleted'')),600)
LIKE left(lower(f_unaccent(''false'')),600) AND lower(f_unaccent(acquisitions_unit.jsonb->>''isDeleted'')) LIKE lower(f_unaccent(''false'')) END) AND
(CASE WHEN length(lower(f_unaccent(''false''))) <= 600 THEN left(lower(f_unaccent(acquisitions_unit.jsonb->>''protectRead'')),600) LIKE lower(f_unaccent(''false''))
ELSE left(lower(f_unaccent(acquisitions_unit.jsonb->>''protectRead'')),600) LIKE left(lower(f_unaccent(''false'')),600) AND lower(f_unaccent(acquisitions_unit.jsonb->>''protectRead''))
LIKE lower(f_unaccent(''false'')) END)')

Appendix

Infrastructure

PTF - environment Ramsons (rcon)

  • 11 m6g.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: ptf-test

    • Number of nodes: 7

    • Version: OpenSearch_2_13_R20240520-P5

  • MSK - fse-tenant

    • 4 kafka.m7g.xlarge brokers in 2 zones

    • Apache Kafka version 3.7.x

    • EBS storage volume per broker 300 GiB

    • auto.create.topics.enable=true

    • log.retention.minutes=480

    • default.replication.factor=3


 RCON modules memory and CPU parameters

rcon-pvt (Wed Dec 11 13:14:17 UTC 2024)

ModuleTask Definition RevisionModule VersionTask CountMem Hard LimitMem Soft LimitCPU UnitsXmxMetaspace SizeMax Metaspace Size
mod-remote-storage7mod-remote-storage:3.3.224920447203960512512
mod-finance-storage7mod-finance-storage:8.7.321024896070088128
mod-ncip7mod-ncip:1.15.621024896076888128
mod-agreements7mod-agreements:7.1.22159214880000
mod-ebsconet7mod-ebsconet:2.3.02124810240700128256
mod-organizations7mod-organizations:2.0.021024896070088128
mod-consortia9mod-consortia:1.2.1251364776020485121024
edge-sip27edge-sip2:3.3.121024896076888128
mod-serials-management7mod-serials-management:1.1.122480231201792384512
mod-settings7mod-settings:1.1.021024896076888128
mod-data-import7mod-data-import:3.2.112048184401292384512
mod-search15mod-search:4.0.2225922480014405121024
edge-dematic7edge-dematic:2.3.111024896076888128
mod-inn-reach4mod-inn-reach:3.2.1-SNAPSHOT.102236003240028805121024
mod-record-specifications7mod-record-specifications:1.0.221024896076888128
mod-tags7mod-tags:2.3.021024896076888128
mod-authtoken9mod-authtoken:2.16.1214401152092288128
edge-courses7edge-courses:1.5.021024896076888128
mod-notify7mod-notify:3.3.021024896076888128
mod-inventory-update7mod-inventory-update:4.0.021024896076888128
mod-configuration7mod-configuration:5.11.021024896076888128
mod-orders-storage7mod-orders-storage:13.8.321024896070088128
edge-caiasoft7edge-caiasoft:2.3.221024896076888128
mod-login-saml7mod-login-saml:2.9.321024896076888128
mod-erm-usage-harvester7mod-erm-usage-harvester:5.0.121024896076888128
mod-gobi7mod-gobi:2.9.021024896070088128
mod-licenses7mod-licenses:6.1.222480231201792384512
mod-password-validator7mod-password-validator:3.3.02144012980768384512
edge-dcb8edge-dcb:1.2.121024896076888128
mod-bulk-operations7mod-bulk-operations:2.1.423072260001536384512
mod-fqm-manager9mod-fqm-manager:3.0.3230002600076888128
mod-graphql8mod-graphql:1.13.021024896076888128
mod-finance7mod-finance:5.0.021024896070088128
mod-erm-usage7mod-erm-usage:5.0.022800255001800384512
mod-batch-print7mod-batch-print:1.2.021024896076888128
mod-tlr4mod-tlr:1.0.0-SNAPSHOT.821024896076888128
mod-lists11mod-lists:3.0.3260002600076888128
mod-copycat7mod-copycat:1.7.021024512076888128
mod-entities-links10mod-entities-links:3.1.12259224800144001024
mod-permissions11mod-permissions:6.6.021684154401024384512
pub-edge7pub-edge:2023.06.1401024896076800
mod-orders7mod-orders:12.9.222048174001024384512
edge-patron7edge-patron:5.2.021024896076888128
mod-marc-migrations15mod-marc-migrations:1.0.121024896076888128
edge-ncip8edge-ncip:1.10.121024896076888128
edge-inn-reach5edge-inn-reach:3.3.0-SNAPSHOT.6921024896076888128
mod-users-bl7mod-users-bl:7.9.3214401152092288128
mod-oa4mod-oa:2.1.0-SNAPSHOT.6621024896076888128
mod-inventory-storage8mod-inventory-storage:28.0.2240963690030765121024
mod-invoice7mod-invoice:5.9.1214401152092288128
mod-user-import7mod-user-import:3.9.021024896076888128
mod-sender7mod-sender:1.13.021024896076888128
edge-oai-pmh7edge-oai-pmh:2.10.021512136001440384512
mod-data-export-worker8mod-data-export-worker:3.3.323072204802048384512
mod-rtac7mod-rtac:3.7.021024896076888128
mod-circulation-storage7mod-circulation-storage:17.3.122880259201814384512
mod-source-record-storage12mod-source-record-storage:5.9.325600500003500384512
mod-calendar7mod-calendar:3.2.021024896076888128
mod-event-config7mod-event-config:2.8.021024896076888128
mod-courses8mod-courses:1.4.1121024896076888128
mod-circulation-item7mod-circulation-item:1.1.0210248960000
mod-inventory7mod-inventory:21.0.222880259201814384512
mod-email7mod-email:1.18.022800255001800384512
mod-requests-mediated4mod-requests-mediated:1.0.0-SNAPSHOT.421024896076888128
mod-circulation7mod-circulation:24.3.222880259201814384512
mod-pubsub7mod-pubsub:2.15.22153614400922384512
mod-di-converter-storage7mod-di-converter-storage:2.3.121024896076888128
edge-rtac7edge-rtac:2.8.021024896076888128
edge-orders7edge-orders:3.1.021024896076888128
mod-users7mod-users:19.4.321024896076888128
mod-template-engine7mod-template-engine:1.21.021024896076888128
mod-patron-blocks7mod-patron-blocks:1.11.121024896076888128
mod-audit7mod-audit:2.10.121024896076888128
edge-fqm8edge-fqm:3.0.121024896076888128
mod-source-record-manager7mod-source-record-manager:3.9.325600500003500384512
nginx-edge7nginx-edge:2023.06.14010248960000
mod-quick-marc7mod-quick-marc:6.0.012288217601664384512
nginx-okapi7nginx-okapi:2023.06.14210248960000
okapi-b7okapi:6.1.02168414400922384512
mod-feesfines7mod-feesfines:19.2.121024896076888128
mod-invoice-storage7mod-invoice-storage:5.9.121872153601024384512
mod-reading-room7mod-reading-room:1.0.021024896076888128
mod-dcb7mod-dcb:1.2.321024896076888128
mod-service-interaction7mod-service-interaction:4.1.122048184401290384512
mod-patron7mod-patron:6.2.121024896076888128
mod-data-export12mod-data-export:5.1.21204818440000
mod-oai-pmh7mod-oai-pmh:3.14.324096369003076384512
edge-connexion7edge-connexion:1.3.121024896076888128
mod-notes7mod-notes:6.0.0210248960952384512
mod-kb-ebsco-java8mod-kb-ebsco-java:5.0.021024896076888128
mod-organizations-storage7mod-organizations-storage:4.8.121024896070088128
mod-data-export-spring7mod-data-export-spring:3.4.212048184401536384512
mod-login7mod-login:7.12.12144012980768384512
pub-okapi7pub-okapi:2023.06.1421024896076800
edge-erm5edge-erm:1.3.021024896076888128
mod-eusage-reports7mod-eusage-reports:3.0.021024896076888128


Methodology/Approach

All tests scenarios  were started from Load Generator i-066a4ed5e6ec777bc on Ramsons ECS (rcon) environment.

Parameters for Tests:

  • Number of users: 1
  • Test duration: 20min
  • Each test scenario was conducted with the following dataset sizes for mod_audit.acquisition_order_log, mod_audit.acquisition_order_line_log and mod_audit.acquisition_piece_log tables:
    • 500k records
    • 1 million records
    • 5 million records
  • No pause between user action

Test scenario №1

  • Open Order tub

  • Open Order (with 10 changes in history)

  • View Order history
  • Open Order Line (with 10 changes in history)

  • View Order Line history
  • Open Pieces (with 10 changes in history)

  • View Pieces history

Test scenario №2

  • Open Order tub

  • Open Order (with 50 changes in history)

  • View Order history
  • Open Order Line (with 50 changes in history)

  • View Order Line history
  • Open Pieces (with 50 changes in history)

  • View Pieces history

Test scenario №3

  • Open Order tub

  • Open Order (with 100 changes in history)

  • View Order history
  • Open Order Line (with 100 changes in history)

  • View Order Line history
  • Open Pieces (with 100 changes in history)

  • View Pieces history

Test scenario №4

  • Open Order tub

  • Open Order (with 1000 changes in history)

  • View Order history
  • Open Order Line (with 1000 changes in history)

  • View Order Line history
  • Open Pieces (with 1000 changes in history)

  • View Pieces history

Attached files

Ramsons ECS (rcon) module configuration parameters:

 

JMeter script:




  • No labels