关于TCP/IP协议栈(转)
1. TCP/IP协议栈
与OSI参考模型不同,TCP/IP协议栈共有4层,其中网络接口层对应OSI中的物理层和数据链路层,应用层对应OSI中的应用层、表示层和会话层。
在网络接口层的主要协议有:ARP、RARP等。ARP协议主要功能是根据IP地址获取物理地址,RARP协议则反之。
网络层的主要协议有:IP、路由协议(RIP、OSPF、BGP等)。IP协议为网络上的每台主机编号,在此基础上才有路由协议,因此路由协议是基于IP协议的。
传输层的主要协议有:TCP、UDP。传输层有端口号的概念,端口号是指TCP或UDP协议能根据端口号找到接受数据包的进程。(也就是说一个TCPServer和一个UDPServer可以绑定同一个端口,详细解释参看第2节)
应用层协议主要有:HTTP、FTP、SMTP等。

2. “协议号+端口号”唯一确定了接收数据包的进程
协议号:协议号是存在于IP数据报的首部的20字节的固定部分,占有8bit。该字段是指出此数据报所携带的是数据是使用何种协议,以便目的主机的IP层知道将数据部分上交给哪个传输层协议(TCP/UDP等)。
端口号:端口号存在于TCP/UDP报文的首部。
目的主机收到数据报后,IP协议会将解析到协议号,并据此将数据上送给相应的传输层协议;传输层协议收到数据并解析,获得端口号,并据此将数据上送给相应的接受数据报的进程。
从上述过程可知,端口号是按照传输层协议号划分了“命名空间”的,因此,同一主机可以同时运行绑定同一端口号的TCP Socket(java中对应ServerSocket、Socket)和UDP Socket(java中对应DatagramSocket)而不发生冲突。
3. 附件
测试使用的代码:
TCPClient.java

1 package socket;
2
3 import java.io.*;
4 import java.net.*;
5 import java.util.Date;
6
7 public class TCPClient {
8
9 /**
10 * @param args
11 */
12 public static void main(String[] args) {
13 // TODO Auto-generated method stub
14 try {
15 System.out.println(new Date());
16 InetAddress remoteAddress = InetAddress.getByName("22.11.143.60");
17 // InetAddress localAddress = InetAddress.getByName("127.0.0.1");
18 // Socket socket = new Socket(remoteAddress, 1287, localAddress, 1288);
19 // Socket socket = new Socket(remoteAddress, 1287);
20 Socket socket = new Socket ();
21 socket.connect(new InetSocketAddress(remoteAddress,1287), 1000);
22 socket.setSoTimeout(110000);
23 System.out.println(new Date());
24 PrintWriter os = new PrintWriter(socket.getOutputStream());
25 BufferedReader is = new BufferedReader(new InputStreamReader(socket.getInputStream()));
26 String msg = "hello";
27 os.println(msg);
28 os.flush();
29 System.out.println("Client: " + msg);
30 // Thread.sleep(1000);
31 System.out.println("Server: " + is.readLine());
32 System.out.println(new Date());
33 Thread.sleep(1000000);
34 System.out.println("end!");
35 os.close();
36 is.close();
37 socket.close();
38 } catch (UnknownHostException e) {
39 // TODO Auto-generated catch block
40 System.out.println(new Date());
41 e.printStackTrace();
42 } catch (IOException e) {
43 // TODO Auto-generated catch block
44 System.out.println(new Date());
45 e.printStackTrace();
46 }
47 catch (InterruptedException e) {
48 // TODO Auto-generated catch block
49 System.out.println(new Date());
50 e.printStackTrace();
51 }
52
53 }
54
55 }

TCPServer.java

1 package socket;
2
3 import java.io.*;
4 import java.net.*;
5
6 public class TCPServer {
7
8 /**
9 * @param args
10 */
11 public static void main(String[] args) {
12 // TODO Auto-generated method stub
13 try {
14 ServerSocket serverSocket = new ServerSocket(1287,2);
15 Socket socket = serverSocket.accept();
16
17 PrintWriter os = new PrintWriter(socket.getOutputStream());
18 BufferedReader is = new BufferedReader(new InputStreamReader(socket.getInputStream()));
19 while (true){
20 System.out.println("Client: " + is.readLine());
21 String msg = "hi";
22 os.println(msg);
23 os.flush();
24 System.out.println("Server: " + msg);
25 }
26 // os.close();
27 // is.close();
28 // socket.close();
29 // serverSocket.close();
30 } catch (IOException e) {
31 // TODO Auto-generated catch block
32 e.printStackTrace();
33 }
34 // catch (InterruptedException e) {
35 // // TODO Auto-generated catch block
36 // e.printStackTrace();
37 // }
38
39 }
40
41 }

UDPClient.java

1 package socket;
2
3 import java.io.IOException;
4 import java.net.DatagramPacket;
5 import java.net.DatagramSocket;
6 import java.net.InetAddress;
7 import java.net.SocketException;
8 import java.net.UnknownHostException;
9
10 public class UDPClient {
11
12 public static void main(String[] args) {
13 try {
14 DatagramSocket ds = new DatagramSocket();
15 String str = "hello";
16 DatagramPacket dp = new DatagramPacket(str.getBytes(),str.length(),InetAddress.getByName("22.11.143.60"),1287);
17 ds.send(dp);
18
19 ds.close();
20
21 } catch (SocketException e) {
22 e.printStackTrace();
23 } catch (UnknownHostException e) {
24 e.printStackTrace();
25 } catch (IOException e) {
26 e.printStackTrace();
27 }
28
29 }
30
31 }

UDPServer.java

1 package socket;
2
3 import java.io.IOException;
4 import java.net.DatagramPacket;
5 import java.net.DatagramSocket;
6 import java.net.SocketException;
7
8 public class UDPServer {
9
10 public static void main(String[] args) {
11
12 try {
13 DatagramSocket ds = new DatagramSocket(1287);
14 byte[] buf=new byte[100];
15 DatagramPacket dp=new DatagramPacket(buf,100);
16 ds.receive(dp);// block here
17 System.out.println(new String(dp.getData()));
18
19 ds.close();
20
21 } catch (SocketException e) {
22 e.printStackTrace();
23 } catch (IOException e) {
24 e.printStackTrace();
25 }
26
27
28 }
29
30 }

http://www.cnblogs.com/kqdongnanf/p/4773539.html
关于TCP/IP协议栈(转)的更多相关文章
- 【转】TCP/IP协议栈及OSI参考模型详解
OSI参考模型 OSI RM:开放系统互连参考模型(open systeminterconnection reference model) OSI参考模型具有以下优点: 简化了相关的网络操作: 提供设 ...
- C1000k 新思路:用户态 TCP/IP 协议栈
现在的服务器支撑上百万个并发 TCP 连接已经不是新闻(余锋2010年的演讲,ideawu 的 iComet 开源项目,WhatsApp 做到了 2.5M).实现 C1000k 的常规做法是调整内核参 ...
- 渣渣小本求职复习之路每天一博客系列——TCP/IP协议栈(5)
前情回顾:一篇短短的博客明显不能满足TCP和UDP这两个饥渴的汉子,而且还被应用协议占了一小半的篇幅.在昨天结束之后,相信大家都基本对TCP/IP协议栈的轮廓有一个大概的印象了,能够对整体有所把握. ...
- TCP/IP协议栈概述
TCP/IP协议栈概述 这篇文章虽然只是很粗浅的介绍了ISO/OSI 网络模型,但确实把握住了关键点,某种意义上,简单回顾一下就可以加深对TCP/IP协议栈的理解. 原作者:阮一峰 链接: http: ...
- [转]为何TCP/IP协议栈设计成沙漏型的
http://m.blog.csdn.net/blog/dog250/18959371 前几天有人回复我的一篇文章问,为何TCP/IP协议栈设计成沙漏型的.这个问题问得好!我先不谈为何它如此设计,我一 ...
- windows下重新安装TCP/IP协议栈
一.windows重装TCP/IP协议 前两天在windows下安装开发环境的时候,把系统的TCP/IP协议栈给搞跪了,导致系统无法ping localhost.无法在程序中创建socket等 ...
- UNIX/Linux网络编程基础:图解TCP/IP协议栈
目录 1.主机到网络层协议:以太网协议 2.IP协议 3.网际控制报文协议(ICMP) 4.传输控制协议(TCP) 5.用户数据报文协议(UDP) 6.流控制传输协议(SCTP) 7.地址解析协议(A ...
- TCP/IP协议栈与数据包封装+TCP与UDP区别
ISO制定的OSI参考模型的过于庞大.复杂招致了许多批评.与此对照,由技术人员自己开发的TCP/IP协议栈获得了更为广泛的应用.如图2-1所示,是TCP/IP参考模型和OSI参考模型的对比示意图. T ...
- TCP/IP协议栈及OSI参考模型详解
OSI参考模型 OSI RM:开放系统互连参考模型(open systeminterconnection reference model) OSI参考模型具有以下优点: 简化了相关的网络操作: 提供设 ...
- TCP/IP协议栈源码图解分析系列10:linux内核协议栈中对于socket相关API的实现
题记:本系列文章的目的是抛开书本从Linux内核源代码的角度详细分析TCP/IP协议栈内核相关技术 轻松搞定TCP/IP协议栈,原创文章欢迎交流, byhankswang@gmail.com linu ...
随机推荐
- ubuntu 系统设置bugzilla制
随着时间的推移.在大脑中形成的记忆总会慢慢的淡去.人的记忆力就是这样.所以最好的办法就是形成博客去记录下来,一方面给自己以后回想用.一方面也算是自己的一个积累.所以一旦选择了一个行业,最好不要轻 易转 ...
- Android源码及SDK国内镜像下载
Android源码及SDK国内镜像下载Android源码下载: 今天发现,清华大学提供AOSP镜像,以前都是从Google的站点下载同步更新的,但是现在有了国内的镜像站点就好多了,下载Androidd ...
- basename, dirname 在C语言中的使用
basename作用是得到特定的路径中的最后一个'/',后面的内容 如/usr/bin,得到的内容就是bin 如果/sdcard/miui_recovery/backup 得到的内容就是backup ...
- CentOS7卸载KDE桌面(转)
最初安装centos时选择了安装KDE桌面,打开很卡,没有用到,想卸载,可是试了网上的方法什么yum groupremove kde-desktop 都不奏效,于是只能自己找出KDE的包,然后yum卸 ...
- 解决adb server is out of date. killing...问题
在运行 adb 命令时出现了例如以下提示: adb server is out of date. killing... 导致 adb 无法正常启动,更无法运行其它命令. 有问题怎么办?百度呗.查了查 ...
- windows下搭建Apache+Mysql+PHP开发环境
原文:windows下搭建Apache+Mysql+PHP开发环境 要求 必备知识 熟悉基本编程环境搭建. 运行环境 windows 7(64位); Apache2.2;MySQL Server 5. ...
- java Double保留小数点位数
0和#都是占位符,但在不同的地方,作用不一样0: 比实际数字的位数多,不足的地方用0补上. new DecimalFormat("00.00").format(3.14) //结果 ...
- POJ 3177 Redundant Paths POJ 3352 Road Construction(双连接)
POJ 3177 Redundant Paths POJ 3352 Road Construction 题目链接 题意:两题一样的.一份代码能交.给定一个连通无向图,问加几条边能使得图变成一个双连通图 ...
- redmine 出口中国的乱码
pdf 这是redmine的bug.必须在个人账户更改将设立中国语文,足够的人才来解决. 顺便说一下,提示.以下更改文件的方法是无效的 /home/redmine/redmine-2.5.1/lib/ ...
- NFS 配置服务
NFS 配置服务 北京市海淀区 张俊浩 一.NFS.即网络文件系统(Network File System,NFS).一种使用于分散式文件系统的协议,由升阳公司开发.于1984年向外发布.功能是通过 ...