Skip to content

Latest commit

 

History

History
68 lines (53 loc) · 2.24 KB

README.md

File metadata and controls

68 lines (53 loc) · 2.24 KB

WIP Learn to use Echo framework

Small example to get familiar with the Echo framework. Coded in 2 hours on a Sunday so quite dirty for now...

Usage

  • build the image docker build . --no-cache -t auth_server:v1
  • docker-compose up

or

  • docker-compose up --build

Test login works curl --location --request POST 'localhost:1323/api/login' \ --header 'Content-Type: application/json' \ --data-raw '{ "username": "george", "password": "testtest" }'

Benchmarks

Hardware: AMD64 8C/16T | 16GB | SATA SSD Test setup: 512 concurrent clients, 500 repetitions.

Login

Quite fast at 16K transactions per second.

siege -c512 -r 500 --content-type "application/json" 'http://localhost:3000/api/login POST {"username": "paul", "password": "testtest"}'
** SIEGE 4.0.4
** Preparing 512 concurrent users for battle.
The server is now under siege...
Lifting the server siege...
Transactions:                256000 hits
Availability:                100.00 %
Elapsed time:                 15.93 secs
Data transferred:             94.73 MB
Response time:                 0.03 secs
Transaction rate:          16070.31 trans/sec
Throughput:                    5.95 MB/sec
Concurrency:                 495.42
Successful transactions:     256000
Failed transactions:              0
Longest transaction:           0.53
Shortest transaction:          0.00

Access JWT protected route

Quite fast at 18.2K transactions per second. Longuest request up to a second but considering that both server and benchmark are running on same machine still good.

siege -c512 -r 500 --header="Authorization:Bearer <obtain token with example login request>" 'http://localhost:3000/api/test
** SIEGE 4.0.4
** Preparing 512 concurrent users for battle.
The server is now under siege...
Lifting the server siege...
Transactions:                256000 hits
Availability:                100.00 %
Elapsed time:                 14.00 secs
Data transferred:              9.52 MB
Response time:                 0.03 secs
Transaction rate:          17135.21 trans/sec
Throughput:                    0.68 MB/sec
Concurrency:                 480.23
Successful transactions:     256000
Failed transactions:              0
Longest transaction:           0.61
Shortest transaction:          0.00