OIS没有给出实际解决方案,只是理论上的一种模型;后来TCP/IP协议被广泛使用;
TCP/IP要解决的五大问题----->>
1,数据量大,网络底层设备以一次无法吞吐巨大的数据量------数据的拆分,通过复用路径来提高效率
2,增加协议头来包装数据
3,相邻设备之间的连接–即局域网
4,路由寻址,找到最适合传输的路线
5,数据重组以及还原
TCP协议
连接时的三次握手
断开时的四次挥手
按照TCP协议在拿到应用层数据后,在传输数据前 要做三件事情-----
1,报文拆分
2,增加tcp头
3,数据重组
发送数据的时候会顺序发送,但是到达接收方时时无序的;
但是如果TCP段特别多的时候,怎么进行排序?
采用时间窗口的形式,在某一个时间段进行排序,如果不在这个时间段,那么就要求客户端重新发送;
TCP头:标志位 NS,ECN,CWR这是属于Tcp协议扩展,URG是一个紧急标志位,当设置紧急标志位为1时,会优先处理该条数据;
ACK响应标志位,
PSH 传送数据,
RST重置标志位
FIN断开标志位
SYN同步标志位
IP协议
32位,大约40亿个地址
源IP,即要发送数据的IP地址,目的Ip即接收方Ip
TypeService 服务类型,主要 用于选择 低延迟/低丢包率/
高吞吐率
IHL 协议头长度
Total Length 报文长度—即封包的长度
Identfication 报文ID,由发送方分配,由于发送时位有序的但是接收时时乱序的;
Fragment offset 描述是否要分包,及如何拆分
Time to Live 封包存活时间
Protocol 描述上层的协议
CheckSum 检验封包的正确性;
借助工具分析一下TCP/IP协议中都包含的内容----->>>>>
package testAera;
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
/**
* 模拟http传输协议
*/
public class MyHttp {
public static void main(String[] args) throws IOException {
//准备一个服务端
ServerSocket socket = new ServerSocket(8888);
//然后准备一个环境,一直接受请求
while (true) {
//blocking
Socket accept = socket.accept();
System.out.println("一个socket被创建了");
//接收输入过来的流
InputStream inputStream = accept.getInputStream();
//通过缓存流来读
BufferedReader br= new BufferedReader(new InputStreamReader(inputStream));
//读取的信息通过StringBuilder拼接
StringBuilder request= new StringBuilder();
String line="";
while(!(line=br.readLine()).isBlank()){
request.append(line+'\n');
}
//输出拼接的信息
System.out.println(request.toString());
//请求之后返回一些信息给客户端吧 要使得客户端与服务端连接起来 传入输出流
BufferedWriter bw= new BufferedWriter(new OutputStreamWriter(accept.getOutputStream()));
bw.write("http/1.1 ok\n\n欢迎来到http的世界");
bw.flush();//刷新一下以使得信息能显示出来
}
}
}
注意,如果是在linux环境下,可以在控制台直接输入curl+IP地址,但是入果是在windows环境下需要配置一下curl才能使用;
curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、Win64下的移植版本。
官网下载----curl
跟配置java_home一样配置好curl然后就可以使用了;