EECS 3214 : Programming Assignment 1
Submit this assignment using the submit command (see the instructions below). The deadline is February 16, 10 am.
Getting familiar with client-server programming
Objective:
The objective of this lab is to get familiar with TCP/IP, and then build the skeleton of a very simple distributed messaging system. The system should allow you to log on to a server and exchange messages with other people logged on to the same server.
The application you will write for this assignment implements a directory server. The second part (next assignment) will implement interaction between peers. Note that the first part is a pure client server architecture and the second is a peer-to-peer application.
For this assignment, you should write a client/server application that does the following.
-
The concurrent server program runs waiting for a connection from a
client.
- The clients and the server should (in general) run on different machines.
-
Each client can send three different messages -- JOIN, LEAVE and LIST. The first two are for joining and leaving the list of players who are online and are
willing to play. The last is to retrieve the list of online players. The
server responds to these messages with the appropriate actions. Note that the
server needs to be concurrent because multiple clients should be able to talk
to it simultaneously.
-
This is meant to be a skeletal program, and you probably will need to impose
some limitations; that is fine, just state them clearly.
- You will lose points if your program does not close the sockets
when the program quits.
-
In order to prevent two students from using the same socket number on the
same machine, you should use the socket number that is 20000 + x, where x is
the last 4 digits of your student number.
-
You may use C/C++ or Java.
-
Check the class page for clarifications etc.
-
You can download the basic client server code in the language of your choice from any site, but please cite that source in your report and code. Not doing so is a breach of academic honesty. For your convenience, here are very short barebones java code for a seqential server and client. Some host names in one of the undergrad labs (LAS 1004) are ptl10,....,ptl23.
Compiling the server and client
programs (C language only)
-
Compile the programs with gcc instead of cc.
-
For the server program, you need the -lsocket flag
-
For the client program, you need the flags -lsocket -lnsl
Instructions for submitting
assignment 1
Submit the programs using the following command:
- submit 3214 a1 <filename>.
- Read the manpages ("man submit") for more details on the submit command. You can also use the web interface to the submit command.
- It may not be possible to submit the files after the deadline.
-
The programs you submit should work and be documented.
-
Your assignment should include a separate (typed) document containing the
results (You can hand this in the class). This document should contains details
of
-
the overall program design, a textual description of "how it works", and
design decisions made.
-
possible improvements and extensions to your program that you would do if you
had more time.
-
situations (if any) when your program may not work correctly.
-
how the grader can compile and run your program.
Demonstration
The TA may ask you to demonstrate to her that your program works on the departmental Linux machines. You will run the server, and 4 clients and show that the program implements the specifications described above.
Grading
Program works correctly : 40%
quality of code and in-line documentation : 25%
report : 35%
NOTE: Late submissions get no credit.
Copying, teamwork
Modifying the skeleton programs for client server programs is permitted. Otherwise, copying of programs (also written homeworks and exams) or teamwork on
an assignment (written or programming) is not permitted. No form
of copying is tolerated in this (or any) course, in accordance with
departmental policy.