An application for performance measuring / testing and personnel training using Event-Driven Architecture, event replay and Apache Kafka.
Good day! This is a prototype branch of the GitHub repository of my Thesis project. Remember to read this file carefully so you will know how to set this project up properly!
The project consists of 3 components:
- NodeUtilityApp - provides GUI for user for easier to interact with the application.
- JavaUtilityApp - intakes data as streams and performs broadcasts to requested clients.
- Kafka Cluster - this component itself is quite self-explanatory.
Sub-components for testings:
- NodeDistributorApp - provides GUI for user for easier to send test data.
- PySorterApp - processes data.
- RubyReporterApp - receives processed data.
- Have NodeJS installed.
cd
to the directory/NodeUtilityApp
.cd
to bothbackapp
,frontapp-react
and runnpm install
of each directory to get required dependencies.- For
backapp
, runnodemon startApp
ornode startApp
or execute a discrete scriptdeploy.sh
. - For
frontapp-react
, runnpm run build
first. Once the process is completed, runserve -s build
or execute a discrete scriptdeploy.sh
.
This is an Apache Kafka application. So make sure it is downloaded first (The version of which recommended by themselves is preferred). Also, it is advised to run Kafka in Linux as many experienced users have proven the app utilizes better resources and possesses better performance than that of Windows. Not to mention the required set up steps in order for Kafka to run in Windows. After that, follow these steps:
- Extract the contents of the downloaded Kafka application. Make sure the Directory path of to it DOES NOT contain any spaces! For example, the path
C:/ProgramData/Broker Server/kafka
is ineligible as it contains a single white space. - Extract the configuration and launch scripts in
Kafka Configs
of the repository into the installation directory of the downloaded Kafka app. cd
to the Kafka application root and run./start-ZK.sh
to start the Zookeeper server first (The syntax is the same regardless of using either WSL or Linux, if you use Linux, make sure that Java is installed beforehand!).- Run
./start-BKx.sh
to start Broker #x (1 -> 2) with x as the broker ID. Currently there are2
brokers, more might be added later. - Perform testings.
- To stop all operations, stop the Kafka brokers first by running
./stop-BKs.sh
. Then run./stop-ZK.sh
to stop the Zookeeper server. DO NOT STOP THE ZOOKEEPER FIRST!
This is a Java application used for receiving data as streams. Follow the steps:
- Have Java installed. More specifically, JDK 16 or higher is preferred.
- Have Maven installed as this App was built using Maven archetype. Either using command line or Visual Studio Code's extension is OK.
cd
tojksa
directory of the App. If command line is preferred, runmvn package
to build the project. If Visual Studio Code's extension is preferred, simply run the project to build it.- Configure the input command line arguments for the Java application as follow
<broker address> <broker port> <socketio address> <socketio port> [enable debug]
Where angle brackets indicate MANDATORY argument whereas square brackets indicate OPTIONAL argument. - To stop the App, use Ctrl + C or Stop button in Visual Studio Code.
- NodeUtilityApp
- Front app: 3000
- Back app: 3001
- JavaUtilityApp
- Broker Ports: 9091 - 9092
- Socket IO Port: 3004
- Testing Apps
- Distributor front app: 3002
- Distributor back app: 3003