CS 10: Problem solving via Object Oriented Programming. Client/Server
|
|
- Martina Atkins
- 5 years ago
- Views:
Transcription
1 CS 10: Problem solving via Object Oriented Programming Client/Server
2 Agenda 1. Sockets 2. Server 3. MulAthreaded server 4. Chat server 2
3 Sockets are a way for computers to communicate IP: HTTP Port: 80 Server Server is listening on a socket (socket = address + protocol + port) Client 1 Client 1 makes connecaon over socket Server receives connecaon, moves communicaaons to own socket Port 80 = HTTP 3
4 Sockets are a way for computers to communicate IP: HTTP Port: 80 Server Server is listening on a socket (socket = address + protocol + port) Port 80 = HTTP Client 1 Client 1 makes connecaon over socket Server receives connecaon, moves communicaaons to own socket Server returns to listening Server talking to Client 1 and ready 4 for others
5 Sockets are a way for computers to communicate IP: HTTP Port: 80 Client 1 Client 2 makes connecaon over socket Server Server is listening on a socket (socket = address + protocol + port) Client 2 Port 80 = HTTP 5
6 Sockets are a way for computers to communicate IP: HTTP Port: 80 Server Server is listening on a socket (socket = address + protocol + port) Port 80 = HTTP Client 1 Client 2 Client 2 makes connecaon over socket Server receives connecaon, moves communicaaons to own socket Server returns to listening Server talking to client 1 and 2 6 ready for others
7 Java provides a convenient Socket class to communicate with servers WWWSocket.java 7
8 Java provides a convenient Socket class to communicate with servers WWWSocket.java Use scanner to read loca3on on CS web server from which user wants to get data String page read from keyboard by scanner Socket: Address Port Protocol Don t forget to close up Open Socket to CS web server on port 80 (standard hbp port) Write out (out from your computer) over Socket to CS web server Read data in from CS web server over Socket into BufferedReader Outputs course web page HTML 8
9 Agenda 1. Sockets 2. Server 3. MulAthreaded server 4. Chat server 9
10 DEMO HelloServer.java: create our own server that listens for clients to connect HelloServer.java Run HelloServer.java Fom terminal type telnet localhost 4242 Quit telnet session with Control + ] then type quit Try connecang from mulaple terminals 10
11 We can create our own server that will listen for clients to connect and respond HelloServer.java Create new ServerSocket listening on port 4242 Port chosen because nothing else there IP: localhost TCP Port: 4242 Pause here un3l someone connects, then create Socket sock for them Server Create output writer and input reader using sock Send output to whomever connected Close up Reader and writer Sockets Read input from client un3l client hangs up (connec3on lost) in.readline() is null on hang up 11
12 We can also create our own client too HelloServer.java and HelloClient.java What is input and what is output is rela3ve to each computer Input to Server is output from Client Output from Server is input to client Code for HelloServer on last slide 12
13 DEMO HelloClient.java: our Client that talks to our Server HelloClient.java Run HelloClient.java (waits for Server to come up) Run HelloServer.java 13
14 Our Client talks to our Server HelloClient.java Setup scanner to read client s keyboard Loop un3l Server answers Output to console what the Server said Create Socket sock on same port as Server (4242) sock will throw excep3on if Server not up, try every 5 seconds un3l it is up Client Got Server connec3on, setup reader and writer Get input from scanner and send to Server If Server hangs up, don t know it un3l you press enter on keyboard. Why? console.nextline() blocks execu3on 14
15 Friends can connect to your server if they connect to the right IP address Run MyIPAdressHelper.java to get your address, edit HelloClient.java Local network router gives inside computers a unique local IP address (e.g., ) Network Address Transla3on (NAT) on local router tells outsiders each inside machine has a different IP address (global address) from what IP address insiders see (e.g., )
16 DEMO: ConnecAng from another machine HelloServer.java and HelloClient.java Run MyIPAddressHelper on server to get IP Start HelloServer.java on server Edit HelloClient.java to change localhost to server IP address Run HelloClient on client machines and make connecaon Connect from student machine? 16
17 Agenda 1. Sockets 2. Server 3. MulAthreaded server 4. Chat server 17
18 Currently our server can only handle one client at a Ame Using Java s Thread mechanism to overcome single client issue We would like our server to talk to mulaple clients at the same Ame (called concurrent users) Trick is to give each client its own socket That way the server can talk concurrently with mulaple clients Java provides a Thread class to handle concurrency (mulaple processes running at same Ame) Threads are much lighter than running mulaple instances of a program (more on threads next class) Inherit from Thread class and override run method Start thread using start method (calls run method) 18
19 We can create a Communicator on a separate thread for each connecaon One Communicator allocated for a single client Communicator Object handles the socket between Server and Client 19
20 We can create a Communicator on a separate thread for each connecaon Mul3ple Communicators allocated for mul3ple clients Create a new Communicator Object on a separate Thread on the server One Communicator for each Client 20
21 DEMO HelloMulAthreadedServer.java: handle mulaple Clients concurrently HelloMul3threadedServer.java Starts new thread with new HelloServerCommunicator on each connecaon HelloServerCommunicator.java Extends Thread Override run Tracks thread ID Otherwise the same as single threaded version Run HelloMul3threadedServer.java with mul3ple telnets 21
22 By using Threads, one Server can handle mulaple concurrent Clients HelloMul3threadedServer.java Create a ServerSocket to listen for incoming connec3ons num keeps track of how many connec3ons have been made Loop forever Put new connec3ons on their own Thread with Communicator setdaemon(true) means stop this Thread when the main Thread ends start() causes a Thread to begin running in Thread Object s run() method Big idea: start a new thread whenever a client connects so this thread can go back to listening for new clients Block un3l Client connects, then return new Socket Pass new ServerSocket on port 4242 to constructor Then call getconnec9ons() 22
23 HelloServerCommunicator runs on its own Thread, handles one Client s connecaon HelloServerCommunicator.java Extends Thread When start() called on Thread, it calls Thread s run() method Save socket to talk to Client and keep id for convenience Print id number so we can track who is communica3ng Setup run() to func3on the same as single- threaded version Now this Thread runs independently of other Threads Handles one Client connec3on Stops when main Thread stops (daemon true) 23
24 Agenda 1. Sockets 2. Server 3. MulAthreaded server 4. Chat server 24
25 DEMO: Chat applicaaon ChatServer.java and ChatClient.java Run MyIPAddressHelper on server to get IP Start ChatSever.java on server Edit ChatClient.java to change localhost to server IP address (in main()) Run ChatClient.java to connect to ChatServer Run ChatClient.java from student machine? 25
26 Goal: Chat server allows communicaaon between mulaple clients Client sends message to server When one Client sends a message, want to broadcast it to all other clients Server coordinates messages Server receives message from Client, then repeats message to all other Clients Message 26
27 Goal: Chat server allows communicaaon between mulaple clients Server broadcasts message to all clients What if a message comes into a Client that is blocking wai3ng for input from keyboard Would like to see message displayed even if typing (or not) Message Message 27
28 Client listens for keyboard on main thread creates Communicator on second thread Client Client uses two threads: 1. Listen for keyboard input (blocks Thread un3l Enter key pressed) 2. Communicates with server on separate Thread (does not block wai3ng for keyboard input) 28
29 ChatServer creates a Communicator for each client Server Both Server and Client side are now mul3- threaded 29
30 ChatServer handles mulaple clients and broadcasts message to each client Client and server Server has one Thread per Client Each Client has two threads 30
31 ChatServer manages one Communicator for each Client ChatServer.java Set up ServerSocket to listen for Client connec3ons Server Communicators Communicator Client Create one Communicator for each Client Keep Communicators in comms ArrayList Set daemon, start Thread running, add to comms Arraylist Block un3l Client connec3on, then create new Communicator running on its own Thread Returns new socket for this Communicator Also pass reference to this Object Add or remove Communicator Object from comms ArrayList 31
32 ChatServer manages one Communicator for each Client ChatServer.java Synchronized keyword makes sure that if two messages arrive at the same 3me, that broadcast finishes the first message before the second Topic of next class Communicators Communicator Client Server Clients will ask Server to broadcast message to all Clients, loop over each Communicator (except Client that sent message) and ask it to send a message to its Client main() set up ServerSocket listening on port
33 Each ChatServerCommunicator runs on own Thread and talks with one Client ChatServerCommunicator.java Extend Thread to run in own thread Communicators Server Communicator Client Save socket to communicate with Client Save ChatServer to communicate with ChatServer Object (e.g., call broadcast()) run() called when Thread is started Set up in reader and out writer as before On any input from Client, call broadcast() on Server broadcast() on Server will call send() on each Communicator (next slide) When Client hangs up, call removecommunicator() on Server and shut down this Thread 33
34 Each ChatServerCommunicator runs on own Thread and talks with one Client ChatServerCommunicator.java Server Communicators Communicator Client When another Client sends a message to the Server via broadcast() method, the Server will call send() on each Communicator to broadcast the message to all Clients 34
35 ChatClient manages keyboard input and creates a ChatClientCommunicator ChatClient.java Set up scanner for keyboard input Communicators Server Communicator Client Create Communicator on another Thread (so not stopped by blocking scanner), start Thread running While Server is connected, tell Communicator to send keyboard messages to Server If Server hangs up, Communicator will call this method to inform ChatClient Object main() calls constructor passing socket on localhost port 4242 then handleuser() 35
36 ChatClientCommunicator runs on its own Thread to communicate with Server ChatClientCommunicator.java Run on own Thread so not blocked by scanner Communicators Server Communicator Client Save socket to communicate with ChatServer Save client to communicate with ChatClient Object Send keyboard message passed by ChatClient Object to Server Read data from ChatServer and write to console If ChatServer hangs up, tell ChatClient Object, then end Thread 36
37 37
Internet Technology 2/7/2013
Sample Client-Server Program Internet Technology 02r. Programming with Sockets Paul Krzyzanowski Rutgers University Spring 2013 To illustrate programming with TCP/IP sockets, we ll write a small client-server
More informationICOM 4015-Advanced Programming. Spring Instructor: Dr. Amir H. Chinaei. TAs: Hector Franqui, Jose Garcia, and Antonio Tapia. Reference: Big Java
ICOM 4015-Advanced Programming Spring 2014 Instructor: Dr. Amir H. Chinaei TAs: Hector Franqui, Jose Garcia, and Antonio Tapia Reference: Big Java By Hortsmann, Ed 4 Lab 7 Continuation of HTTP and Introduction
More informationLab 10: Sockets 12:00 PM, Apr 4, 2018
CS18 Integrated Introduction to Computer Science Fisler, Nelson Lab 10: Sockets 12:00 PM, Apr 4, 2018 Contents 1 The Client-Server Model 1 1.1 Constructing Java Sockets.................................
More informationNetworking and socket communica2on
Networking and socket communica2on CSCI 136: Fundamentals of Computer Science II Keith Vertanen Copyright 2014 Networking basics Overview Difference between: clients and servers Addressing IP addresses,
More informationCS2 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 informationSocket programming. Complement for the programming assignment INFO-0010
Socket programming Complement for the programming assignment INFO-0010 Outline Socket definition Briefing on the Socket API A simple example in Java Multi-threading and Synchronization Example : HTTP protocol
More informationCSCD 330 Network Programming Spring 2018
CSCD 330 Network Programming Spring 2018 Lecture 6 Application Layer Socket Programming in Java Reading for Java Client/Server see Relevant Links Some Material in these slides from J.F Kurose and K.W.
More informationAdvanced 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 informationCSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2013
CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2013 Name: This exam consists of 5 problems on the following 6 pages. You may use your double-sided hand-written 8 ½ x 11 note sheet
More informationCS348: Computer Networks (SMTP, POP3, IMAP4); FTP
CS348: Computer Networks E-MAIL (SMTP, POP3, IMAP4); FTP Dr. Manas Khatua Assistant Professor Dept. of CSE, IIT Guwahati E-mail: manaskhatua@iitg.ac.in Electronic mail (E-mail) Allows users to exchange
More informationCSCD 330 Network Programming
CSCD 330 Network Programming Lecture 8 Client-Server Programming Threads Spring 2017 Reading: Chapter 2, Relevant Links - Threads Some Material in these slides from J.F Kurose and K.W. Ross All material
More informationProgramming Methods Dr Robert Harle
Programming Methods Dr Robert Harle IA NST CS and CST Lent 2008/09 Handout 4 Our Motivating Example We re going to make the world s simplest web server It s not going to challenge apache etc But it will
More informationExcep&ons and Threads
Excep&ons and Threads Excep&ons What do you do when a program encounters an anomalous, unusual event? Try to open a file and it's not there Try to convert a string to an integer and it's not a valid integer
More informationWeek 13 Lab - Exploring Connections & Remote Execution
Week 13 Lab - Exploring Connections & Remote Execution COSC244 & TELE202 1 Assessment This lab is worth 0.5%. The marks are awarded for completing the programming exercise and answering the questions.
More informationCS September 2017
Machine vs. transport endpoints IP is a network layer protocol: packets address only the machine IP header identifies source IP address, destination IP address Distributed Systems 01r. Sockets Programming
More informationCOMP 213. Advanced Object-oriented Programming. Lecture 20. Network Programming
COMP 213 Advanced Object-oriented Programming Lecture 20 Network Programming Network Programming A network consists of several computers connected so that data can be sent from one to another. Network
More informationSRM ARTS AND SCIENCE COLLEGE SRM NAGAR, KATTANKULATHUR
SRM ARTS AND SCIENCE COLLEGE SRM NAGAR, KATTANKULATHUR 603203 DEPARTMENT OF COMPUTER SCIENCE & APPLICATIONS QUESTION BANK (2017-2018) Course / Branch : MCA Semester / Year : EVEN / II Subject Name : Programming
More informationPrevious lecture: threads G51PRG: Introduction to Programming Second semester Lecture 12 URL
Previous lecture: threads G51PRG: Introduction to Programming Second semester Lecture 12 What is a thread Why use multiple threads Issues and problems involved Java threads Natasha Alechina School of Computer
More informationNetworking Code CSCI 201 Principles of Software Development
Networking Code CSCI 201 Principles of Software Development Jeffrey Miller, Ph.D. jeffrey.miller@usc.edu Server Networking Client Networking Program Outline USC CSCI 201L Server Software A server application
More informationCS 5010: PDP. Lecture 11: Networks CS 5010 Fall 2017 Seattle. Adrienne Slaughter, Ph.D.
Lecture 11: Networks CS 5010 Fall 2017 Seattle CS 5010: PDP Adrienne Slaughter, Ph.D. ahslaughter@northeastern.edu Northeastern University 1 Agenda Networking Northeastern University 2 INTRODUCTION Northeastern
More informationCSCD 330 Network Programming
CSCD 330 Network Programming Lecture 8 Client-Server Programming Threads Spring 2018 Reading: Chapter 2, Relevant Links - Threads Some Material in these slides from J.F Kurose and K.W. Ross All material
More informationCSCD 330 Network Programming
CSCD 330 Network Programming Lecture 8 Client-Server Programming Threads Winter 2015 Reading: Chapter 2, Relevant Links Some Material in these slides from J.F Kurose and K.W. Ross All material copyright
More informationCS 10: Problem solving via Object Oriented Programming. Web Services
CS 10: Problem solving via Object Oriented Programming Web Services Big picture: query online photo database Flickr and display results Overview Give me pictures of cats Your computer Flickr photo database
More informationCS 2113 Software Engineering
CS 2113 Software Engineering Java 6: File and Network IO https://github.com/cs2113f18/template-j-6-io.git Professor Tim Wood - The George Washington University Project 2 Zombies Basic GUI interactions
More informationThe Specification of Project-1
The Specification of Project-1 EE122 Introduction to Communication Networks, Fall 2002 Weidong Cui, Karthik Lakshminarayanan, Khian Hao Lim Revision : 1.23 1 Overview In this project, you will build a
More informationGET TO KNOW YOUR HOME PHONE
telstra.com/homephone visit a telstra store 13 2200 HOME FEATURES USER GUIDE GET TO KNOW YOUR HOME PHONE C020 OCT13 ENJOY FEATURES THAT MAKE LIFE EASIER Home features make it easy for you to do more with
More informationJoseph Faber Wonderful Talking Machine (1845)
Joseph Faber Wonderful Talking Machine (1845) Connected World Human-to-Human communication Human-Machine interaction Machine-to-Machine communication (M2M) Internet-of-Things (IOT) Internet of Things How
More informationJava Support for developing TCP Network Based Programs
Java Support for developing TCP Network Based Programs 1 How to Write a Network Based Program (In Java) As mentioned, we will use the TCP Transport Protocol. To communicate over TCP, a client program and
More information10/7/15. MediaItem tostring Method. Objec,ves. Using booleans in if statements. Review. Javadoc Guidelines
Objec,ves Excep,ons Ø Wrap up Files Streams MediaItem tostring Method public String tostring() { String classname = getclass().tostring(); StringBuilder rep = new StringBuilder(classname); return rep.tostring();
More informationCS18000: Programming I
CS18000: Programming I File I/O 22 March, 2010 Prof. Chris Clifton Goal: Make Data Useful Beyond Program Execution Program data stored in variables Okay, a little more than that Arrays Linked data structures
More informationCS 10: Problem solving via Object Oriented Programming. Lists Part 1
CS 10: Problem solving via Object Oriented Programming Lists Part 1 Agenda 1. Defining a List ADT 2. Generics 3. Singly linked list implementaeon 4. ExcepEons 5. Visibility: public vs. private vs. protected
More informationCS 351 Design of Large Programs Java and Socket Communication
CS 351 Design of Large Programs Java and Socket Communication Instructor: Joel Castellanos e-mail: joel@unm.edu 4/6/2017 Transmission Control Protocol The Transmission Control Protocol (TCP) is one of
More informationLesson 11 Transcript: Concurrency and locking
Lesson 11 Transcript: Concurrency and locking Slide 1: Cover Welcome to Lesson 11 of the DB2 on Campus Lecture Series. We are going to talk today about concurrency and locking. My name is Raul Chong and
More information.NET Advance Package Syllabus
Module 1: Introduction to.net Lecture 1: About US: About SiSTech About your self Describe training methodology Lecture 2: What is.net? Application developed in.net Application development Architecture.Net
More informationA Client-Server Exchange
Socket programming A Client-Server Exchange A server process and one or more client processes Server manages some resource. Server provides service by manipulating resource for clients. 1. Client sends
More informationLecture 05 Application Layer - I
Computer Networks and Internet Protocol Prof. Soumya Kanti Ghosh Department of Computer Science and Engineering Indian Institute of Technology, Kharagpur Lecture 05 Application Layer - I Hi. So, we will
More informationCS 455/655 Computer Networks Fall Programming Assignment 1: Implementing a Social Media App Due: Thursday, October 5 th, 2017 (1pm)
CS 455/655 Computer Networks Fall 2017 Programming Assignment 1: Implementing a Social Media App Due: Thursday, October 5 th, 2017 (1pm) To be completed individually. Please review Academic Honesty noted
More informationPieter van den Hombergh Richard van den Ham. March 17, 2018
: Network : Network, Object Pieter van den Hombergh Richard van den Ham Fontys Hogeschool voor Techniek en Logistiek March 17, 2018 /FHTenL : Network March 17, 2018 1/21 Topics, Object Some everyday life
More informationCS 43: Computer Networks. 07: Concurrency and Non-blocking I/O Sep 17, 2018
CS 43: Computer Networks 07: Concurrency and Non-blocking I/O Sep 17, 2018 Reading Quiz Lecture 5 - Slide 2 Today Under-the-hood look at system calls Data buffering and blocking Inter-process communication
More informationLab 2 : Java RMI. request sayhello() Hello interface remote object. local object. response "Hello world"
Lab 2 : Java RMI 1. Goals In this lab you will work with a high-level mechanism for distributed communication. You will discover that Java RMI provides a mechanism hiding distribution in OO programming.
More informationProject-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 informationNetworking: IPv6, UDP and TCP. Network Programming in Java UDP and TCP
Networking: IPv6, UDP and TCP Network Programming in Java UDP and TCP SCOMRED, November 2018 Instituto Superior de Engenharia do Porto (ISEP) Departamento de Engenharia Informática(DEI) SWitCH Computing
More informationCSCI 136: Fundamentals of Computer Science II. Keith Vertanen Museum 102 h8p://ka<e.mtech.edu/classes/csci136
CSCI 136: Fundamentals of Computer Science II Keith Vertanen Museum 102 kvertanen@mtech.edu h8p://ka
More informationCore Java SYLLABUS COVERAGE SYLLABUS IN DETAILS
Core Java SYLLABUS COVERAGE Introduction. OOPS Package Exception Handling. Multithreading Applet, AWT, Event Handling Using NetBean, Ecllipse. Input Output Streams, Serialization Networking Collection
More informationSockets and RMI. CS151 Chris Pollett Dec. 5, 2005.
Sockets and RMI CS151 Chris Pollett Dec. 5, 2005. Outline Echo Server with Multiple Clients Client pull/server push Remote Method Invocation Proxy Pattern Echo Server with Multiple Clients public class
More informationJava for Interfaces and Networks
Java for Interfaces and Networks Threads and Networking Federico Pecora School of Science and Technology Örebro University federico.pecora@oru.se Federico Pecora Java for Interfaces and Networks Lecture
More informationRemedial Java - Excep0ons 3/09/17. (remedial) Java. Jars. Anastasia Bezerianos 1
(remedial) Java anastasia.bezerianos@lri.fr Jars Anastasia Bezerianos 1 Disk organiza0on of Packages! Packages are just directories! For example! class3.inheritancerpg is located in! \remedialjava\src\class3\inheritencerpg!
More informationIT 341: Introduction to System
IT 341: Introduction to System Administration Private IP Addresses and the Internet Using IP Addresses to Communicate Over the Internet Network Address Translation Private IP Addresses and the Internet
More informationCore Java Contents. Duration: 25 Hours (1 Month)
Duration: 25 Hours (1 Month) Core Java Contents Java Introduction Java Versions Java Features Downloading and Installing Java Setup Java Environment Developing a Java Application at command prompt Java
More informationBasics. Once socket is configured, applica6ons. Socket is an interface between applica6on and network
Socket Programming Basics Socket is an interface between applica6on and network Applica6on creates a socket Socket type dictates the style of communica6on Once socket is configured, applica6ons Pass data
More informationReport.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 informationCourse Status Networking GUI Wrap-up. CS Java. Introduction to Java. Andy Mroczkowski
CS 190 - Java Introduction to Java Andy Mroczkowski uamroczk@cs.drexel.edu Department of Computer Science Drexel University March 10, 2008 / Lecture 8 Outline Course Status Course Information & Schedule
More informationJava Programming Unit 7. Error Handling. Excep8ons.
Java Programming Unit 7 Error Handling. Excep8ons. Run8me errors An excep8on is an run- 8me error that may stop the execu8on of your program. For example: - someone deleted a file that a program usually
More informationProgramming 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 informationProject 2 - A Simple Chat Program
Project 2 - A Simple Chat Program Minimum Effort Due: (Part 1) 2/11/2007 (Sunday) Complete Project Due: (Part 2) 2/23/2007 (Friday) Late Project Due: (Last Chance) 2/24/2007 (Saturday) Overview In this
More informationInterlude. Object Oriented Design
Interlude Object Oriented Design Announcements for This Lecture This Week Today is an Interlude Nothing today is on exam Another Big Picture talk Relevant to Assignment 6 Review for exam posted New Review
More informationWeb 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 information3. Remote Procedure Call
3. Remote Procedure Call Master II Software Engineering Imed Bouchrika Dept of Mathematics & Computer Science University of Souk-Ahras imed@imed.ws Imed Bouchrika. Distributed Objects, Uni of Souk-Ahras
More informationChanging Your Call Transfer and Screening Preferences
Changing Your Call Transfer and Screening Preferences Changing Your Call Transfer Preferences, page 2 Changing Your Call Holding Preferences, page 3 Changing Your Call Screening Preferences, page 4 Changing
More informationChapter 4: Processes
Chapter 4: Processes Process Concept Process Scheduling Operations on Processes Cooperating Processes Interprocess Communication Communication in Client-Server Systems 4.1 Process Concept An operating
More informationDistributed Systems Recitation 2. Tamim Jabban
15-440 Distributed Systems Recitation 2 Tamim Jabban Agenda Communication via Sockets in Java (this enables you to complete PS1 and start P1 (goes out today!)) Multi-threading in Java Coding a full Client-Server
More informationCSCD 330 Network Programming Spring 2018
CSCD 330 Network Programming Spring 2018 Lecture 7 Application Layer Socket Programming in Java Reading: Chapter 2, Java links Relevant Links page Some Material in these slides from J.F Kurose and K.W.
More informationProject 3: Chat Application Using Nachos Networking Module *
OpenStax-CNX module: m30811 1 Project 3: Chat Application Using Nachos Networking Module * Duong Anh Duc This work is produced by OpenStax-CNX and licensed under the Creative Commons Attribution License
More informationCSCD 330 Network Programming Winter 2019
CSCD 330 Network Programming Winter 2019 Lecture 7 Application Layer Socket Programming in Java Reading: Chapter 2, Java links Relevant Links page Some Material in these slides from J.F Kurose and K.W.
More informationTHIS EXAMINATION PAPER MUST NOT BE REMOVED FROM THE EXAMINATION ROOM
UNIVERSITY OF LONDON GOLDSMITHS COLLEGE B. Sc. Examination 2012 COMPUTER SCIENCE IS52025A Internet and Distributed Programming Duration: 2 hours 15 minutes Date and time: There are five questions in this
More informationAdvanced Object-oriented Programming
COMP 213 Advanced Object-oriented Programming Lecture 21 Concurrency What is Concurrency? Concurrency is when two or more programs execute at the same time, either: sharing the same processor (multi-threading),
More informationELEC / COMP 177 Fall Some slides from Kurose and Ross, Computer Networking, 5 th Edition
ELEC / COMP 177 Fall 2014 Some slides from Kurose and Ross, Computer Networking, 5 th Edition Project #1 Starts in one week Is your Linux environment all ready? Bring your laptop Work time after quick
More informationSchool of Informatics, University of Edinburgh
CS1Bh Lecture Note 16 Case Study: Client/Server In this case study we look at providing a slightly more realistic client/server application and explore some of the issues that arise in this context. Specifically
More informationApplication Development in JAVA. Data Types, Variable, Comments & Operators. Part I: Core Java (J2SE) Getting Started
Application Development in JAVA Duration Lecture: Specialization x Hours Core Java (J2SE) & Advance Java (J2EE) Detailed Module Part I: Core Java (J2SE) Getting Started What is Java all about? Features
More informationIntroduc)on to Computer Networks
Introduc)on to Computer Networks COSC 4377 Lecture 3 Spring 2012 January 25, 2012 Announcements Four HW0 s)ll missing HW1 due this week Start working on HW2 and HW3 Re- assess if you found HW0/HW1 challenging
More informationLecture 2-ter. 2. A communication example Managing a HTTP v1.0 connection. Managing a HTTP request. transport session. Step 1 - opening transport
Lecture 2-ter. 2 A communication example Managing a HTTP v1.0 connection Managing a HTTP request User digits URL and press return (or clicks ). What happens (HTTP 1.0): 1. opens a TCP transport session
More informationNetwork Protocols - Revision
Network Protocols - Revision Luke Anderson luke@lukeanderson.com.au 18 th May 2018 University Of Sydney Overview 1. The Layers 1.1 OSI Model 1.2 Layer 1: Physical 1.3 Layer 2: Data Link MAC Addresses 1.4
More informationOBJECT 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 informationComplete Java Contents
Complete Java Contents Duration: 60 Hours (2.5 Months) Core Java (Duration: 25 Hours (1 Month)) Java Introduction Java Versions Java Features Downloading and Installing Java Setup Java Environment Developing
More informationLecture 11.1 I/O Streams
21/04/2014 Ebtsam AbdelHakam 1 OBJECT ORIENTED PROGRAMMING Lecture 11.1 I/O Streams 21/04/2014 Ebtsam AbdelHakam 2 Outline I/O Basics Streams Reading characters and string 21/04/2014 Ebtsam AbdelHakam
More informationCONTENTS. Chapter 1 Getting Started with Java SE 6 1. Chapter 2 Exploring Variables, Data Types, Operators and Arrays 13
CONTENTS Chapter 1 Getting Started with Java SE 6 1 Introduction of Java SE 6... 3 Desktop Improvements... 3 Core Improvements... 4 Getting and Installing Java... 5 A Simple Java Program... 10 Compiling
More informationCS 43: Computer Networks. 08:Network Services and Distributed Systems 19 September
CS 43: Computer Networks 08:Network Services and Distributed Systems 19 September Reading Quiz Lecture 8 -Slide 2 Last class Inter-process communication using message passing How send and recv buffers
More informationSockets: Network io HOM DOS HVD HEE. Sockets, Object Streams and Serialization. Sockets. Sockets: Network io HOM DOS HVD HEE
: Network : Network ieter van den Hombergh hijs Dorssers ichard van den Ham Uwe van Heesch, bject Fontys Hogeschool voor echniek en Logistiek April 22, 2016 /FHenL : Network April 22, 2016 1/19 opics :
More informationprotocols September 15,
Contents SCI 351 4 Protocols, WWW Internet applications WWW, document technology Lennart Herlaar Original slides by Piet van Oostrum September 15, 2003 SCI351-4 1 X SCI351-4 1 X Internet applications How
More informationProject 0. Danyang Zhuo CSE sp Sec;on #2
Project 0 Danyang Zhuo CSE 461 15sp Sec;on #2 Proj0 You have to implement: Mul;- UDP Server Mul;- UDP Client Async IO UDP Server Async IO UDP Client Your server must support mul;ple clients Submit Format
More informationMulti-threaded Web Server (Assignment 1) Georgios Georgiadis
Multi-threaded Web Server (Assignment 1) Georgios Georgiadis Overview Multi-threaded Web Server What to do and how to do it HTTP messages Processes and threads ComputerComm '09 2 Multi-threaded Web Server
More informationTCP connections. Fundamentals of Internet Connections Objectives. Connect to an Echo port. java.net.socket
Objectives TCP connections To understand programming of clients that connect to servers via TCP To understand the basics of programming of servers that accept TCP connections To practice programming of
More informationNetworking Fundamentals
Networking Fundamentals How Computers Talk to Each Other Fundamentals of Communication Computers need to be told everything in intimate detail because they are dumb. We want to make computers talk to each
More informationComputer Networks CS3516 B Term, 2013
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 What You Will Do In This Project. The purpose
More informationConcurrent Programming. Copyright 2017 by Robert M. Dondero, Ph.D. Princeton University
Concurrent Programming Copyright 2017 by Robert M. Dondero, Ph.D. Princeton University 1 Objectives You will learn/review: What a process is How to fork and wait for processes What a thread is How to spawn
More informationCS 126 Lecture S5: Networking
CS 126 Lecture S5: Networking Outline Introductions Connectivity Naming and addressing Abstractions and layering Example: socket programming Conclusions CS126 24-1 Randy Wang Review: Technology Advances
More informationCS 126 Lecture S5: Networking
CS 126 Lecture S5: Networking Outline Introductions Connectivity Naming and addressing Abstractions and layering Example: socket programming Conclusions CS126 24-1 Randy Wang Review: Technology Advances
More informationJava for Interfaces and Networks (DT3029)
Java for Interfaces and Networks (DT3029) Lecture 3 Threads and Networking Federico Pecora federico.pecora@oru.se Center for Applied Autonomous Sensor Systems (AASS) Örebro University, Sweden Capiscum
More informationCSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2015
CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2015 Name: This exam consists of 5 problems on the following 7 pages. You may use your double- sided hand- written 8 ½ x 11 note sheet
More informationLearning from Bad Examples. CSCI 5828: Foundations of Software Engineering Lecture 25 11/18/2014
Learning from Bad Examples CSCI 5828: Foundations of Software Engineering Lecture 25 11/18/2014 1 Goals Demonstrate techniques to design for shared mutability Build on an example where multiple threads
More informationIntroduction to Sockets
Introduction to Sockets Sockets in Java 07/02/2012 EPL 602 1 Socket programming Goal: learn how to build client/server application that communicate using sockets Socket API o introduced in BSD4.1 UNIX,
More informationBrickNet (cont d) Other Academic Projects
BrickNet (cont d) Object-request brokers on the servers Aimed for collaborative design environments each node is responsible for its part of design and for sharing that information Also, networked games,
More informationJAVA SOCKET PROGRAMMING
JAVA SOCKET PROGRAMMING WHAT IS A SOCKET? Socket The combination of an IP address and a port number. (RFC 793 original TCP specification) The name of the Berkeley-derived application programming interfaces
More informationTCP and Concurrency. The third assignment at DA
TCP and Concurrency The third assignment at DA2402 2009-03-05 Jonas Lundberg/Ola Flygt adapted to Java by Marcus Edvinsson maintained by Marcus Edvinsson Matematiska och systemtekniska institutionen, MSI
More information3D Audio Enabled SecondLife Viewer Installation and Usage Guide
D Audio Enabled SecondLife Viewer Installation and Usage Guide This document describes how to install and use our D Audio enabled SecondLife Viewer. This software is provided to the CS 548 students for
More informationMerge Sort Quicksort 9 Abstract Windowing Toolkit & Swing Abstract Windowing Toolkit (AWT) vs. Swing AWT GUI Components Layout Managers Swing GUI
COURSE TITLE :Introduction to Programming 2 COURSE PREREQUISITE :Introduction to Programming 1 COURSE DURATION :16 weeks (3 hours/week) COURSE METHODOLOGY:Combination of lecture and laboratory exercises
More informationAssignment 2 Team Project: Distributed System and Application
Assignment 2 Team Project: Distributed System and Application Dr. Rajkumar Buyya and Dr. Maria Sossa Cloud Computing and Distributed Systems (CLOUDS) Laboratory School of Computing and Information Systems
More informationUDP and TCP. Introduction. So far we have studied some data link layer protocols such as PPP which are responsible for getting data
ELEX 4550 : Wide Area Networks 2015 Winter Session UDP and TCP is lecture describes the two most common transport-layer protocols used by IP networks: the User Datagram Protocol (UDP) and the Transmission
More informationObject-Oriented Systems Design RMI
Object-Oriented Systems Design RMI Michael Hauser November 2001 Workshop: AW3 Module: EE5029A Tutor: Mr. Müller Course: M.Sc Distributes Systems Engineering Lecturer: Mr. Prowse CONTENTS Contents 1 Aims
More informationJava Programming Course Overview. Duration: 35 hours. Price: $900
978.256.9077 admissions@brightstarinstitute.com Java Programming Duration: 35 hours Price: $900 Prerequisites: Basic programming skills in a structured language. Knowledge and experience with Object- Oriented
More information