By Albert, Dean, Emeka, Gianni, and Victor
Clone the repository:
git clone https://github.com/alzh9000/cs262-final-project.git
Ensure that the most recent version of Python is downloaded here
Ensure that correct dependencies are installed by running the following command:
pip install -r requirements.txt
In constants.py, make sure to set the IP/HOST of each respective server before starting. Futhermore, ensure that the NUM_SERVERS
constant matches the number of servers you want the exchange to use.
For example, servers with IDs = 0, 1, 2 have the respective IP's:
SERVER_IPS = {50050: "host_ip_for_server_0", 50051: "host_ip_for_server_1", 50052: "host_ip_for_server_2"}
NUM_SERVERS = 3
To run the servers, splitting the server between different machines/terminals, you can run (where id = 0, 1, or 2).
python exchange.py id
Or to run all NUM_SERVERS
servers in the same terminal using multiprocessing, you can run:
python exchange.py
Then, run the corresponding broker:
python broker.py
Lastly, start the websever that hosts the frontend client application used to interact with the service by running:
python UI/client_application.py
Navigate to the provided webpage, where you can perfom the client interactions. (Note: once the webserver is running, clients from any device can connect.)
Tests are located in the tests/
folder and should run automatically using the python
command, such as by running python tests/exchange_tests.py
. You will need to have the correct host and number of servers set in the constants.py file in order to run the tests correctly. Further tests can be run using the files in the experiments/
directory, such as testing the latency of the exchange or using trading bots to test throughput and correctness.