Skip to end of banner
Go to start of banner

Master Script high load test - NLA report (without Data Import)

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 2 Next »

IN PROGRESS

Overview


In the scope of PERF-531 - Getting issue details... STATUS  it's needed to run tests to answer questions: 

  • Can the current System can accommodate a high use case load NLA load model investigation and creation?
  • What happened at peak times when all workflows are running at once? 
  • Typical KPIs:
    • Service CPU
    • Service Memory
    • DB CPU
    • DB Memory
  • Response times
  • Durations of long workflows
  • Recommendations to improve on scaling up/out modules to accommodate peak times

Summary

tested without Data Import due to PERF-582 - Getting issue details... STATUS

  • The current system can accommodate an average load without Data Import. With data import, we will have 'HTTP 500 Internal Server Error. If the issue persists, please report it to EBSCO Connect.' for several workflows in the source-storage/records/{id}/formatted requests PERF-582 - Getting issue details... STATUS .
  • Service CPU utilization did not exceed 33% even at the beginning of all processes together.  Instance CPU Utilization did not exceed 13%.
  • Service memory utilization was stable, and no memory leaks were suspected during tests.
  • Each FYR (Fiscal close - end of FY rollover) job is consuming a lot of DB CPU. Approximately DB CPU usage is up to 95,2% with FYR and up to 75% without.

Recommendations & Jiras (Optional)

Jiras

PERF-582 - Getting issue details... STATUS

Test Runs & Results

Test #

# configuration

Test durationcomments
1All workflows started at the same time. Test without Data import1 hourNO server errors
2All workflows started at the same time. Test without Data import1 hourNO server errors
3All workflows started at the same time. Test without Data import1 hourNO server errors

 Test results from 1st test run (1st, 2nd and 3rd test run results are similar):

Test #

Workflow name 

Total time it takes to complete workflow

Avg diff


Avg no DI (sec) high load95th pct no DI (sec) high loadAvg no DI (sec) normal load95th pct no DI (sec) normal load
1Checkin

1.0541.591
2Checkout

1.6501.948
3View invoices

0.7630.913
4Create invoices

1.1741.370
5Edit invoices

1.5811.897
6Delete invoices

0.8040.927
7Approving Invoices

1.4531.940
8View Authority records

0.2890.381
9View MARC tag table

0.9871.284
10View holdings records

1.5261.922
11View Bib

0.8411.168
12View patron records

0.5660.883
13Delete patron records

0.6381.070
14Update patron records

1.0431.625
15Create patron records

1.0981.261
16View Ledger

0.0500.088
17Create ledger

0.6160.761
18Edit ledger

0.0540.085
19Delete a ledger

0.0460.080
20Export bib "Default instances export job profile"
-5 sec  (5000 records)-
21Export holdings "Default holdings export job profile"
-26 sec  (5000 records)-
22Export authority records "Default authority export job profile"
-3 sec  (5000 records)-
23DI "DISC HRID match"----
24DI "DS LA edeposit records update"----
25DI "DISC New edeposit records"----
26DI "DISC New NON edeposit records"----
27View item records

1.2891.649
28update item records

0.9981.250
29delete item records

0.9271.099
30Monitoring Pick Slips and Requests GET /circulation/requests

0.3590.480
31Monitoring Pick Slips and Requests GET /circulation/pick-slips/

0.1120.256
32Monitoring Pick Slips and Requests

0.3030.303
33Users loan renewal

1.4671.661
34Item-level requests

0.6690.973
35View vendor records

0.7131.165
36Edit vendor records

5.1996.190
37Create vendor records

1.0641.200
38Delete vendor records

0.4120.522
39Create purchase orders

1.6251.733
40View purchase orders

1.2051.435
41Edit purchase orders

2.0762.984
42Delete purchase orders

1.4321.830
43Retrieving instances and holdings

0.0350.073
44Edit MARC tag table

3.4244.257
45Fiscal close - end of FY rollover
-11 min-
46

Blacklight: View an inventory record JMeter script



0.8211.042
47Blacklight: Create a Request JMeter script

1.1221.404
48

Blacklight: Create a View Patron record JMeter script



0.0730.110

Throughput graphs

For Test#1, Test#2 and Test#3 graphs are almost the same. With FYR general throughput is decreased. Possibly, the reason is high database resource usage of FYR.

Memory Utilization

This graph represents memory usage of 3 test runs and shows that no memory leak is suspected for all of the modules.




Service CPU Utilization 

Average CPU usage did not exceed 33 % for all modules. We can observe spikes in CPU usage of mod-authtoken like in every CICO testing.

Most CPU-consuming modules: 

  • mod-configuration - 33%
  • nginx-okapi - 24%
  • mod-users - 22%
  • okapi - 21
  • mod-finance-storage - 20%
  • mod-authtoken - 10-22% (spiking)
  • pub-okapi - 14%
  • mod-finance -13%
  • mod-inventory - 12,5%
  • mod-inventory-storage -12%
  • mod-quick-marc - 11%
  • mod-invoice-storage -11%
  • others - usage less than - 10%


Instance CPU Utilization

Instance CPU Utilization did not exceed 13%.


RDS CPU Utilization 

Each FYR (Fiscal close - end of FY rollover) job is consuming a lot of DB CPU (spike at the start corresponds to FYR job).

Approximately DB CPU usage is up to 95,2% with FYR and up to 75% without.


RDS Database Connections


Test# 1 - Test# 3 - 420 connections count.

Appendix

Infrastructure

PTF -environment ncp3 

  • m6i.2xlarge EC2 instances located in US East (N. Virginia)us-east-1
  • 2 database  instances, one reader, and one writer

    NameAPI NameMemory GIBvCPUsmax_connections
    R6G Extra Largedb.r6g.xlarge32 GiB4 vCPUs2731
  • MSK ptf-kakfa-3
    • 4 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 topics partitioning: - 2 partitions for DI topics


Modules memory and CPU parameters

Modules

Version

Task Definition

Running Tasks 

CPU

Memory

MemoryReservation

MaxMetaspaceSize

Xmx

mod-inventory-storage26.0.0121024220819523841440
mod-inventory20.0.4121024288025925121814
mod-tags2.0.1121281024896128768
mod-gobi2.6.0121281024896128700
mod-remote-storage2.0.2121024492044725123960
mod-invoice-storage5.6.0121281024896128700
edge-sip23.0.0121281024896128768
mod-users-bl7.5.01251214401152128922
edge-rtac2.6.0121281024896128768
mod-feesfines18.2.1121281024896128768
mod-rtac3.5.0121281024896128768
mod-erm-usage-harvester4.3.0121281024896128768
mod-search2.0.1124002592248010241440
mod-service-interaction2.2.212256204818445121290
edge-ncip1.8.1121281024896128768
mod-authtoken2.13.01251214401152128922
mod-permissions6.3.122512168415445121024
mod-circulation-storage16.0.012102415361440512896
mod-ncip1.13.1121281024896128768
mod-pubsub2.9.112102415361440512922
edge-orders2.8.112102415361440512922
mod-circulation23.5.412153628802592128700
edge-caiasoft2.0.0121281024896--
mod-data-export4.7.11110241024896128768
mod-organizations-storage4.5.1121281024896128700
mod-source-record-storage5.6.5122048560050005123600
mod-copycat1.4.0128961024896128768
mod-bulk-operations1.0.5121024307226005121536
mod-quick-marc3.0.011128228821765121664
mod-audit2.7.01210241024896128768
mod-oai-pmh3.11.3121024224820005121440
edge-connexion1.0.6121281024896128768
mod-kb-ebsco-java3.13.0121281024896128768
mod-patron5.5.2121281024896128768
mod-email1.15.3121281024896128768
mod-password-validator3.0.01212814401298512768
mod-login7.9.012102414401298512768
mod-data-export-worker3.0.12121024307226005122048
mod-agreements5.5.212128309625805122048
edge-oai-pmh2.6.1121024151213605121440
mod-eusage-reports1.3.0121281024896128768
mod-orders-storage13.5.0125121024896128700
mod-notify3.0.0121281024896128768
mod-source-record-manager3.6.2122048560050005123600
mod-di-converter-storage2.0.2221281024896128768
mod-template-engine1.18.0121281024896128768
mod-user-import3.7.2121281024896128768
mod-finance-storage8.4.1121281024896128700
mod-users19.1.1121281024896128768
mod-sender1.10.0121281024896128768
mod-graphql1.11.0121281024896128768
mod-licenses4.3.112128248023125121792
mod-invoice-b5.6.21251214401152128922
mod-event-config2.5.0121281024896128768
mod-calendar2.4.2121281024896128768
mod-erm-usage4.5.2121281024896128768
mod-patron-blocks1.8.01210241024896128768
mod-data-import2.7.111256204818445121292
mod-ebsconet2.0.01212812481024256700
edge-dematic2.0.0121281024896--
mod-task-list5.0.1111281024896128768
mod-courses1.4.7121281024896128768
mod-inventory-update3.0.1121281024896128768
mod-login-saml2.6.1121281024896128768
mod-orders12.6.6121024204814405121024
mod-configuration5.9.1121281024896128768
mod-organizations1.7.0121281024896128700
mod-notes5.0.1121281024896128322
mod-finance4.7.1121281024896128700
mod-data-export-spring2.0.111256204818442561292
edge-patron4.11.0122561024896128768
okapi5.0.123102416841440512922
nginx-okapi2022.03.02121281024896--
pub-okapi2022.03.02121281024896-768

Methodology/Approach

To test Baseline for normal NLA library usage the JMeter scripts were used.

Tested with different DI delays:

  • From test start
  • 1 min delay
  • 20 min delay
  • without DI

Data was gathered from 2 periods with and without data import.


  • DI - data import
  • FYR - Fiscal close - end of FY rollover






  • No labels