Integrated project for Telecommunications systems and Distributed Systems courses at the University of Antwerp.
For more specific information, see READMEs in subdirectories.
chat-app is a CLI java application which allows users to communicate with each other using a server-clients architecture (with Apache Avro).
Using the application, clients can chat with one another in public or private chat mode.
Video streaming is also supported. Features which are implemented are listed in features.txt.
More information about the implementation can be found in architecture.txt.
Implementation of the Resource ReSerVation Protocol (RFCs 2205 and 2210) in userlevel Click.
A video session in the chat-app will, using custom components in Click, set up a path reservation with RSVP. The reservation can also be set up outside of the chat-app.
Videos can be streamed with Quality of Service. Video streaming is possible in one or in both ways between two clients.
To make the QoS reservation work, certains scripts need to be running before the Chat App Clients (see list of steps).
The application will still work without QoS if these scripts are not running.
We use Click scripts (in telecommunications-systems/scripts) which create a virtual network that is limited to 1Mbps. Videos can be streamed with Quality of Service over this virtual network.
- On PC 1:
- run setup_ds_server.sh
- run host2.click -p 10000
- run AppServer
- run AppClient
- Server IP = 192.168.11.1, Client IP = 192.168.11.1
- On PC 2:
- run setup_click.sh
- run ipnetwork.click -p 10000
- run AppClient
- Server IP = 192.168.11.1, Client IP = 192.168.10.1
- Start a private chat session between the two AppClient instances.
- Request a reservation (= send a path message), write "?videoRequest" or "?vr".
- Accept a reservation (= send a resv message and construct reservation path), write "?acceptVideo" or "?av".
- Select a video to stream.
- Generate background traffic from PC 2 to PC 1
- iperf -c 192.168.11.1 -l 9999MB -u -b 500K
- Confirm that the video is streamed with Quality of Service by executing read_statistics.sh on PC 2.
- On PC 2 because read_statistics.sh looks for Click elements in ipnetwork.click
The integration was tested on the university's lab PCs, which had a direct ethernet connection.