Client/Server Communication
Technique
1 January 6, 2025
Socket
Socket: This is a software construct that supports network
input/output.
A Socket acts as an endpoint for communication and is
Bi-directional.
An application creates a socket when it needs a
connection to a network.
It then establishes a connection to a remote application via
the socket.
Communication is achieved by reading data from the
socket and writing data to it.
2 January 6, 2025
.
• A socket is defined in the Operating System as a structure.
• Simplified socket structure with five fields:
- Family: defines the protocol group (IPv4, IPv6, UNIX or
Internet domain protocols)
- Type: defines the exchange-type (stream, packet, raw)
- Protocol: set to zero for TCP/ UDP
- Local address: combination of local IP and application
port address.
- Remote address: combination of remote IP and
application port address.
3 January 6, 2025
Socket Types
Stream socket: to be used with connection oriented
protocol (TCP)
Datagram socket: to be used with connectionless
protocol (UDP)
Raw socket: some protocols (ICMP) directly use the
service of IP. Raw sockets are used in these applications.
4th type of scket
4 January 6, 2025
Clients/Servers
• A client application program runs on a local machine
requesting for a service from another program called
Server application that is running on a remote machine.
• A server provides a service to any client, not a particular
client
• A client application program that is requesting for a
service only runs when needed.
• A server program providing service should run all the
time since its services might be needed at any time.
5 January 6, 2025
.
A client opens the communication channel by
invoking the IP address of the remote host and the
port address of the specific server program running
on the host.
Request for server service and response from server
may be repeated several times, until the client closes
the communication channel. The process is finite.
6 January 6, 2025
.
• A server program opens its door for incoming requests
from clients but never initiates a service unless explicitly
requested.
• Server program is infinite, runs continuously unless a
problem occurs.
• Two or more clients can run at the same time on a
machine(Concurrency in clients)
• Clients can also be iterative, where one client starts, runs,
and terminates before another client may start.
7 January 6, 2025
.
Concurrency in servers: An iterative server can process
only one request at a time whereas a concurrent server can
process many requests from different clients at the same
time(time sharing).
Connectionless iterative servers: servers that use UDP
are iterative, in this case the server uses one single port,
and arriving packets have to wait in line.
Connection oriented concurrent servers : Servers
using TCP can process request concurrently.
8 January 6, 2025
Client/Server communication
• Once a connection is established between server and each
client, it remains open until the entire stream is processed.
• Each connection requires a port and many connections
may remain open simultaneously.
• Server can use only one well-known port.
• Client makes request through the well-known port, once
the connection is made, server assigns a temporary port to
this connection to free the “well-known port” for
listening to additional connections.
9 January 6, 2025
process
A program is coded in a computer language to define all
the variables and the actions to be performed on those
variables.
note;
A process is an instance of a program(or an executing
program).
An OS creates a process when executing a program,
several processes can be created from one program
running concurrently.
10 January 6, 2025
TCP Server Socket Creation
o The operating system through a system call is invoked
to create a socket Create a socket (ask the OS)
o Bind (associates the network address of a machine
with a socket identifier)
o Listen (ask the OS to be passive and listen to
connecting clients)
o Accept (Ask the OS to assign a slave socket to the
accepted client)
o Following steps are repeated every time a new client is
accepted:
a) Create a child process (temporary child process is assigned
to serve the client, parent is free every time a client is
accepted)
11
b)Create a new socket (to be used by the child process) January 6, 2025
.
c) Repeat (the following steps as long as the child has requests
from the client)
- Read(child reads a stream of bytes from the connection)
- Process (the child processes the stream of bytes)
- write (the child writes the result as a stream of bytes to the
connection)
d) Destroy (asks the OS to destroy the temporary socket once
the client has been served)
12 January 6, 2025
.
TCP Client Socket Creation Process
- Create a socket
- Connect (asks the OS to make a connection)
- Repeats the following as long as it has requests to make:
a) Write (sends a stream of bytes to the server)
b) Read (receives a stream of bytes from the server)
- Destroy (asks the OS to destroy the socket once it has
finished)
13 January 6, 2025
.
Data structures:
sockaddr_in
sin_family: 16-bit integer specifying protocol
sin_port: 16-bit field specifying port number (application)
s_addr: 32-bit Internet address
hostent
h_name: character string of text address of host
14 January 6, 2025
.
Socket Commands:
‘socket’ – creates a socket
‘gethostbyname’ – returns a host address corresponding to a
name
‘gethostname’ – returns the host name
‘connect’ – requests a connection with a remote socket
‘bind’ – assigns an address and port number to a socket
15 January 6, 2025
.
Socket Commands:
‘listen’ – server is ready for connection requests and listens
for them
‘accept’ – accepts a connection request over a socket
‘recv’ or read – receives data from a socket
‘send’ or write– sends data through a socket
‘close’ – closes a socket
16 January 6, 2025