Socket Programming. Request. Reply. Figure 1. Client-Server paradigm



Similar documents
ELEN 602: Computer Communications and Networking. Socket Programming Basics

Socket Programming. Srinidhi Varadarajan

Tutorial on Socket Programming

Introduction to Socket Programming Part I : TCP Clients, Servers; Host information

Socket Programming. Kameswari Chebrolu Dept. of Electrical Engineering, IIT Kanpur

Network Programming with Sockets. Process Management in UNIX

TCP/IP - Socket Programming

Unix Network Programming

Introduction to Socket programming using C

Implementing Network Software

Socket Programming in C/C++

Porting applications & DNS issues. socket interface extensions for IPv6. Eva M. Castro. ecastro@dit.upm.es. dit. Porting applications & DNS issues UPM

Application Architecture

VMCI Sockets Programming Guide VMware ESX/ESXi 4.x VMware Workstation 7.x VMware Server 2.0

NS3 Lab 1 TCP/IP Network Programming in C

ICT SEcurity BASICS. Course: Software Defined Radio. Angelo Liguori. SP4TE lab.

INTRODUCTION UNIX NETWORK PROGRAMMING Vol 1, Third Edition by Richard Stevens

Limi Kalita / (IJCSIT) International Journal of Computer Science and Information Technologies, Vol. 5 (3), 2014, Socket Programming

Client / Server Programming with TCP/IP Sockets

Lab 4: Socket Programming: netcat part

BSD Sockets Interface Programmer s Guide

Programmation Systèmes Cours 9 UNIX Domain Sockets

Operating Systems Design 16. Networking: Sockets

DESIGN AND IMPLEMENT AND ONLINE EXERCISE FOR TEACHING AND DEVELOPMENT OF A SERVER USING SOCKET PROGRAMMING IN C

The POSIX Socket API

IT304 Experiment 2 To understand the concept of IPC, Pipes, Signals, Multi-Threading and Multiprocessing in the context of networking.

Session NM059. TCP/IP Programming on VMS. Geoff Bryant Process Software

UNIX Sockets. COS 461 Precept 1

Communication Networks. Introduction & Socket Programming Yuval Rochman

Networks class CS144 Introduction to Computer Networking Goal: Teach the concepts underlying networks Prerequisites:

Networks. Inter-process Communication. Pipes. Inter-process Communication

Building Applications With Sockets

Computer Networks/DV2 Lab

CSE 333 SECTION 6. Networking and sockets

UNIX. Sockets. mgr inż. Marcin Borkowski

Computer Networks Network architecture

Network Programming TDC 561

IBM i Version 7.2. Programming Socket programming IBM

Packet Sniffing and Spoofing Lab

Review of Previous Lecture

Overview. Socket Programming. Using Ports to Identify Services. UNIX Socket API. Knowing What Port Number To Use. Socket: End Point of Communication

Goal: learn how to build client/server application that communicate using sockets. An interface between application and network

System calls. Problem: How to access resources other than CPU

Windows Socket Programming & IPv6 Translation Middleware

Objectives of Lecture. Network Architecture. Protocols. Contents

What is CSG150 about? Fundamentals of Computer Networking. Course Outline. Lecture 1 Outline. Guevara Noubir noubir@ccs.neu.

Network Programming with Sockets. Anatomy of an Internet Connection

Writing Client/Server Programs in C Using Sockets (A Tutorial) Part I. Session Greg Granger grgran@sas. sas.com. SAS/C & C++ Support

This tutorial has been designed for everyone interested in learning the data exchange features of Unix Sockets.

Network Programming using sockets

Socket = an interface connection between two (dissimilar) pipes. OS provides this API to connect applications to networks. home.comcast.

Programming guidelines on transition to IPv6

sys socketcall: Network systems calls on Linux

Implementing and testing tftp

TCP/IP Programming. Joel Snyder, Opus1 Geoff Bryant, Process Software

KATRAGADDA INNOVATIVE TRUST FOR EDUCATION NETWORK PROGRAMMING. Notes prepared by D. Teja Santosh, Assistant Professor, KPES, Shabad, R.R. District.

Basic Networking Concepts. 1. Introduction 2. Protocols 3. Protocol Layers 4. Network Interconnection/Internet

Chapter 3. Internet Applications and Network Programming

An Advanced 4.4BSD Interprocess Communication Tutorial

Programming with TCP/IP Best Practices

Network-Oriented Software Development. Course: CSc4360/CSc6360 Instructor: Dr. Beyah Sessions: M-W, 3:00 4:40pm Lecture 2

Chapter 11. User Datagram Protocol (UDP)

SMTP-32 Library. Simple Mail Transfer Protocol Dynamic Link Library for Microsoft Windows. Version 5.2

IP Network Layer. Datagram ID FLAG Fragment Offset. IP Datagrams. IP Addresses. IP Addresses. CSCE 515: Computer Network Programming TCP/IP

presentation DAD Distributed Applications Development Cristian Toma

Network Programming. Chapter The Client-Server Programming Model

Data Communication Networks. Lecture 1

transmission media and network topologies client/server architecture layers, protocols, and sockets

Generalised Socket Addresses for Unix Squeak

An Introductory 4.4BSD Interprocess Communication Tutorial

Abhijit A. Sawant, Dr. B. B. Meshram Department of Computer Technology, Veermata Jijabai Technological Institute

TCP Session Management (SesM) Protocol Specification

Application Development with TCP/IP. Brian S. Mitchell Drexel University

Socket programming. Socket Programming. Languages and Platforms. Sockets. Rohan Murty Hitesh Ballani. Last Modified: 2/8/2004 8:30:45 AM

Introduction to Computer Networks

The exam has 110 possible points, 10 of which are extra credit. There is a Word Bank on Page 8. Pages 7-8 can be removed from the exam.

Chapter 5. Transport layer protocols

Ethernet. Ethernet. Network Devices

Concurrent Server Design Alternatives

A Client Server Transaction. Introduction to Computer Systems /18 243, fall th Lecture, Nov. 3 rd

Application Note: AN00121 Using XMOS TCP/IP Library for UDP-based Networking

An Overview of IPv6 CHAPTER

Fundamentals of Symbian OS. Sockets. Copyright Symbian Software Ltd.

ICOM : Computer Networks Chapter 6: The Transport Layer. By Dr Yi Qian Department of Electronic and Computer Engineering Fall 2006 UPRM

Writing a C-based Client/Server

Named Pipes, Sockets and other IPC

IPv6 Enabling CIFS/SMB Applications

First Workshop on Open Source and Internet Technology for Scientific Environment: with case studies from Environmental Monitoring

Lecture 17. Process Management. Process Management. Process Management. Inter-Process Communication. Inter-Process Communication

Transport Layer. Chapter 3.4. Think about

Programming With Sockets 2

Socket Programming in the Data Communications Laboratory

Application Layer. CMPT Application Layer 1. Required Reading: Chapter 2 of the text book. Outline of Chapter 2

q Connection establishment (if connection-oriented) q Data transfer q Connection release (if conn-oriented) q Addressing the transport user

TCP/IP Sockets in C. Practical Guide for Programmers

M06 (31-May-2001) Requirements and guidelines for distributed laboratories application migration WP 3

Overview. Securing TCP/IP. Introduction to TCP/IP (cont d) Introduction to TCP/IP

MATLAB/Simulink TCP/IP Communication

Programming OpenSSL. The Server Perspective. by Sean Walton. Copyright 2001 Sean Walton

Computer Networks - Xarxes de Computadors

Transcription:

Socket Programming 1. Introduction In the classic client-server model, the client sends out requests to the server, and the server does some processing with the request(s) received, and returns a reply (or replies) to the client. The terms request and reply here may take on different meanings depending upon the context, and method of operation. An example of a simple and ubiquitous client-server application would be that of a Web-server. A client (Internet Explorer, or Netscape) sends out a request for a particular web page, and the web-server (which may be geographically distant, often in a different continent!) receives and processes this request, and sends out a reply, which in this case, is the web page that was requested. The web page is then displayed on the browser (client). Request Client Reply Server Figure 1. Client-Server paradigm Further, servers may be broadly classified into two types based on the way they serve requests from clients. Iterative servers can serve only one client at a time. If two or more clients send in their requests at the same time, one of them has to wait until the other client has received service. On the other hand, concurrent servers can serve multiple clients at the same time. Typically, this is done by spawning off a new server process on the receipt of a request the original process goes back to listening to new connections, and the newly spawned off process serves the request received. We can realize the client-server communication described above with a set of network protocols, like the TCP/IP protocol suite, for instance. The lower-level details, like the operation of the protocol itself must be clear to you by now. In this tutorial, we will look at the issue of developing applications for realizing such communication over a network. In order to write such applications, we need to understand sockets. 2. What are sockets? Sockets (also called Berkeley Sockets, owing to their origin) can simply be defined as end-points for communication. To provide a rather crude visualization, we could imagine the client and server hosts in Figure 1 being connected by a pipe through which data-flow takes place, and each end of the pipe can now be construed as an end-point. Thus, a socket provides us with an abstraction or a logical end point for communication. There are different types of sockets. Stream sockets, of type SOCK_STREAM are used for connection oriented, TCP connections, whereas datagram sockets of type SOCK_DGRAM are used for UDP based applications. Apart from these two, there are other socket types defined, like SOCK_RAW and SOCK_SEQPACKET. 1

2.1 Socket layer, and the Berkeley Socket API Figure 2 shows the TCP/IP protocol stack, and shows where the Socket layer may be placed. Again, please be advised that this is just a representation to indicate the level at which we operate when we write network programs using sockets. As shown in the figure, sockets make use of the lower level network protocols, and provide the application developer with an interface to the lower level network protocols. A library of system calls are provided by the socket layer, and are termed as the Socket API. These system calls can be used in writing socket programs. In the sections that ensue, we will study those system calls in detail. Application Layer Sockets Transport Layer Network Layer Data-Link Layer Physical Layer Figure 2. TCP/IP protocol stack 2.2 Programming environment, and the WinSock library We will study socket programming on the windows environment (Windows 9x/NT/2000/XP). Socket programming on UNIX based environments is similar, and most of the system calls used are the same. Windows adds its own windows-specific extensions. Windows provides the WinSock library which contains the system calls used for socket programming on the windows environment. Compilation issues on windows machines is relegated to Appendix-I. 3 Basic Socket system calls Figure 3 shows the sequence of system calls between a client and server for a connectionoriented protocol. 3.1 The socket() system call The socket() system call creates a socket and returns a handle to the socket created. The handle is of data type SOCKET. In UNIX based environments, the socket descriptor is a non-negative integer, but Windows uses the SOCKET data type for the same. 2

socket() bind() listen() accept() Blocking until conn. From the client Conn. establishment socket() connect() read() Data (request) write() write() Data (reply) read() Figure 3. Socket system calls for connection-oriented case Socket handles may take any value in the range 0 to INVALID_SOCKET-1. socket() system call syntax 3

SOCKET sd = socket (int af, int type, int protocol); Here, af is the Address family specification, type is the socket type and the protocol field is used to specify the protocol to be used with the address family specified. The address family can be one of AF_INET (for Internet protocols like TCP, UDP) or AF_UNIX (for Unix internal protocols), AF_NS, for Xerox network protocols or AF_IMPLINK for the IMP link layer. The type field is the socket type which may be SOCK_STREAM for stream sockets (TCP connections), or SOCK_DGRAM (for datagram connections). Other socket types are defined too. SOCK_RAW is used for raw sockets, and SOCK_SEQPACKET is used for a sequenced packet socket. The protocol argument is typically set to 0. You may also specify a protocol argument to use a specific protocol for your application. socket system call SOCKET sd = socket(...); if (sd == INVALID_SOCKET) /* error condition */ 3.2 The bind() system call The bind() system call is used to specify the association <Local-Address Local-Port>. It is used to bind either connection oriented or connectionless sockets. The bind() function basically associates a name to an unnamed socket. name, here refers to three components The address family, the host address, and the port number at which the application will provide its service. The syntax and arguments taken by the bind system call is given below: bind() syntax int result = bind (SOCKET sd, const struct sockaddr* name, int namelen); Here, sd is the SOCKET handle returned by the socket() system call before, and name points to the SOCKADDR structure, and namelen is the length of the parameter name in bytes. bind system call int res = bind (...); if (res == SOCKET_ERROR) /* error condition */ 4

Upon success, bind() returns 0. In case of error, bind() returns SOCKET_ERROR. So the return value of the bind system call must be checked against SOCKET_ERROR to check if the call succeeded. 3.3 The listen() system call After creation of the socket, and binding to a local port, the server has to wait on incoming connection requests. The listen() system call is used to specify the queue or backlog of waiting (or incomplete) connections. The syntax and arguments taken by the listen system call is given below: listen() syntax int result = listen (SOCKET sd, int backlog); Here, sd is the SOCKET handle returned by the socket() system call before, and backlog is the number of incoming connections that can be queued. listen system call int result = listen (...); if (result == SOCKET_ERROR) /* error condition */ Upon success, listen() returns 0. In case of error, listen() returns SOCKET_ERROR. 3.4 The accept() system call After executing the listen() system call, a server waits for incoming connections. An actual connection setup is completed by a call to accept(). accept() takes the first connection request on the queue, and creates another socket with the same properties as sd (the socket descriptor returned earlier by the socket() system call). In case of blocking sockets, this call would block the caller until a connection request arrives. accept() assumes a concurrent server, and automatically creates a new socket descriptor for the connection request received. In case of concurrent servers, a new server process is spawned (or fork ed in UNIX terminology), and the newly created server process serves this connection on this socket. The earlier socket goes back to listening on new connections. In a sense, the accept() system call completes the connection, and at the end of a successful accept(), all elements of the four tuple (or the five tuple if you consider protocol as one of the elements) of a connection are filled. The four-tuple that we talk about here is <Local Addr, Local Port, Remote Addr, Remote Port>. This combination of fields is used to uniquely identify a flow or a connection. The fifth tuple 5

element can be the protocol field. No two connections can have the same values for all the four (or five) fields of the tuple. accept() syntax SOCKET newsd = accept (SOCKET sd, struct sockaddr* addr, int* addrlen); Here, sd is the SOCKET handle returned by the socket() system call before, and addr is a pointer to a buffer that receives the address of the connecting entity, and addrlen is the length of the parameter addr. accept system call SOCKET newsd = accept (...); if (newsd == INVALID_SOCKET) /* error condition */ Upon success, accept() returns a handle to the new socket created. In case of error, accept() returns SOCKET_ERROR. 3.5 The connect() system call A client process also starts out by creating a socket by calling the socket() system call. It uses connect() to connect that socket descriptor to establish a connection with a server. In the case of a connection oriented protocol (like TCP/IP), the connect() system call results in the actual connection establishment of a connection between the two hosts. In case of TCP, following this call, the three-way handshake to establish a connection is completed. Note that the client does not have to bind to a local port in order to call connect(). Clients typically choose ephemeral port numbers for their end of the connection. Servers, on the other hand, have to provide service on well-known (premeditated) port numbers. connect() syntax int result = connect (SOCKET sd, const struct sockaddr* servaddr, int addrlen); Here, sd is the SOCKET handle returned by the socket() system call before, servaddr is a pointer to the server s address structure. addrlen holds the length of this parameter. connect system call int result = connect (...); if (result == SOCKET_ERROR) /* error condition */ Upon success, connect() returns 0. In case of error, connect() returns SOCKET_ERROR. 6

3.6 send(), recv(), sendto() and recvfrom() system calls After connection establishment, data is exchanged between the server and client using the system calls send(), recv(), sendto() and recvfrom(). The syntax of the system calls are as below: send(), recv(), sendto() and recvfrom() syntax int nbytes = send (SOCKET sd, const char* buf, int len, int flags); int nbytes = recv (SOCKET sd, const char* buf, int len, int flags); int nbytes = sendto (SOCKET sd, const char* buf, int len, int flags, struct sockaddr* to, int tolen); int nbytes = recvfrom (SOCKET sd, const char* buf, int len, int flags, struct sockaddr* from, int fromlen); Here, sd is the SOCKET handle returned by the socket() system call before, buf is the char buffer to be sent or received, flags is the indicator specifying the way the call is to be made. sendto() and recvfrom() are used in case of connectionless sockets, and they do the same function as send() and recv() except that they take more arguments (the to and from addresses as the socket is connectionless) Upon success, all these calls return the number of bytes written or read. Upon failure, all the above calls return SOCKET_ERROR 3.7 The closesocket() system call The closesocket() system call is used to close the connection. In some cases, any remaining data that is queued is sent out before the closesocket() is executed. closesocket() syntax int result = closesocket (SOCKET sd); Here, sd is the SOCKET handle returned by the socket() system call before. closesocket system call int result = closesocket (...); if (result == SOCKET_ERROR) /* error condition */ Upon success, closesocket() returns 0. In case of error, closesocket() returns SOCKET_ERROR. 7

3.8 The shutdown() system call The shutdown() system call is used to disable sends or receives on a socket. shutdown() syntax int result = shutdown (SOCKET sd, int how); Here, sd is the SOCKET handle returned by the socket() system call before. The parameter how determines how the shutdown is achieved. If the value of the parameter how is SD_RECEIVE, further receives on the socket will be disallowed. If how is SD_SEND, further sends are disallowed, and finally, if how is SD_BOTH, both sends and receives on the socket are disallowed. Remember that the shutdown() function does not close the socket. The socket is closed and all the associated resources are freed only after a closesocket() call. shutdown system call int result = shutdown (...); if (result == SOCKET_ERROR) /* error condition */ Upon success, shutdown() returns 0. SOCKET_ERROR. In case of error, shutdown() returns 4 Byte ordering, and byte ordering routines When data is transmitted on networks, the byte ordering of data becomes an issue. There are predominantly two kinds of byte orderings Little-Endian byte ordering, and Big- Endian byte ordering. Different processor architectures use different kinds of byte orderings. For example, the x86 family of processors uses Little-Endian byte ordering, and the Motorola 68K machines use Big-Endian byte ordering. Because of disparities like the above, when data is transmitted over a network, we need to change the byte ordering to the Network byte order, and change it back to Host byte order when data is read in. The following routines help in changing the byte order of the data. u_short result = ntohs (u_short netshort); u_short result = htons (u_short hostshort); u_long result = ntohl (u_long netlong); u_long result = htonl (u_long hostlong); The hton* routines convert host-byte-order to the network-byte-order and return the value in TCP/IP network byte order. The ntoh* routines do the opposite. 8

5 Important structs This section has definitions for the structs used in the socket system calls. struct sockaddr { unsigned short sa_family; /* address family, AF_xxx / char sa_data[14]; /* 14 bytes of protocol address */ }; The sockaddr structure holds the socket address information for all types of sockets. The sa_family field can point to many address families. Refer from section 3.1 that the Internet address family is denoted by AF_INET, and that encompasses most of the popular protocols we use (TCP/UDP), and so the Internet address specific parallel sockaddr structure is called sockaddr_in. The fields are self-explanatory. The sin_zero field serves as padding, and is typically set to all zeroes using memset(). struct sockaddr_in { short sin_family; u_short sin_port; struct in_addr sin_addr; char sin_zero[8]; }; 9

Appendix: Compilation instructions The code provided for both the EchoServer and EchoClient are written for the Windows platform, using the Winsock Library. You can use any compiler that provides the windows libraries, like the Microsoft VC++ compiler, or the CodeWarrior IDE. The usage of the IDE itself is clearly explained in the tutorials that come with CodeWarrior or MSVC++. In either case, you need to open a new project, and add the given source files to the project, and use the build option for getting the executables for both the Client and Server. 10