Computer Networks CS3516 B Term, 2013

Size: px
Start display at page:

Download "Computer Networks CS3516 B Term, 2013"

Transcription

1 Computer Networks CS3516 B Term, 2013 Project 1 Project Assigned: October 31 Checkpoint: November 07 12:01 AM Due: November 14 12:01 AM Networks - Project 1 1

2 What You Will Do In This Project. The purpose of this project is to build a simple Web Server and Web Client. This project to be developed in several stages. It must be written in either C or C++. You have two tasks before you: 1. Develop a multithreaded server that can display the contents of the http GET message. You will use a standard browser to generate this message. 2. Build a client (browser), complete the server, and be able to download.html and.jpg files. An overview of all this is shown on the next slide. Networks - Project 1 2

3 What You Will Do In This Project. Client Server Target File Result Firefox or other commercial browser Checkpoint Your browser Your multithreaded server that prints out client requests Your multithreaded server that prints out client requests None actually accessed. None actually accessed. Server prints out text delivered from client Server prints out comparable text as came from commercial browser. Your browser Your multithreaded server that delivers files to the client Gettysburg.html Your browser prints out the text from Gettysburg.html. Your server prints out client text and target filename. Your browser The Apache server in the CS Department Your browser prints out the text that Apache sends it. Commercial browser Your multithreaded server that delivers files to the client MyJpg.jpg The jpg is visible on the browser. Networks - Project 1 3

4 What You Will Do In This Project. Submission Submission is in two parts: Checkpoint: For the checkpoint submission you need to provide the following: The partially completed web server (.c and.h files) A makefile that compiles this web server code (Tutorial on writing a makefile) Combine (via zip or tar) everything up into a single archive file named "your-wpi-login_project1.zip". Submit your document electronically via Instruct Assist ( by 12:01AM on the day the assignment is due. Make sure you choose "Project 1 Checkpoint" under project drop-down in IA before uploading the zip file. Final: For the final submission you need to provide the following: All the code for the web client and the web server (.c and.h files) A makefile that compiles the client and the server code (Tutorial on writing a makefile) A ReadMe (txt) file that spells out exactly how to compile and run the client and the server The file Gettysburg.html. The file MyJpg.jpg that you have created. Combine (via zip or tar) everything up into a single archive file named "your-wpi-login_project1.zip". Submit your document electronically via Instruct Assist ( by 12:01AM on the day the assignment is due. Make sure you choose "Project 1 Final" under project drop-down in IA before uploading the zip file. Networks - Project 1 4

5 What You Will Do In This Project. Grading Grade breakdown (%) assuming all documents are present: Checkpoint Submitted, compiles and executes = 10% Your Web client displays Gettysburg.html generated by your server = 25% Your Web client displays an.html generated by apache = 25% A commercial browser displays the.jpg served up by your server = 25% Makefile = 5% Successful Show and Tell for the staff = 15% Description of marking for late submissions is given on the course webpage. The grade will be a ZERO if: The code (client or server) does not compile or gives a run-time error To get the FULL CREDIT for the Web client and Web server: The client should obtain the entire html file from the server it is talking to, when its HTTP request succeeds. And your client/server should act appropriately if a non-existent file is requested. Your server should be multi-threaded and able to handle multiple simultaneous requests. Networks - Project 1 5

6 What You Will Do In This Project. Specifications These are expanded in the remaining slides The HTTP Server Execution: Your server should start first (i.e., before the client) and take a command line argument specifying a port number. For example,./myserver <port-number> The HTTP Client Execution: Your client should take command line arguments and then use the GET method to download a web-page. The arguments are as follows: The server URL ( or an IP address ( ) The port number on which to contact the server The path to the target file For example:./myclient <server-url> <port-number> <Path-To-File> Networks - Project 1 6

7 What You Will Do In This Project. Useful Notes: You must chose a server port number larger that 1023 (to be safe, choose a server port number larger than 5000). When you connect to ccc.wpi.edu, you may get hostnames other than cccworks3.ccc.wpi.edu (as given the examples above). Please use the command hostname to find out where you are connected. I would strongly suggest that you follow the order given in the What You Will Do Table. In writing your code, make sure to check for an error return from your system calls or method invocations, and display an appropriate message. In C this means checking andhandling error return codes from your system calls. If you need to kill a background process after you have started it, you can use the UNIX kill command. Use the UNIX ps command to find the process id of your server. Make sure you perform error handling and close every socket that you use in your program. If you abort your program, the socket may still hang around and the next time you try and bind a new socket to the port ID you previously used (but never closed), you may get an error. On UNIX systems, you can run the command "netstat" to see which port numbers are currently assigned. Networks - Project 1 7

8 Building a Multi-Threaded Web Server In this Project you will develop a Web Server and a Browser (client). Your multi-threaded Web server will be capable of processing multiple simultaneous service requests in parallel. Your browser will be able to print out the text of the data sent to it. We will demonstrate that your Web server is capable of delivering various page types to a Web browser. You are going to implement version 1.0 of HTTP, as defined in RFC 1945, where separate HTTP requests are sent for each component of the Web page. The server will be able to handle multiple simultaneous service requests in parallel. This means that the Web server is multi-threaded. In the main thread, the server listens to a fixed port. When it receives a TCP connection request, it sets up a TCP connection through another port and services the request in a separate thread. Networks - Project 1 8

9 Overview Of Operation Web Browser Your Web Server Connect Send Receive Accept( new_socket ) Create_thread Receive Send New Thread Networks - Project 1 9

10 Building a Multi-Threaded Web Server To simplify this programming task, we will develop the code in multiple stages. In the first stage, you will write a multi-threaded server that simply displays the contents of the HTTP request message that it receives. After this program is running properly, you will add the code required to generate an appropriate response. As you are developing the code, you can test your server from a Commercial web browser. But remember that you are not serving through the standard port 80, so you need to specify the port number within the URL that you give to your browser. For example, if your machine's name is ccwork3.wpi.edu, and if your server is listening to port 6789, and if you want to retrieve the file index.html, then you would specify the following URL within the browser: ccwork3.wpi.edu :6789/index.html If you omit ":6789", the browser will assume port 80 which will either not have a server listening on it or will have apache listening if apache is running on the target machine. When the server encounters an error, it sends a response message with the appropriate HTML source so that the error information is displayed in the browser window. Networks - Project 1 10

11 Web Server Development In the following steps, we will go through the code for the first implementation of our Web Server. Our first implementation of the Web server will be multi-threaded, where the processing of each incoming request will take place inside a separate thread of execution. This allows the server to service multiple clients in parallel, or to perform multiple file transfers to a single client in parallel. When we create a new thread of execution, we need to pass to the Thread, information about the socket that s just been accepted from the remote browser. See the diagram on the next page to better understand this. Networks - Project 1 11

12 Web Server Skeleton For your amusement and edification, the code for a working multithreaded program is given here. You would be wise to run that program just to see how it works. And you would also be wise to use this code as the starting point for your web server. You can then insert network-specific code into this multithreaded example. The skeleton of your Web server is contained in that multithreaded example from the file. #include <stdio.h> #include <pthread.h> #include <sys/resource.h> #include <asm/errno.h> int WorkThread( void * ); // Prototype unsigned int CreateAThread( void *, int *); // Prototype // /////////////////////////////////////////////////////////////////////// // This is the main() code - it is the original thread // /////////////////////////////////////////////////////////////////////// main() { unsigned int CurrentPriority, MyPid; unsigned int NewThreadID; // Create a new thread that will start executing at location WorkThread NewThreadID = CreateAThread( (void *)(*WorkThread), &data); // Other main code } // End of main // This is the new thread that's created int WorkThread( void *data ) { } // End of WorkThread Networks - Project 1 12

13 Web Server Skeleton Next, we open a socket and wait for a TCP connection request. Because we will be servicing request messages indefinitely, we place the accept operation inside of an infinite loop. This means we will have to terminate the Web server by pressing ^C on the keyboard. // Get the port number via the command line // Establish the socket that will be used for listening fd = socket(????? ) // Do a bind of that socket bind( fd,???? ) // Set up to listen listen( fd,??? ) fdlisten = fd; while( TRUE ) { // Do the accept fdconn = accept( fdlisten,???? ) } Networks - Project 1 13

14 Web Server Skeleton When a connection request is received, we create a thread, passing to that thread a reference to the new Socket, fdconn, that represents our established connection with the client. The thread creation routine wants data of type (void *) so we cast fdconn going into the routine, and then cast it back when we get into WorkThread. while(true) { // Do the accept fdconn = accept( fdlisten,???? ) out = CreateAThread( (void *)(*WorkThread), &fdconn); } // End of while } // End of main // This is the new thread that's created int WorkThread( void *data ) { int fdconn; fdconn = (int)data; } // End of WorkThread After the new thread has been created, execution in the main thread returns to the top of the while loop. The main thread will then block on accept, waiting for another TCP connection request, while the new thread continues running. When another browser request is received, the main thread goes through the same thread creation regardless of whether the previous thread has finished execution or is still running. Networks - Project 1 14

15 Web Server Skeleton Now, let's develop the code within WorkThread. Here are the steps we need to follow: 1. We alloc an input buffer to hold the data we re getting from the client zero it out. 2. Then we get the client s request message which we do with a recv(). The amount of data taken in will be the lesser of the amount of data in the system ready to be received, OR the size of our buffer. Recv returns the number of bytes it s received so we keep reading until nothing more is taken in. 3. We could take in 1 byte or we could take in up to BUFFERSIZE bytes with each recv we don t know so we just keep reading until we don t get anything more. The checkpoint includes the server code you ve written up to this point. Networks - Project 1 15

16 Web Client / Browser Continuing with the outline shown at the beginning, your next task is to build your client. Begin by getting the starter code. One of your tasks requires that your command line accepts a URL OR an IP address here s some sample code for your amusement. You might as well also get the file Gettysburg.html that you will use to demonstrate that your system is successful. You will be using your own.jpg file something of interest to you, but you may want to also download the file I used. The starter code gives you a great outline of what you need to do. Find resources that will guide you to fill in the missing pieces. From your previous work, you know what a browser request looks like your server has been printing that out for you. Design this client so it produces a request formatted the way a server wants it. When you use your client to look at a website you can see the format that a server uses to send information back to the client. Networks - Project 1 16

17 Web Server Part 2 Instead of simply terminating the thread after displaying the browser's HTTP request message (as done previously), you will analyze the request and send an appropriate response. Here are the steps you might follow: 1) Check that the client really gave us a GET request. 2) Extract and massage the filename the client wants to see. Check out the C library routines Strncmp, Strcpy, Strncat, and Strchr. You may find them useful. 3) After you ve extracted the filename from the browser string, print it out as you have been doing. (Make sure that you precede the filename with a./ so that the file is required to exist in your current directory otherwise the browser could be asking for any file in your entire directory structure.) 4) If the file does not exist, pass back a 404 error message to the client. 5) If the file, Gettysburg.html, does exist, prepare a header and then pass back the file to the client. (You will be reading from a file and writing to the network. 6) The client should be prepared to print out the contents of the file that it receives from the webserver. Networks - Project 1 17

18 Web Server Part 2 When the file exists, we need to determine the file's MIME type and send the appropriate MIME-type specifier back to the client.. We make this determination by examining the file s extension. which returns a string that we can include in the content type line that we are constructing. A file with extension.html has MIME of "text/html A file with extension.ram has MIME of "audio/x-pn-realaudio A file with extension.jpg has MIME of image/jpg You will have figured out how to use this information by examining the headers being sent back and forth between client and server. This completes the code for the second phase of development of your Web server. Try running the server from the directory where your Gettysburg.html and your.jpg are located, and try viewing the.html file with your browser. Networks - Project 1 18

Web Server Project. Tom Kelliher, CS points, due May 4, 2011

Web Server Project. Tom Kelliher, CS points, due May 4, 2011 Web Server Project Tom Kelliher, CS 325 100 points, due May 4, 2011 Introduction (From Kurose & Ross, 4th ed.) In this project you will develop a Web server in two steps. In the end, you will have built

More information

Programming Assignment 3

Programming Assignment 3 UNIVERSITY OF NEBRASKA AT OMAHA Computer Science 3550 Section 002 Communication Networks Spring 2018 Programming Assignment 3 Introduction Having created a TCP client in programming assignment 2, it s

More information

Project 2 Group Project Implementing a Simple HTTP Web Proxy

Project 2 Group Project Implementing a Simple HTTP Web Proxy Project 2 Group Project Implementing a Simple HTTP Web Proxy Overview: This is a group project. CPSC 460 students are allowed to form a group of 3-4 students (It is ok if you want to take it as an individual

More information

Project 2 Implementing a Simple HTTP Web Proxy

Project 2 Implementing a Simple HTTP Web Proxy Project 2 Implementing a Simple HTTP Web Proxy Overview: CPSC 460 students are allowed to form a group of up to 3 students. CPSC 560 students each must take it as an individual project. This project aims

More information

CSSE 460 Computer Networks Group Projects: Implement a Simple HTTP Web Proxy

CSSE 460 Computer Networks Group Projects: Implement a Simple HTTP Web Proxy CSSE 460 Computer Networks Group Projects: Implement a Simple HTTP Web Proxy Project Overview In this project, you will implement a simple web proxy that passes requests and data between a web client and

More information

HTTP Server Application

HTTP Server Application 1 Introduction You are to design and develop a concurrent TCP server that implements the HTTP protocol in the form of what is commonly called a web server. This server will accept and process HEAD and

More information

Computer Networks - A Simple HTTP proxy -

Computer Networks - A Simple HTTP proxy - Computer Networks - A Simple HTTP proxy - Objectives The intent of this assignment is to help you gain a thorough understanding of: The interaction between browsers and web servers The basics of the HTTP

More information

Computer Networks. Project 3. Project Assigned: December 2 Due: December 17 12:01 AM Show and Tell: December Networks - Project 3 1

Computer Networks. Project 3. Project Assigned: December 2 Due: December 17 12:01 AM Show and Tell: December Networks - Project 3 1 Computer Networks Project 3 Project Assigned: December 2 Due: December 7 2:0 AM Show and Tell: December 7-9 Networks - Project 3 Description In this assignment you will be asked to implement a distributed

More information

Project #1: Tracing, System Calls, and Processes

Project #1: Tracing, System Calls, and Processes Project #1: Tracing, System Calls, and Processes Objectives In this project, you will learn about system calls, process control and several different techniques for tracing and instrumenting process behaviors.

More information

Problem Set 4 Due: Start of class, October 5

Problem Set 4 Due: Start of class, October 5 CS242 Computer Networks Handout # 8 Randy Shull September 28, 2017 Wellesley College Problem Set 4 Due: Start of class, October 5 Reading: Kurose & Ross, Sections 2.5, 2.6, 2.7, 2.8 Problem 1 [4]: Free-riding

More information

Lab Assignment 3 for ECE374

Lab Assignment 3 for ECE374 Lab Assignment 3 for ECE374 Posted: 02/25/18 Due: 03/08/18 In this lab, we ll take a quick look at the UDP and TCP transport protocol. Whenever possible you should hand in a Wireshark screenshot that you

More information

Project 1. 1 Introduction. October 4, Spec version: 0.1 Due Date: Friday, November 1st, General Instructions

Project 1. 1 Introduction. October 4, Spec version: 0.1 Due Date: Friday, November 1st, General Instructions Project 1 October 4, 2013 Spec version: 0.1 Due Date: Friday, November 1st, 2013 1 Introduction The sliding window protocol (SWP) is one of the most well-known algorithms in computer networking. SWP is

More information

CS 450 Introduction to Networking Spring 2014 Homework Assignment 1 File Transfer and Data Bandwidth Analysis Tool

CS 450 Introduction to Networking Spring 2014 Homework Assignment 1 File Transfer and Data Bandwidth Analysis Tool CS 450 Introduction to Networking Spring 2014 Homework Assignment 1 File Transfer and Data Bandwidth Analysis Tool Due: Monday 17 February. Electronic copy due at 10:30 A.M., Optional paper copy may be

More information

Project 1: A Web Server Called Liso

Project 1: A Web Server Called Liso Project 1: A Web Server Called Liso 15-441/641 Computer Networks Kenneth Yang Viswesh Narayanan "What happens when you type google.com into your browser's address box and press enter?"... Establish a TCP

More information

Project-2 Continued. Subhojeet Mukherjee CSU Database and Security Research Group

Project-2 Continued. Subhojeet Mukherjee CSU Database and Security Research Group Project-2 Continued Subhojeet Mukherjee CSU Database and Security Research Group Storyboard IP: 129.82.34.24 IP: 129.62.14.90 IP: 219.65.74.90 IP: 219.62.21.91 I know what you did last summer from this

More information

Total Points 100 (One Hundred)

Total Points 100 (One Hundred) Project 2: Implementing Reliable Data Transfer Protocol (CS3516 A18) Due: Sep 28, 2018 F, 11:59 PM Total Points 100 (One Hundred) 1. Overview In this programming assignment, you will be writing the sending

More information

CS 118 Project Phase 2 P2P Networking

CS 118 Project Phase 2 P2P Networking CS 118 Project Phase 2 P2P Networking Due Monday, March 15 th at 11:59pm Boelter Hall 4428, Box D3/C4 and via Electronic Submission Overview In this phase you will extend your work from Phase 1 to create

More information

MP 1: HTTP Client + Server Due: Friday, Feb 9th, 11:59pm

MP 1: HTTP Client + Server Due: Friday, Feb 9th, 11:59pm MP 1: HTTP Client + Server Due: Friday, Feb 9th, 11:59pm Please read all sections of this document before you begin coding. In this assignment, you will implement a simple HTTP client and server. The client

More information

6.824 Lab 2: A concurrent web proxy

6.824 Lab 2: A concurrent web proxy Page 1 of 6 6.824 - Fall 2002 6.824 Lab 2: A concurrent web proxy Introduction In this lab assignment you will write an event-driven web proxy to learn how to build servers that support concurrency. For

More information

Compilers Project 3: Semantic Analyzer

Compilers Project 3: Semantic Analyzer Compilers Project 3: Semantic Analyzer CSE 40243 Due April 11, 2006 Updated March 14, 2006 Overview Your compiler is halfway done. It now can both recognize individual elements of the language (scan) and

More information

LECTURE 10. Networking

LECTURE 10. Networking LECTURE 10 Networking NETWORKING IN PYTHON Many Python applications include networking the ability to communicate between multiple machines. We are going to turn our attention now to the many methods of

More information

Practicum 5 Maps and Closures

Practicum 5 Maps and Closures Practicum 5 Maps and Closures Assignment Details Assigned: February 18 th 2014. Due: February 20 th, 2014 at midnight. Background One of the requirements of PA1 Part 2 using a data structure to hold function

More information

Web Client And Server

Web Client And Server Web Client And Server Project Part A Overview In this part of the project, you and your partner will build a simple web client and a succession of servers to which it can connect. The goal is to slowly

More information

CS143 Handout 05 Summer 2011 June 22, 2011 Programming Project 1: Lexical Analysis

CS143 Handout 05 Summer 2011 June 22, 2011 Programming Project 1: Lexical Analysis CS143 Handout 05 Summer 2011 June 22, 2011 Programming Project 1: Lexical Analysis Handout written by Julie Zelenski with edits by Keith Schwarz. The Goal In the first programming project, you will get

More information

The print queue was too long. The print queue is always too long shortly before assignments are due. Print your documentation

The print queue was too long. The print queue is always too long shortly before assignments are due. Print your documentation Chapter 1 CS488/688 F17 Assignment Format I take off marks for anything... A CS488 TA Assignments are due at the beginning of lecture on the due date specified. More precisely, all the files in your assignment

More information

Program Assignment 2

Program Assignment 2 Program Assignment 2 CMSC 417 Fall 2014 September 16, 2014 1 Deadline September 30, 2014. 2 Objective In this assignment you will write the server program which will communicate using sockets with the

More information

CS 322 Operating Systems Programming Assignment 4 Writing a memory manager Due: November 16, 11:30 PM

CS 322 Operating Systems Programming Assignment 4 Writing a memory manager Due: November 16, 11:30 PM CS 322 Operating Systems Programming Assignment 4 Writing a memory manager Due: November 16, 11:30 PM Goals To understand the nuances of building a memory allocator. To create a shared library. Background

More information

ECE 650 Systems Programming & Engineering. Spring 2018

ECE 650 Systems Programming & Engineering. Spring 2018 ECE 650 Systems Programming & Engineering Spring 2018 Programming with Network Sockets Tyler Bletsch Duke University Slides are adapted from Brian Rogers (Duke) Sockets We ve looked at shared memory vs.

More information

Peer to Peer Instant Messaging

Peer to Peer Instant Messaging Peer to Peer Instant Messaging Assignment in Computer Networks I, Department of Information Technology, Uppsala University. Overview In this assignment you will implement an instant messaging system that

More information

CS 105, Spring 2015 Ring Buffer

CS 105, Spring 2015 Ring Buffer CS 105, Spring 2015 Ring Buffer March 10, 2015 1 Introduction A ring buffer, also called a circular buffer, is a common method of sharing information between a producer and a consumer. In class, we have

More information

A programmer can create Internet application software without understanding the underlying network technology or communication protocols.

A programmer can create Internet application software without understanding the underlying network technology or communication protocols. CS442 Comer Networking API Chapter 3 Chapter three of the textbook presents an API to perform network programming in the C language. While this chapter does not cover everything about network programming,

More information

Slide Set 6. for ENCM 339 Fall 2017 Section 01. Steve Norman, PhD, PEng

Slide Set 6. for ENCM 339 Fall 2017 Section 01. Steve Norman, PhD, PEng Slide Set 6 for ENCM 339 Fall 2017 Section 01 Steve Norman, PhD, PEng Electrical & Computer Engineering Schulich School of Engineering University of Calgary October 2017 ENCM 339 Fall 2017 Section 01 Slide

More information

CMSC 332 Computer Networking Web and FTP

CMSC 332 Computer Networking Web and FTP CMSC 332 Computer Networking Web and FTP Professor Szajda CMSC 332: Computer Networks Project The first project has been posted on the website. Check the web page for the link! Due 2/2! Enter strings into

More information

CSCI 1100L: Topics in Computing Spring 2018 Web Page Project 50 points

CSCI 1100L: Topics in Computing Spring 2018 Web Page Project 50 points CSCI 1100L: Topics in Computing Spring 2018 Web Page Project 50 points Project Due (All lab sections): Check on elc Assignment Objectives: Lookup and correctly use HTML tags. Lookup and correctly use CSS

More information

Final Project: LC-3 Simulator

Final Project: LC-3 Simulator Final Project: LC-3 Simulator Due Date: Friday 4/27/2018 11:59PM; No late handins This is the final project for this course. It is a simulator for LC-3 computer from the Patt and Patel book. As you work

More information

New York University Computer Science Department Courant Institute of Mathematical Sciences

New York University Computer Science Department Courant Institute of Mathematical Sciences New York University Computer Science Department Courant Institute of Mathematical Sciences Course Title: Data Communications & Networks Course Number: g22.2662-001 Instructor: Jean-Claude Franchitti Session:

More information

CS 322 Operating Systems Programming Assignment 4 Writing a memory manager Due: April 5, 11:30 PM

CS 322 Operating Systems Programming Assignment 4 Writing a memory manager Due: April 5, 11:30 PM CS 322 Operating Systems Programming Assignment 4 Writing a memory manager Due: April 5, 11:30 PM Goals To understand the nuances of building a memory allocator. To create a shared library. Background

More information

EECE.2160: ECE Application Programming

EECE.2160: ECE Application Programming Spring 2018 Programming Assignment #10: Instruction Decoding and File I/O Due Wednesday, 5/9/18, 11:59:59 PM (Extra credit ( 4 pts on final average), no late submissions or resubmissions) 1. Introduction

More information

COSC 2206 Internet Tools. The HTTP Protocol

COSC 2206 Internet Tools. The HTTP Protocol COSC 2206 Internet Tools The HTTP Protocol http://www.w3.org/protocols/ What is TCP/IP? TCP: Transmission Control Protocol IP: Internet Protocol These network protocols provide a standard method for sending

More information

Project 1: Web Client and Server

Project 1: Web Client and Server Project 1: Web Client and Server Overview In this part of the project, your group will build a simple web client and a succession of servers to which it can connect. In addition you, will learn how to

More information

Lab 0. Yvan Petillot. Networks - Lab 0 1

Lab 0. Yvan Petillot. Networks - Lab 0 1 Lab 0 Yvan Petillot Networks - Lab 0 1 What You Will Do In This Lab. The purpose of this lab is to help you become familiar with the UNIX/LINUX on the lab network. This means being able to do editing,

More information

CS342 - Spring 2019 Project #3 Synchronization and Deadlocks

CS342 - Spring 2019 Project #3 Synchronization and Deadlocks CS342 - Spring 2019 Project #3 Synchronization and Deadlocks Assigned: April 2, 2019. Due date: April 21, 2019, 23:55. Objectives Practice multi-threaded programming. Practice synchronization: mutex and

More information

CS 326: Operating Systems. Networking. Lecture 17

CS 326: Operating Systems. Networking. Lecture 17 CS 326: Operating Systems Networking Lecture 17 Today s Schedule Project 3 Overview, Q&A Networking Basics Messaging 4/23/18 CS 326: Operating Systems 2 Today s Schedule Project 3 Overview, Q&A Networking

More information

CS155: Computer Security Spring Project #1

CS155: Computer Security Spring Project #1 CS155: Computer Security Spring 2018 Project #1 Due: Part 1: Thursday, April 12-11:59pm, Parts 2 and 3: Thursday, April 19-11:59pm. The goal of this assignment is to gain hands-on experience finding vulnerabilities

More information

UNIVERSITY OF NEBRASKA AT OMAHA Computer Science 4500/8506 Operating Systems Fall Programming Assignment 1 (updated 9/16/2017)

UNIVERSITY OF NEBRASKA AT OMAHA Computer Science 4500/8506 Operating Systems Fall Programming Assignment 1 (updated 9/16/2017) UNIVERSITY OF NEBRASKA AT OMAHA Computer Science 4500/8506 Operating Systems Fall 2017 Programming Assignment 1 (updated 9/16/2017) Introduction The purpose of this programming assignment is to give you

More information

In either case, remember to delete each array that you allocate.

In either case, remember to delete each array that you allocate. CS 103 Path-so-logical 1 Introduction In this programming assignment you will write a program to read a given maze (provided as an ASCII text file) and find the shortest path from start to finish. 2 Techniques

More information

Announcements Fawzi Emad, Computer Science Department, UMCP

Announcements Fawzi Emad, Computer Science Department, UMCP Announcements You must come to lecture for which you are registered! If you are going to be routinely late (or leave early) please try to adjust your class schedule. Look over class webpage Lectures slides

More information

Graduate-Credit Programming Project

Graduate-Credit Programming Project Graduate-Credit Programming Project Due by 11:59 p.m. on December 14 Overview For this project, you will: develop the data structures associated with Huffman encoding use these data structures and the

More information

Project 1: Web Client and Server

Project 1: Web Client and Server Project 1: Web Client and Server Overview In this part of the project, your group will build a simple web client and a succession of servers to which it can connect. In addition you, will learn how to

More information

OBJECT ORIENTED PROGRAMMING

OBJECT ORIENTED PROGRAMMING 1 OBJECT ORIENTED PROGRAMMING Lecture 14 Networking Basics Outline 2 Networking Basics Socket IP Address DNS Client/Server Networking Class & Interface URL Demonstrating URL Networking 3 Java is practically

More information

CS 344/444 Spring 2008 Project 2 A simple P2P file sharing system April 3, 2008 V0.2

CS 344/444 Spring 2008 Project 2 A simple P2P file sharing system April 3, 2008 V0.2 CS 344/444 Spring 2008 Project 2 A simple P2P file sharing system April 3, 2008 V0.2 1 Introduction For this project you will write a P2P file sharing application named HiP2P running on the N800 Tablet.

More information

CS 3305 Intro to Threads. Lecture 6

CS 3305 Intro to Threads. Lecture 6 CS 3305 Intro to Threads Lecture 6 Introduction Multiple applications run concurrently! This means that there are multiple processes running on a computer Introduction Applications often need to perform

More information

Lab 2: Threads and Processes

Lab 2: Threads and Processes CS333: Operating Systems Lab Lab 2: Threads and Processes Goal The goal of this lab is to get you comfortable with writing basic multi-process / multi-threaded applications, and understanding their performance.

More information

Report.doc General design overview of the software Manual.doc How to use the software

Report.doc General design overview of the software Manual.doc How to use the software A1. Structure of the Distributed Files A1.1 Documentation Software Documentation Report.doc General design overview of the software Manual.doc How to use the software ehttp/ API Documentation o HTML/ index.html

More information

Programming Assignment 8 ( 100 Points )

Programming Assignment 8 ( 100 Points ) Programming Assignment 8 ( 100 Points ) Due: 11:59pm Wednesday, November 22 Start early Start often! README ( 10 points ) You are required to provide a text file named README, NOT Readme.txt, README.pdf,

More information

Project Introduction

Project Introduction Project 1 Assigned date: 10/01/2018 Due Date: 6pm, 10/29/2018 1. Introduction The sliding window protocol (SWP) is one of the most well-known algorithms in computer networking. SWP is used to ensure the

More information

Exercise: Calling LAPACK

Exercise: Calling LAPACK Exercise: Calling LAPACK In this exercise, we ll use the same conventions and commands as in the batch computing exercise. You should refer back to the batch computing exercise description for detai on

More information

Fishnet Assignment 1: Distance Vector Routing Due: May 13, 2002.

Fishnet Assignment 1: Distance Vector Routing Due: May 13, 2002. Fishnet Assignment 1: Distance Vector Routing Due: May 13, 2002. In this assignment, you will work in teams of one to four (try to form you own group; if you can t find one, you can either work alone,

More information

162 HW2. David Culler, Arka Bhattacharya, William Liu. September 2014

162 HW2. David Culler, Arka Bhattacharya, William Liu. September 2014 162 HW2 David Culler, Arka Bhattacharya, William Liu September 2014 Contents 1 Introduction 2 1.1 Setup Details........................................... 2 1.2 Structure of HTTP Request...................................

More information

Module 3 Web Component

Module 3 Web Component Module 3 Component Model Objectives Describe the role of web components in a Java EE application Define the HTTP request-response model Compare Java servlets and JSP components Describe the basic session

More information

Eat (we provide) link. Eater. Goal: Eater(Self) == Self()

Eat (we provide) link. Eater. Goal: Eater(Self) == Self() 15-251: Great Theoretical Ideas Guru: Yinmeng Zhang Assignment 12 Due: December 6, 2005 1 Reading Comprehension (0 points) Read the accompanying handout containing Ken Thompson s Turing Award Lecture,

More information

Setting up a ColdFusion Workstation

Setting up a ColdFusion Workstation Setting up a ColdFusion Workstation Draft Version Mark Mathis 2000 all rights reserved mark@teratech.com 2 Setting up a ColdFusion workstation Table of Contents Browsers:...5 Internet Explorer:...5 Web

More information

CSc 450/550 Computer Networks Network Architectures & Client-Server Model

CSc 450/550 Computer Networks Network Architectures & Client-Server Model CSc 450/550 Computer Networks Network Architectures & Client-Server Model Jianping Pan Summer 2007 5/17/07 CSc 450/550 1 Last lectures So far, nuts and bolts views of the Internet Internet evolution and

More information

Module 6 Node.js and Socket.IO

Module 6 Node.js and Socket.IO Module 6 Node.js and Socket.IO Module 6 Contains 2 components Individual Assignment and Group Assignment Both are due on Wednesday November 15 th Read the WIKI before starting Portions of today s slides

More information

CS : Programming for Non-majors, Fall 2018 Programming Project #2: Census Due by 10:20am Wednesday September

CS : Programming for Non-majors, Fall 2018 Programming Project #2: Census Due by 10:20am Wednesday September CS 1313 010: Programming for Non-majors, Fall 2018 Programming Project #2: Census Due by 10:20am Wednesday September 19 2018 This second assignment will introduce you to designing, developing, testing

More information

ENGR 3950U / CSCI 3020U (Operating Systems) Simulated UNIX File System Project Instructor: Dr. Kamran Sartipi

ENGR 3950U / CSCI 3020U (Operating Systems) Simulated UNIX File System Project Instructor: Dr. Kamran Sartipi ENGR 3950U / CSCI 3020U (Operating Systems) Simulated UNIX File System Project Instructor: Dr. Kamran Sartipi Your project is to implement a simple file system using C language. The final version of your

More information

Reliable Data Transmission

Reliable Data Transmission Reliable Data Transmission CS5516: Project 1 Spring 2003 Deadline: Midnight March 13 th, 2003 Score: 100 points Introduction Reliable data transmission protocols form the basis of data communication. The

More information

COMP 3400 Programming Project : The Web Spider

COMP 3400 Programming Project : The Web Spider COMP 3400 Programming Project : The Web Spider Due Date: Worth: Tuesday, 25 April 2017 (see page 4 for phases and intermediate deadlines) 65 points Introduction Web spiders (a.k.a. crawlers, robots, bots,

More information

CS 43: Computer Networks. HTTP September 10, 2018

CS 43: Computer Networks. HTTP September 10, 2018 CS 43: Computer Networks HTTP September 10, 2018 Reading Quiz Lecture 4 - Slide 2 Five-layer protocol stack HTTP Request message Headers protocol delineators Last class Lecture 4 - Slide 3 HTTP GET vs.

More information

Recitation 12: ProxyLab Part 1

Recitation 12: ProxyLab Part 1 Recitation 12: ProxyLab Part 1 Instructor: TA(s) 1 Outline Proxies Networking Networking Demos 2 Proxy Lab There are no grace days / late submissions 8% of final grade You are submitting an entire project

More information

(Worth 50% of overall Project 1 grade)

(Worth 50% of overall Project 1 grade) 第 1 页共 8 页 2011/11/8 22:18 (Worth 50% of overall Project 1 grade) You will do Part 3 (the final part) of Project 1 with the same team as for Parts 1 and 2. If your team partner dropped the class and you

More information

SOCKET PROGRAMMING. What is a socket? Using sockets Types (Protocols) Associated functions Styles

SOCKET PROGRAMMING. What is a socket? Using sockets Types (Protocols) Associated functions Styles LABORATORY SOCKET PROGRAMMING What is a socket? Using sockets Types (Protocols) Associated functions Styles 2 WHAT IS A SOCKET? An interface between application and network The application creates a socket

More information

CS-220 Spring 2016 Project 2 Due: March 23, Warehouse

CS-220 Spring 2016 Project 2 Due: March 23, Warehouse Warehouse Project Description For this project, we will be writing software to be used in a warehouse environment. The job in the warehouse is to assemble kits to send out to customers. Each kit is made

More information

Data Communication EDA344, DIT420 Description of Lab 1 and Optional Programming HTTP Assignment

Data Communication EDA344, DIT420 Description of Lab 1 and Optional Programming HTTP Assignment Data Communication EDA344, DIT420 Description of Lab 1 and Optional Programming HTTP Assignment Aras Atalar Prajith R G 24/01/2018 Overview Lab 1 (Compulsory): WIRESHARK lab General Description Programming

More information

CS 447 : Networks and Data Communications Programming Assignment #02 Total Points: 150

CS 447 : Networks and Data Communications Programming Assignment #02 Total Points: 150 CS 447 : Networks and Data Communications Programming Assignment #02 Total Points: 150 Assigned Date : Tuesday, October 23, 2018 Due Date : Tuesday, November 06, 2018 @ 12:29:59 p.m. Overview Your second

More information

Programming Assignment #4 Arrays and Pointers

Programming Assignment #4 Arrays and Pointers CS-2301, System Programming for Non-majors, B-term 2013 Project 4 (30 points) Assigned: Tuesday, November 19, 2013 Due: Tuesday, November 26, Noon Abstract Programming Assignment #4 Arrays and Pointers

More information

Global Servers. The new masters

Global Servers. The new masters Global Servers The new masters Course so far General OS principles processes, threads, memory management OS support for networking Protocol stacks TCP/IP, Novell Netware Socket programming RPC - (NFS),

More information

Pemrograman Jaringan Web Client Access PTIIK

Pemrograman Jaringan Web Client Access PTIIK Pemrograman Jaringan Web Client Access PTIIK - 2012 In This Chapter You'll learn how to : Download web pages Authenticate to a remote HTTP server Submit form data Handle errors Communicate with protocols

More information

Homework 3 CSC , Spring, 2016

Homework 3 CSC , Spring, 2016 Homework 3 CSC453-001, Spring, 2016 Instructions in previous homeworks also apply to this one. For a coding question that requires coding your BBBK, you also need to be able to demonstrate, upon demand,

More information

Figure 1: Graphical representation of a client-server application

Figure 1: Graphical representation of a client-server application CS/EE 145a : Networking Lab #1 http://www.its.caltech.edu/ eecs145/ Due: October 24, 2007 1 Introduction The development of network-based software has been around for many years. Since its conception,

More information

Lab 4: On Lists and Light Sabers

Lab 4: On Lists and Light Sabers Lab 4: On Lists and Light Sabers Due: March 19th at 11:59pm Overview The goal of this lab is to familiarize yourself with the usage of Lists and their implementations, Array List and Linked. To do so,

More information

Lab 2 Building on Linux

Lab 2 Building on Linux Lab 2 Building on Linux Assignment Details Assigned: January 28 th, 2013. Due: January 30 th, 2013 at midnight. Background This assignment should introduce the basic development tools on Linux. This assumes

More information

15-441: Computer Networks - Project 3 Reliability and Congestion Control protocols for MPEG

15-441: Computer Networks - Project 3 Reliability and Congestion Control protocols for MPEG 15-441: Computer Networks - Project 3 Reliability and Congestion Control protocols for MPEG Project 3 Lead TA: Umair Shah (umair@cs.cmu.edu) Assigned: Friday, October 18, 2002. Due Date: Friday November

More information

Lab 1 Introduction to UNIX and C

Lab 1 Introduction to UNIX and C Name: Lab 1 Introduction to UNIX and C This first lab is meant to be an introduction to computer environments we will be using this term. You must have a Pitt username to complete this lab. NOTE: Text

More information

Advanced Java Programming. Networking

Advanced Java Programming. Networking Advanced Java Programming Networking Eran Werner and Ohad Barzilay Tel-Aviv University Advanced Java Programming, Spring 2006 1 Overview of networking Advanced Java Programming, Spring 2006 2 TCP/IP protocol

More information

HW 2: HTTP Server CS 162. Due: October 5, Introduction Getting Started Setup Details... 2

HW 2: HTTP Server CS 162. Due: October 5, Introduction Getting Started Setup Details... 2 CS 162 Due: October 5, 2015 Contents 1 Introduction 2 1.1 Getting Started.......................................... 2 1.2 Setup Details........................................... 2 2 Background 3 2.1 Structure

More information

CSMC 412. Computer Networks Prof. Ashok K Agrawala Ashok Agrawala Set 2. September 15 CMSC417 Set 2 1

CSMC 412. Computer Networks Prof. Ashok K Agrawala Ashok Agrawala Set 2. September 15 CMSC417 Set 2 1 CSMC 412 Computer Networks Prof. Ashok K Agrawala 2015 Ashok Agrawala Set 2 September 15 CMSC417 Set 2 1 Contents Client-server paradigm End systems Clients and servers Sockets Socket abstraction Socket

More information

It is academic misconduct to share your work with others in any form including posting it on publicly accessible web sites, such as GitHub.

It is academic misconduct to share your work with others in any form including posting it on publicly accessible web sites, such as GitHub. p4: Cache Simulator 1. Logistics 1. This project must be done individually. It is academic misconduct to share your work with others in any form including posting it on publicly accessible web sites, such

More information

CS 2110 Fall Instructions. 1 Installing the code. Homework 4 Paint Program. 0.1 Grading, Partners, Academic Integrity, Help

CS 2110 Fall Instructions. 1 Installing the code. Homework 4 Paint Program. 0.1 Grading, Partners, Academic Integrity, Help CS 2110 Fall 2012 Homework 4 Paint Program Due: Wednesday, 12 November, 11:59PM In this assignment, you will write parts of a simple paint program. Some of the functionality you will implement is: 1. Freehand

More information

CS2 Advanced Programming in Java note 8

CS2 Advanced Programming in Java note 8 CS2 Advanced Programming in Java note 8 Java and the Internet One of the reasons Java is so popular is because of the exciting possibilities it offers for exploiting the power of the Internet. On the one

More information

Welcome to CS 241 Systems Programming at Illinois

Welcome to CS 241 Systems Programming at Illinois Welcome to CS 241 Systems Programming at Illinois Robin Kravets Copyright : University of Illinois CS 241 Staff 1 The Team Robin Kravets Office: 3114 SC rhk@illinois.edu TAs Wade Fagen, Farhana Ashraf,

More information

Programming Standards: You must conform to good programming/documentation standards. Some specifics:

Programming Standards: You must conform to good programming/documentation standards. Some specifics: CS3114 (Spring 2011) PROGRAMMING ASSIGNMENT #3 Due Thursday, April 7 @ 11:00 PM for 100 points Early bonus date: Wednesday, April 6 @ 11:00 PM for a 10 point bonus Initial Schedule due Thursday, March

More information

Project 5 Handling Bit Arrays and Pointers in C

Project 5 Handling Bit Arrays and Pointers in C CS 255 Project 5 Handling Bit Arrays and Pointers in C Due: Thursday, Apr. 30 by 8:00am. No late submissions! Assignment: This homework is adapted from the CS450 Assignment #1 that Prof. Mandelberg uses

More information

CS3114 (Fall 2013) PROGRAMMING ASSIGNMENT #2 Due Tuesday, October 11:00 PM for 100 points Due Monday, October 11:00 PM for 10 point bonus

CS3114 (Fall 2013) PROGRAMMING ASSIGNMENT #2 Due Tuesday, October 11:00 PM for 100 points Due Monday, October 11:00 PM for 10 point bonus CS3114 (Fall 2013) PROGRAMMING ASSIGNMENT #2 Due Tuesday, October 15 @ 11:00 PM for 100 points Due Monday, October 14 @ 11:00 PM for 10 point bonus Updated: 10/10/2013 Assignment: This project continues

More information

Dr. Mohammad Nassiri

Dr. Mohammad Nassiri Bu-Ali Sina University Faculty of Engineering Computer Department Title: Internet Engineering Course Socket Programming Project Instructor: Dr. Mohammad Nassiri Adapted from: Mr. Raja Venkatraman P R s

More information

Problem Set 6 Audio Programming Out of 40 points. All parts due at 8pm on Thursday, November 29, 2012

Problem Set 6 Audio Programming Out of 40 points. All parts due at 8pm on Thursday, November 29, 2012 Problem Set 6 Audio Programming Out of 40 points All parts due at 8pm on Thursday, November 29, 2012 Goals Learn the basics of audio processing in C Learn how to use audio APIs Grading Metrics The code

More information

The Assignment-2 Specification and Marking Criteria

The Assignment-2 Specification and Marking Criteria The Assignment- Specification and Marking Criteria Java RMI (Remote Method Invocation, reference Chapter 5 of the textbook and Week-3 lecture) enables the local invocation and remote invocation use the

More information

Introduction to computer networking

Introduction to computer networking Introduction to computer networking First part of the assignment Academic year 2017-2018 Abstract In this assignment, students will have to implement a client-server application using Java Sockets. The

More information

CS164: Programming Assignment 5 Decaf Semantic Analysis and Code Generation

CS164: Programming Assignment 5 Decaf Semantic Analysis and Code Generation CS164: Programming Assignment 5 Decaf Semantic Analysis and Code Generation Assigned: Sunday, November 14, 2004 Due: Thursday, Dec 9, 2004, at 11:59pm No solution will be accepted after Sunday, Dec 12,

More information

C for C++ Programmers

C for C++ Programmers C for C++ Programmers CS230/330 - Operating Systems (Winter 2001). The good news is that C syntax is almost identical to that of C++. However, there are many things you're used to that aren't available

More information