Ensimag Rubrique Formation 2022

Networking project - 5MMPRA3

  • Number of hours

    • Projects 18.0

    ECTS

    ECTS 3.0

Goal(s)

Development of a Java network application from scratch or from existing libraries to make students sensitive to the implementation and integration of network protocols within a complete prototype (GUI, Parser, ...). Software architectue will be specified and implemented and the compliance of the prototype will be checked against existing applications.

The network application will be a Bittorrent client.

Contact Olivier ALPHAND

Content(s)

Students have to organize their work by themselves, look for any documentation or existing code on the Web, and integrate independent parts into an operational prototype meeting the requirements of scenarios progressively defined by students. The programming language is Java. Besides the teamwork aspect, the project will give you the opportunity to conceive a complete object-oriented architecture and tackle advanced notions of network programming (non blocking sockets (Java.nio), Peer-to-Peer paradigm, Protocol Parser, ...) and simple programming (thread, clean code, design pattern : state machine, observeer, reactor, ...).

You will use a Integrated Development Environment (Eclipse/Netbeans), a version control system (Git) and you will test the compatibility of your network traffic thanks to network tools (Wireshark, ...) or by interacting directly with existing applications.

At last, you will test the performances (Jprofiler, network throughput, ...) of your application through an automated scenario aiming at seeding/leeching on bulky file among several existing bittorrent clients on different machines from the local Ensimag network. Comparing the performances of client from different groups in a similar scenario could fuel discussions about the efficiency of implemented downloading strategies.



Prerequisites

Prerequisites: 2nd year Computer Networks course and labs, Java object-oriented programming, Network tools (Wireshark)

Test

project source code, final report and prototype demonstration



N1=code + rapport + démonstration prototype à la fin du projet
<br>
Pas de rattrapage en 2ème session

Additional Information

Curriculum->Embedded Systems & Connect. Devices->Semester 9