NBBO Calculation example
NBBO is the National Best Bid and Offer, defined as the lowest available ask price and highest available bid price across the participating markets for a given security. Brokers should route trade orders to the market with the best price, and by law must guarantee customers the best available price.
This example app includes a VoltDB database schema that stores each market data tick and automatically inserts a new NBBO record whenever there is a change to the best available bid or ask price. This can be used to serve the current NBBO or the history of NBBO changes on demand to consumers such as the dashboard or other applications.
The example includes a web dashboard that shows the real-time NBBO for a security and the latest avaialble prices from each exchange. It also includes a client benchmark application that generates synthetic market data ticks for all of the listed stocks from NYSE, AMEX, and NASDAQ. The prices are simulated using a random walk algorithm that starts from the end of day closing price that is initially read from a CSV file. It is not intended to be a realistic simulation of market data, but simply to generate simulated data for demonstration purposes.
The code is divided into projects:
See below for instructions on running these applications. For any questions, please contact fieldengineering@voltdb.com.
Before running these scripts you need to have VoltDB 4.0 or later installed, and the bin subdirectory should be added to your PATH environment variable. For example, if you installed VoltDB Enterprise 4.5 in your home directory, you could add it to the PATH with the following command:
export PATH="$PATH:$HOME/voltdb-ent-4.5/bin"
Start the web server
./run.sh start_web
Start the database and client
./run.sh demo
Open a web browser to http://hostname:8081
To stop the demo:
Stop the client (if it hasn't already completed)
Ctrl-C
Stop the database
voltadmin shutdown
Stop the web server
./run.sh stop_web
You can control various characteristics of the demo by modifying the parameters passed into the NbboBenchmark java application in the "client" function within the run.sh script.
Speed & Duration:
--duration=120 (benchmark duration in seconds)
--autotune=true (true = ignore rate limit, run at max throughput until latency is impacted)
(false = run at the specified rate limit)
--ratelimit=20000 (when autotune=false, run up to this rate of requests/second)
Before running this demo on a cluster, make the following changes:
On each server, edit the run.sh file to set the HOST variable to the name of the first server in the cluster:
HOST=voltserver01
On each server, edit db/deployment.xml to change hostcount from 1 to the actual number of servers:
On each server, start the database
./run.sh server
On one server, Edit the run.sh script to set the SERVERS variable to a comma-separated list of the servers in the cluster
SERVERS=voltserver01,voltserver02,voltserver03
Run the client script:
./run.sh client