Académique Documents
Professionnel Documents
Culture Documents
Name
Register No. :
Year
Semester
: VI
Information Technology
Branch :
TABLE OF CONTENTS
: III
Expt Date
No.
Title of the
program
Pag
e.
No.
Date of
submiss
ion
Signatu
re
DateServer.java:
import java.net.*;
import java.io.*;
import java.util.*;
class dateserver
{
public static void main(String args[])
{
ServerSocket ss;
Socket s;
PrintStream ps;
DataInputStream dis;
String inet;
try
{
ss=new ServerSocket(8020);
while(true)
{
s=ss.accept();
ps=new PrintStream(s.getOutputStream());
Date d=new Date();
ps.println(d);
dis=new DataInputStream(s.getInputStream());
inet=dis.readLine();
System.out.println("THE CLIENT SYSTEM ADDRESS IS :"+inet);
ps.close();
}
}
catch(IOException e)
{
System.out.println("The exception is :"+e);
}
}
}
OUTPUT:
CLIENTSIDE:
C:\Program Files\Java\jdk1.5.0\bin>javac dateclient.java
SERVERSIDE:
C:\Program Files\Java\jdk1.5.0\bin>javac dateserver.java
Note: dateserver.java uses or overrides a deprecated API.
Note: Recompile with -deprecation for details.
C:\Program Files\Java\jdk1.5.0\bin>java dateserver
THE CLIENT SYSTEM ADDRESS IS :com17/192.168.21.17
TCPclient1.java
import java.net.*;
import java.io.*;
public class TCPclient1
{
public static void main(String arg[])
{
Socket c=null;
String line;
DataInputStream is,is1;
PrintStream os;
try
{
InetAddress ia = new InetAddress.getLocalHost();
c=new Socket(ia,9999);
}
catch(IOException e)
{
System.out.println(e);
}
try
{
os=new PrintStream(c.getOutputStream());
is=new DataInputStream(System.in);
is1=new DataInputStream(c.getInputStream());
do
{
System.out.println("Client:");
line=is.readLine();
os.println(line);
System.out.println("Server:" + is1.readLine());
}while(line.equalsIgnoreCase("quit")==false);
is1.close();
os.close();
}
catch(IOException e)
{
System.out.println("Socket Closed!Message Passing is
over");
}
}
OUTPUT
Client Side:
C:\Program Files\Java\jdk1.5.0_10\bin>javac client.java
Note: client.java uses or overrides a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
C:\Program Files\Java\jdk1.5.0_10\bin>java client
Client:
hai server
Server:hai client
Client:
how are you
Server:fine
Client:
quit
Server:quit
C:\Program Files\Java\jdk1.5.0_10\bin>
Server Side:
C:\Program Files\Java\jdk1.5.0_10\bin>javac server.java
Note: server.java uses or overrides a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
C:\Program Files\Java\jdk1.5.0_10\bin>java server
Client:hai server
Server:
hai client
Client:how are you
Server:
fine
Client:quit
Server:
quit
C:\Program Files\Java\jdk1.5.0_10\bin>
DataInputStream is;
PrintStream ps;
Socket c=null;
try
{
s=new ServerSocket(9000);
}
catch(IOException e)
{
System.out.println(e);
}
try
{
c=s.accept();
is=new DataInputStream(c.getInputStream());
ps=new PrintStream(c.getOutputStream());
while(true)
{
line=is.readLine();
ps.println(line);
}
}
catch(IOException e)
{
System.out.println(e);
}
}
}
EClient.java
import java.net.*;
import java.io.*;
public class EClient
{
public static void main(String arg[])
{
Socket c=null;
String line;
DataInputStream is,is1;
PrintStream os;
try
{
InetAddress ia = InetAddress.getLocalHost();
c=new Socket(ia,9000);
}
catch(IOException e)
{
System.out.println(e);
}
try
{
os=new PrintStream(c.getOutputStream());
is=new DataInputStream(System.in);
is1=new DataInputStream(c.getInputStream());
while(true)
{
System.out.println("Client:");
line=is.readLine();
os.println(line);
System.out.println("Server:" + is1.readLine());
}
}
catch(IOException e)
{
System.out.println("Socket Closed!");
}
}
}
Output
Server
C:\Program Files\Java\jdk1.5.0\bin>javac EServer.java
Note: EServer.java uses or overrides a deprecated API.
Note: Recompile with -deprecation for details.
C:\Program Files\Java\jdk1.5.0\bin>java EServer
C:\Program Files\Java\jdk1.5.0\bin>
Client
C:\Program Files\Java\jdk1.5.0\bin>javac EClient.java
Note: EClient.java uses or overrides a deprecated API.
fp=fopen("dnsip.txt","r");
while(!feof(fp))
{
fscanf(fp,"%s%s",&f[i].domain,&f[i].logad);
printf("\n%s\t%s",f[i].domain,&f[i].logad);
i++;
}
fclose(fp);
n=i;
printf("\n\n1.IP ADDRESS\n\n2.DOMAIN NAME\n\n3.EXIT\n");
do
{
printf("\n Enter your choice:");
scanf("%d",&ch);
switch(ch)
{
case 1:
printf("Enter the domain name:");
scanf("%s",&padd);
rarp(padd);
break;
case 2:
printf("\n Enter the logical address:");
scanf("%s",ladd);
arp(ladd);
break;
case 3:
exit(0);
break;
}
}
while(ch<4);
}
void rarp(char padd[30])
{
int i;
for(i=0;i<n;i++)
if(!strcmp(padd,f[i].domain))
{
printf("\n LOGICAL ADDRESS IS %s\n",f[i].logad);
break;
}
if(i==n)
printf("\n ERROR");
}
dnsip.txt:
www.ubuntu.com 192.168.1.1
www.gmail.com 192.168.2.2
www.ymail.com 192.168.3.3
www.yahoo.com 192.162.4.5
OUTPUT :
www.ubuntu.com
www.gmail.com
www.ymail.com
www.yahoo.com
192.168.1.1
192.168.2.2
192.168.3.3
192.162.4.5
1.IP ADDRESS
2.DOMAIN NAME
3.EXIT
Enter your choice:1
Enter the domain name:www.ubuntu.com
LOGICAL ADDRESS IS 192.168.1.1
Enter your choice:1
Enter the domain name:www.yahoo.com
ds.receive(p);
String psx=new String(p.getData(),0,p.getLength());
System.out.println("Client:" + psx);
System.out.println("Server:");
String str=dis.readLine();
if(str.equals("end"))
break;
buffer=str.getBytes();
ds.send(new
DatagramPacket(buffer,str.length(),ia,serverport));
}
}
}
UDPclient.java
import java .io.*;
import java.net.*;
class UDPclient
{
public static DatagramSocket ds;
public static int clientport=789,serverport=790;
public static void main(String args[])throws Exception
{
byte buffer[]=new byte[1024];
ds=new DatagramSocket(serverport);
BufferedReader dis=new BufferedReader(new
InputStreamReader(System.in));
System.out.println("server waiting");
InetAddress ia=InetAddress.getLocalHost();
while(true)
{
System.out.println("Client:");
String str=dis.readLine();
if(str.equals("end"))
break;
buffer=str.getBytes();
ds.send(new
DatagramPacket(buffer,str.length(),ia,clientport));
DatagramPacket p=new
DatagramPacket(buffer,buffer.length);
ds.receive(p);
String psx=new String(p.getData(),0,p.getLength());
System.out.println("Server:" + psx);
}
}
}
OUTPUT:
Server
C:\Program Files\Java\jdk1.5.0\bin>javac UDPserver.java
C:\Program Files\Java\jdk1.5.0\bin>java UDPserver
press ctrl+c to quit the program
Client:Hai Server
Server:
Hello Client
Client:How are You
Server:
I am Fine
Client
C:\Program Files\Java\jdk1.5.0\bin>javac UDPclient.java
C:\Program Files\Java\jdk1.5.0\bin>java UDPclient
server waiting
Client:
Hai Server
Server:Hello Clie
Client:
How are You
Server:I am Fine
Client:
end
Coding :
Client.c:
#include<stdio.h>
#include<sys/types.h>
#include<sys/ipc.h>
#include<sys/msg.h>
#include<stdlib.h>
#include<string.h>
struct mymsgbuf
{
long mtype;
char mtext[25];
};
FILE *fp;
int main( )
{
struct mymsgbuf buf;
int msqid,n,a[100],i=0,s,count=0,frmsz;
char d;
if((msqid=msgget(77,IPC_CREAT/06666))==-1)
{
printf("\n ERROR");
exit(0);
}
printf("\n ENTER FRAME SIZE:");
scanf("%d",&frmsz);
if((fp=fopen("check1.txt","r"))==NULL)
printf("\n FILE WAS NOT OPENED");
else
printf("\n FILE WAS OPENED");
while(!feof(fp))
{
d=getc(fp);
a[i]=d;
i++;
}
s=i;
for(i=0;i<=frmsz;i++)
{
if((msgrcv(msqid,&buf,sizeof(buf),0,1)==-1))
{
printf("\n ERROR");
exit(0);
}
printf("\n RECEIVED FRAMES ARE : %C",buf.mtext[i]);
}
for(i=0;i<=frmsz;i++)
{
if(a[i]==buf.mtext[i])
count ++;
if(count==0)
{
printf("/n FRAMES WERE NOT RECEIVED IN CORRECT SEQUENCE");
exit(0);
}
}
if(count==frmsz)
printf("\n FRAMES WERE RECEIVED IN CORRECT SEQUENCE");
else
printf("\n FRAMES WERE RECEIVED IN INCORRECT SEQUENCE");
}
Server.c:
#include<stdio.h>
#include<sys/types.h>
#include<sys/ipc.h>
#include<sys/msg.h>
#include<stdlib.h>
struct mymsgbuf
{
long mtype;
char mtext[25];
};
FILE *fp;
int main( )
{
struct mymsgbuf buf;
int msqid,si,ei,sz,i=0,s;
char a[100];
char d;
if((fp=fopen("send1.txt","r"))==NULL)
printf("\n FILE WAS NOT OPENED");
else
printf("\n ENTER STARTING ADDRESS & ENDING ADDRESS OF THE
FRAME ARRAY:");
scanf("%d%d",&si,&ei);
sz=ei-si;
if((msqid=msgget(77,IPC_CREAT/06666))==-1)
{
printf("\n ERROR");
exit(0);
}
while(!feof(fp))
{
d=getc(fp);
a[i]=d;
i++;
}
s=i;
buf.mtype=1;
for(i=si;i<=ei;i++)
buf.mtext[i]=a[i];
for(i=0;i<=sz;i++)
{
if(msgsnd(msqid,&buf,sizeof(buf),0)==-1)
{
printf("/n ERROR SENDING FRAMES");
exit(0);
}
}
printf("\n FRAMES ARE SENT");
return 0;
send1.txt:
10110110
OUTPUT :
send.txt
10101101
server.c
File was opened
ENTER STARTING ADDRESS & ENDING ADDRESS OF THE FRAME ARRAY : 0 5
Frames are sent
client.c
ENTER FRAME SIZE : 4
RECEIVED FRAMES ARE : 1
RECEIVED FRAMES ARE : 0
RECEIVED FRAMES ARE : 1
RECEIVED FRAMES ARE : 0
ADD SERVER
import java.net.*;
import java.rmi.*;
public class AddServer
{
public static void main(String args[])
{
try
{
AddServerImpl addServerImpl=new AddServerImpl();
Naming.rebind("AddServer",addServerImpl);
}
catch(Exception e)
{
System.out.println("Exception :"+e);
}
}
}
ADD SERVERIMPL:
import java.rmi.*;
import java.rmi.server.*;
public class AddServerImpl extends UnicastRemoteObject implements
AddServerIntf
{
public AddServerImpl()throws RemoteException
{
}
public double add(double d1,double d2)throws RemoteException
{
return d1+d2;
}
}
ADDSERVERINTF:
import java.rmi.*;
public interface AddServerIntf extends Remote
{
double add(double d1,double d2)throws RemoteException;
}
OUTPUT :
Coding :
Simulation of ARP/RARP
#include<stdio.h>
#include<string.h>
struct file
{
char logad[30];
char phyad[30];
}
f[15];
int n;
void rarp(char padd[30]);
void arp(char ladd[30]);
FILE *fp;
main()
{
int i=0,ch;
char padd[30],ladd[30];
fp=fopen("arprarp.txt","r");
while(!feof(fp))
{
fscanf(fp,"%s%s",&f[i].logad,&f[i].phyad);
i++;
}
fclose(fp);
n=i;
printf("\n 1.RARP 2.ARP 3.EXIT\n");
do
{
printf("\n \n ENTER YOUR CHOICE:");
scanf("%d",&ch);
switch(ch)
{
case 1:
printf("\n ENTER PHYSICAL ADDRESS:");
scanf("%s",&padd);
rarp(padd);
break;
case 2:
printf("\n ENTER LOGICAL ADDRESS:");
scanf("%s",&ladd);
arp(ladd);
case 3:
exit (0);
break;
}
}while(ch<4);
}
void rarp(char padd[30])
{
int i;
for(i=0;i<n;i++)
{
if(!strcmp(padd,f[i].phyad))
{
printf("\n LOGICAL ADDRESS IS %s",f[i].logad);
break;
}
}
if(i==n)
printf("\n ERROR");
}
void arp(char ladd[30])
{
int i;
for(i=0;i<n;i++)
{
if(!strcmp(ladd,f[i].logad))
{
printf(" \n PHYSICAL ADDRESS IS %s",f[i].phyad);
break;
}
}
if(i==n)
printf("\n ERROR");
}
arprarp.txt:
121.124.5.9 5F-6J-7J-2A
OUTPUT :
121.124.5.9 5F-6J-7J-2A
Coding :
#include <stdio.h>
#include<conio.h>
int main()
{
int n;
int i,j,k;
int a[10][10],b[10][10];
printf("\n Enter the number of nodes:");
scanf("%d",&n);
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("\n Enter the distance between the host %d %d:",i+1,j+1);
scanf("%d",&a[i][j]);
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%d\t",a[i][j]);
}
printf("\n");
}
for(k=0;k<n;k++)
{
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
if(a[i][j]>a[i][k]+a[k][j])
{
a[i][j]=a[i][k]+a[k][j];
}
}
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
b[i][j]=a[i][j];
if(i==j)
{
b[i][j]=0;
}
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%d\t",b[i][j]);
}
printf("\n");
}
getch();
}
OUTPUT :
Enter the number of nodes:4
Enter
Enter
Enter
Enter
Enter
Enter
Enter
Enter
Enter
the
the
the
the
the
the
the
the
the
distance
distance
distance
distance
distance
distance
distance
distance
distance
between
between
between
between
between
between
between
between
between
the
the
the
the
the
the
the
the
the
host
host
host
host
host
host
host
host
host
1
1
1
1
2
2
2
2
3
1:5
2:9
3:6
4:4
1:2
2:1
3:8
4:3
1:6
Enter
Enter
Enter
Enter
Enter
Enter
Enter
5
2
6
5
the
the
the
the
the
the
the
9
1
1
1
distance
distance
distance
distance
distance
distance
distance
6
8
4
8
between
between
between
between
between
between
between
the
the
the
the
the
the
the
host
host
host
host
host
host
host
3
3
3
4
4
4
4
2:1
3:4
4:2
1:5
2:1
3:8
4:2
4
3
2
2
5
0
1
1
6
8
0
8
4
3
2
0
shortest();
display();
getch();
}
void getdata()
{
clrscr();
printf("\n\nENTER THE NUMBER OF HOST IN THE GRAPH\n");
scanf("%d",&n);
printf("\n\nIF THERE IS NO DIRECT PATH \n");
printf(" \n\nASSIGN THE HIGHEST DISTANCE VALUE 1000 \n");
for(i=0;i<n;i++)
{
a[i][j]=0;
for(j=0;j<n;j++)
{
if(i!=j)
{
printf("\n\nENTER THE DISTANCE BETWENN (%d,
%d): ",i+1,j+1);
scanf("%d",&a[i][j]);
if(a[i][j]==0)
a[i][j]=1000;
}
}
}
}
void shortest()
{
int i,j,k;
for(k=0;k<n;k++)
for(i=0;i<n;i++)
for(j=0;j<n;j++)
{
if(a[i][k]+a[k][j]<a[i][j])
a[i][j]=a[i][k]+a[k][j];
}
}
void display()
{
int i,j;
for(i=0;i<n;i++)
for(j=0;j<n;j++)
if(i!=j)
{
printf("\n SHORTEST PATH IS : (%d,%d)--%d\n",i+1,j+1,a[i][j]);
}
getch();
}
OUTPUT :
PROGRAM TO FIND SHORTEST PATH BETWEEN TWO NODES
ENTER THE NUMBER OF HOST IN THE GRAPH : 3
IF THERE IS NO DIRECT PATH then ASSIGN THE HIGHEST DISTANCE VALUE
1000
ENTER THE DISTANCE BETWEEN(12):23
ENTER THE DISTANCE BETWEEN(13):54
if(setsockopt(sd,IPPROTO_IP,IP_HDRINCL,val,sizeof(one))>0)
{
perror("setsockopt()error");
}
else
printf("setsockopt() is OK\n");
printf("using :::::: SOURCE IP:%s port:%u,Target IP:%s port:
%u.\n",argv[1],atoi(argv[2]),argv[3],atoi(argv[4]));
unsigned int count;
for(count=0;count<20;count++)
{
if(sendto(sd,buffer,ip->iph_len,0,(struct sockaddr *)&sin,sizeof(sin))>0)
{
perror("sendto() error");
exit(-1);
}
else
printf("count #%u - sendto() is ok\n",count);
sleep(2);
}
close(sd);
return 0;
}
OUTPUT :
[saace@linux 9002]# gcc rawtcp.c -o rawtcp
[saace@linux 9002]# ./rawtcp
- Invalid parameters!!!
- Usage: ./rawtcp <source hostname/IP> <source port> <target
hostname/IP> <target port>
[exam03@localhost 03]# ./rawtcp 10.10.10.100 23 203.106.93.88 8008
socket()-SOCK_RAW and tcp protocol is OK.
setsockopt() is OK
Using:::::Source IP: 10.10.10.100 port: 23, Target IP: 203.106.93.88 port:
8008.
Count #0 - sendto() is OK
Count #1 - sendto() is OK
Count #2 - sendto() is OK
Count #3 - sendto() is OK
Count #4 - sendto() is OK
...
Expt No. : 9
Date
:
performance
Study of UDP
Introduction
Most network games use the User Datagram Protocol (UDP) as the underlying
transport protocol. The Transport Control Protocol (TCP), which is what most Internet
traffic relies on, is a reliable connection-oriented protocol that allows datastreams
coming from a machine connected to the Internet to be received without error by
any other machine on the Internet. UDP however, is an unreliable connectionless
protocol that does not guarantee accurate or unduplicated delivery of data.
The UDP segment shown above consists of an 8-byte header followed by the data
octets.
Fields :The source and destination ports identify the end points within the source
and destination machines.
The source port indicates the port of the sending process and unless otherwise
stated it is the port to which a reply should be sent to. A zero is inserted into it if it is
not used.
The UDP Length field shows the length of the datagram in octets. It includes the 8byte header and the data to be sent.
The UDP checksum field contains the UDP header, UDP data and the pseudo-header
shown above. The pseudo-header contains the 32-bit IP addresses of the source and
destination machines, the UDP protocol number and the byte count for the UDP
segment. The pseudo-header helps to find undelivered packets or packets that
arrive at the wrong address. However the pseudo-header violates the protocol
hierarchy because the IP addresses which are used in it belong to the IP layer and
not to the UDP layer.
UDP Latency
While TCP implements a form of flow control to stop the network from flooding there
is no such concept in UDP. This is because UDP does not rely on acknowledgements
to signal successful delivery of data. Packets are simply transmitted one after
another with complete disregard to event of the receiver being flooded.
segments are added to the network, the routers become overloaded with
unnecessary traffic, which must be analyzed and discarded.
When IP helper addressing is used in this type of topology, no more than one router
can be configured to forward UDP broadcasts (unless the receiving applications can
handle duplicate broadcasts). This is because duplicate packets arrive on the trader
network. This restriction limits redundancy in the design and can be undesirable in
some implementations.
To send UDP broadcasts bidirectionally in this type of topology, a second ip helper
address command must be applied to every router interface that receives UDP
broadcasts. As more segments and devices are added to the network, more ip
helper address commands are required to reach them, so the administration of
these routers becomes more complex over time. Note, too, that bidirectional traffic
in this topology significantly impacts router performance.
Router A Router B
164.53.8.0 164.53.9.0 164.53.10.0
E1
E0 E0
E1
TIC server network 164.53.7.0
200.200.200.0
Feed Network
200.200.200.61 200.200.200.62
164.53.7.61 164.53.7.62
164.53.8.61
164.53.9.61
164.53.10.61
servers cannot quickly learn an alternative route in the event of a primary router
failure.
With alternatives eliminated, the network designers turned to a simpler
implementation that supports redundancy without duplicating packets and that
ensures fast convergence and minimal loss of data when a router fails: UDP
flooding.
topology for the purpose of forwarding broadcasts. The key commands for enabling
UDP flooding are as follows:
bridge group protocol protocolip forward-protocol spanning tree
bridge-group group input-type-list access-list-number
UDP Broadcast Flooding
A broadcast is a data packet that is destined for multiple hosts. Broadcasts can
occur at the data link layer and the network layer. Data-link broadcasts are sent to
all hosts attached to a particular physical network. Network layer broadcasts are
sent to all hosts attached to a particular logical network. The Transmission Control
Protocol/Internet Protocol (TCP/IP) supports the following types of broadcast packets:
All onesBy setting the broadcast address to all ones (255.255.255.255), all hosts
on the network receive the broadcast.
NetworkBy setting the broadcast address to a specific network number in the
network portion of the IP address and setting all ones in the host portion of the
broadcast address, all hosts on the specified network receive the broadcast. For
example, when a broadcast packet is sent with the broadcast address of
131.108.255.255, all hosts on network number 131.108 receive the broadcast.
SubnetBy setting the broadcast address to a specific network number and a
specific subnet number, all hosts on the specified subnet receive the broadcast. For
example, when a broadcast packet is set with the broadcast address of
131.108.4.255, all hosts on subnet 4 of network 131.108 receive the broadcast.
Because broadcasts are recognized by all hosts, a significant goal of router
configuration is to control unnecessary proliferation of broadcast packets. Cisco
routers support two kinds of broadcasts:
directed and flooded. A directed broadcast is a packet sent to a specific network or
series of networks, whereas a flooded broadcast is a packet sent to every network.
In IP internetworks, most broadcasts take the form of User Datagram Protocol (UDP)
broadcasts. Although current IP implementations use a broadcast address of all
ones, the first IP implementations used a broadcast address of all zeros.
Expt No. : 10
Date
:
Introduction:
The Transmission Control Protocol (TCP) and the User Datagram
Protocol(UDP) are both IP transport layer protocols. UDP is a lightweight
protocol that allows applications to make diret use of the unreliable
datagram sevice provided by the underlying IP service. UDP is commonly
user dto support applications that use simple query/response transactions, or
applications that support real-time communications. TCP provided a reliable
data-transfer service, and is user for both bulk data transfer an interactive
data applications. TCP is the major transport protocol in use in most IP
networks, and supports the transfer of over 90 percent of all traffic across
the public Internet today. Given this major role for TCP, the performance of
this protocol forms a significant part of the total picture of service
performance for IP networks.
Overview of TCP:
TCP is the embodiment of reliable end-to-end transmission functionality in
the overall Internet architecture. All the functionality required to take a
simple base of IP datagram delivery and build upon this a control model that
implements reliability, sequencing,flow control, and data streaming is
embedded within TCP
TCP provides a communication channel between processes on each host
system. The channel is reliable,full-duplex, and streaming. To achieve this
functionality, the TCP drivers break up the session data stream into discreate
segments, and attach a TCP header to each segment. An IP header is
attached to this TCP packet, and the composite packet is then passed to the
network for delivery. This TCP header has numerous fields that are used to
support the intended TCP functionality. TCP has the following functional
characteristics:
Unicast protocol: TCP is based unicast network model, and supports data
exchange between precisely two parties. Id does not support broadcast or
multicast network models.
Connection state: Rather than impose a state within the network to
support the connection. TCP uses synchronized state between the two
endpoints. Much of the protocol design is intended to ensure that each local
state transition is communicated to, and acknowledged by, the remote party.
Reliable: Reliability implies that the stream of octets passed to the TCP
driver at one end of the connection will be transmitted across the network so
that the stream is presented to the remote access.
Full duplex: TCP is a full-duplexed protocol; it allows both parties to send
and receive data within the context of the single TCP connection.
Streaming : Although TCP uses a packet structure for network transmission.
Some protocols explicitly encapsulate each application transaction; for every
write , there must be a matching read. TCP does not preserve such an
implicit structure imposed on data stream, so that there is no pairing
between write and read operations within the network protocol.
Rate Adaptation : TCP is also a rate-adaptive protocol, in that the rate of
data transfer is intended to adapt to the prevailing load conditions within the
network and adapt to the processing capacity of the receiver. Conversely , if
there is congestion, a TCP sender will reduce its sending rate to allow the
network to recover.
TCP Protocol Header:
The TCP header structure is shown in fig., uses a pair of 16 bit source
destination port address. Then next field is a 32 bit sequence number, which
identifies the sequence number of the first data octet in this packet. The
sequence number does not start at an initial value of 1 for each new TCP
connection; the selection of an initial value is critical, because it is a delayed
data from old connection from being incorrectly interpreted as being valid
within a current connection.The acknowledgement sequence number is used
to inform the remote end of the data that has been successfully received.
The acknowledgement sequence number is actually one greater than that of
the last octet correctly received at the local end of th connection . The data
offset field indidcates the number of four-octet words within the TCP header.
Six single bit flags are used to indicate various conditions. URG is used to
indicate whether the urgent pointer is valid. The acknowledgement
sequence number is used to inform the remote end of the data that has been
successfully received. The acknowledgement sequence number is actually
one greater than that of the last octet correctly received at the local end of
th connection . The data offset field indidcates the number of four-octet
words within the TCP header. Six single bit flags are used to indicate various
conditions. URG is used to indicate whether the urgent pointer is valid. ACK
is used to indicate whether the acknowledgement field is valid. The window
field is a 16 bit count of available buffer space. It is added to the
acknowledgement sequence number to indicate the higher sequence
number the receiver can accept. The TCP checksum is applied to a
synthesized header that includes the source and destination addresses from
the outer IP datagram.
version
Length
IHL
Identification
Flags
Fragment
offset
Time to live
Checksum
Protocol=7
Source Address
Destination Address
Options
Padding
Sequence Number
Acknowledgement Number
Data Offset
Window
U A P R S
F
R C S S Y
I
Header
G K H T N N
Check sum
Pointer
Urgent
Top Options
Padding
Top Data
Fig. TCP/IP Datagram
The final field in the TCP header is the urgent pointer, which when added to
the sequence number, indicates the sequence number of the final octet of
urgent data if the urgent flag is set.
TCP Operation :
The first phase of a TCP session is establishment of the connection. This
requires a three way handshake , ensuring that both sids of the connection
have an unambiguous understanding of th sequence number space of the
remote side for this session. The operation of the connection is as follows:
The local system sends the remote end an initial sequence number to
the remote port, using a SYN packet.
The remote system responds with an ACK of the initial sequence
number and the initial sequence number o fthe remote end in a
response sYN packet.
The local end responds with an ACK of this remote sequence number.
The connection is opened.
After the connection has been established , the TCP protocol manages
the reliable exchange of data between the two systems.
The algorithms that determine the various retransmission timers have been
redefined numerous tiemes. TCP is sliding-window protocol, and the general
principle of flow control is based on the management of the advertised