壹:tcp协议:可靠传输

一: 3次握手,建立链接;4次挥手,断开链接

3次握手,建立链接:图解 ,这样双向通路就建立完成了。

在建立链接时,并没有数据传输,所以中间两部可以合在一起,也就是3次握手,建立了链接(图1)

此时,有一个问题,客户端给服务端发完包以后,服务端又回一个包,那么客户端如何知道,

服务端回的这个包是基于上一次的请求信息而来的。所以需要一个记号,也就是seq=x,从而解决

上述的问题(图2)。

4次挥手,断开链接:图解 , 建成链接之后,就该基于双向通路进行数据的传递了。

而且说明一点:tcp协议传输数据更加可靠,这是因为tcp协议 “有求必应”,也就是客户端给服务端发一个包,

服务端一定要回一个包,要有一个回应。所以数据更不容易丢失,才更加可靠。

断开链接,由于要考虑到数据的发送是否已经完成,所以需要4步,才断开链接,例(图3),客户端数据发送完成,

请求断开链接(fin=1),但是此时服务端数据可能并没有完成,所以不能合成3步。

                       

二: tcp协议的相关状态:状态可以在cmd中去查看,命令:netstat  -an  |findstr  ?(例:TCP)

(LISTENING,ESTABLISHED,……)

客户端上可以查看到什么样的状态信息:客户端一旦发送完一个请求信息syn=1以后,客户端立马会进入一个状态,

叫syn_send的状态。服务端在收到这个请求信息之前,服务端会首先处于一个状态,叫listen状态,一旦服务端

收到一个syn=1请求信息后,服务端就会从listen状态立马进入一个叫syn_rcvd的状态(received),代表收到请

求信息了。服务端收到请求信息后,服务端开始给客户端回数据,客户端一旦收到这个确认信息后,客户端会立

马进入到一个叫ESTABLISHED的状态(链接已经建立成功),那这个数据包回到服务端,服务端一旦收到ack=1

的确认信息后,服务端也会进入到一个叫ESTABLISHED的状态。

所以(图4) tcp三次握手在客户端会看到哪些状态,syn_send和ESTABLISHED,

在服务端会看到哪些状态,listen,syn_rcvd和ESTABLISHED

如果想要用上面的命令netstat..去捕捉这些状态的话,

在客户端中,通常只能捕捉到ESTABLISHED状态,因为tcp三次握手速度非常快,客户端在发送完请求信息后,

瞬间就进入到了ESTABLISHED状态,所以几乎不可能捕捉到syn_send状态。

在服务端中,通常只能捕捉到listen和ESTABLISHED状态,也是因为速度太快....

(图5)tcp断开链接的几种状态:

三:syn洪水攻击:就是黑客模拟大量的假的客户端来向服务端发送正常的syn请求,发送给服务端以后,服务端就要响应回去,

然后等待着客户端的回应,然而这是黑客模拟的假的客户端,并不会回应了,所以服务端的资源一直被占用着,这时

syn_rcvd的状态就会大量涌现。

四:半连接池(backlog):服务端有一个半连接池,专门用来存请求信息,就是一个队列,先进先出,客户端来一个请求,

就把请求放到半连接池中,注意,放的是请求数,不是链接数。当然如果遭受syn洪水攻击,就应该调高半

连接池的大小,但这并不能从根本上解决问题,因为半连接池占用的是内存空间,所以最大也不会大过内存

空间,所以如果流量足够大的情况下,半连接池的作用就没有用了。

贰:socket(套接字)介绍:socket是应用层与传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供

应用层调用已实现进程在网络中通信。

基于tcp协议通信的套接字(简单版本)   例:

tcp协议以及socket介绍的更多相关文章

  1. 网络编程——基于TCP协议的Socket编程,基于UDP协议的Socket编程

    Socket编程 目前较为流行的网络编程模型是客户机/服务器通信模式 客户进程向服务器进程发出要求某种服务的请求,服务器进程响应该请求.如图所示,通常,一个服务器进程会同时为多个客户端进程服务,图中服 ...

  2. 基于TCP 协议的socket 简单通信

    DNS 服务器:域名解析 socket 套接字 : ​ socket 是处于应用层与传输层之间的抽象层,也是一组操作起来非常简单的接口(接受数据),此接口接受数据之后,交由操作系统 为什么存在 soc ...

  3. 自学Python-基于tcp协议的socket

    自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...

  4. Python基础系列讲解——TCP协议的socket编程

    前言 我们知道TCP协议(Transmission Control Protocol, 传输控制协议)是一种面向连接的传输层通信协议,它能提供高可靠性通信,像HTTP/HTTPS等网络服务都采用TCP ...

  5. 闲来无事,写个基于TCP协议的Socket通讯Demo

    .Net Socket通讯可以使用Socket类,也可以使用 TcpClient. TcpListener 和 UdpClient类.我这里使用的是Socket类,Tcp协议. 程序很简单,一个命令行 ...

  6. TCP协议下Socket的基础编程类型

    套接字的基本操作有: 创建(socket).命名(bind).侦听(listen).连接(accept).关闭(shutdown).发送(send).接受(recv). 下面逐个分析: 一.创建(so ...

  7. 基于TCP协议的socket编程

    什么是socket Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面, ...

  8. 基于网络编程 TCP协议 及 socket 基本语法

    socket是什么 Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面, ...

  9. 网络编程: 基于TCP协议的socket, 实现一对一, 一对多通信

    TCP协议  面向连接 可靠的 面向字节流形式的 tcp是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端 TCP协议编码流程: 服务器端:                 客户端 实例化对 ...

随机推荐

  1. 五、Java基础加强

    Java基础加强 1.MyEclipse的使用工作空间(workspace).工程(project)在eclipse下Java程序的编写和运行,及java运行环境的配置.快捷键的配置,常用快捷键:内容 ...

  2. phpredis Redis集群 Redis Cluster

    官方url: https://github.com/phpredis/phpredis/blob/develop/cluster.markdown#readme 2017年10月29日20:44:25 ...

  3. POJ 2689 - Prime Distance - [埃筛]

    题目链接:http://poj.org/problem?id=2689 Time Limit: 1000MS Memory Limit: 65536K Description The branch o ...

  4. git迁移

    git迁移 项目开发的不同阶段可能要使用不同的git仓库,有时需要迁移. git有很好的方法,只需要几个命令 目标: 我们需要把代码从 http://a.com/projectA.git 迁移到 ht ...

  5. C和C指针小记(十五)-结构和联合

    1.结构 1.1 结构声明 在声明结构时,必须列出它包含的所有成员.这个列表包括每个成员的类型和名称. struct tag {member-list} variable-list; 例如 //A s ...

  6. 6、LwIP协议规范翻译——缓冲及内存管理

    6.缓冲及内存管理 在一个通信系统中,内存缓冲管理系统必须容纳各种大小的缓冲数据,其范围从包含具有数百个字节的数据的全尺寸TCP段到只有几个字节的短ICMP回复包.此外,为了避免拷贝,应该让数据内容缓 ...

  7. cocos2d-x在Android上的编译过程(3):简化Android.mk文件的编写

    在编译动态库时.要求我们要去编写jni/Android.mk文件.告诉编译器编译出来的库时应包括包括编译文件和其它引用库.但对于一个大项目来说,维护这个文件肯定是一件比較繁琐的事情.由于每加一个文件或 ...

  8. [js]面向对象2

    delete删除属性 删除对象的属性 删除未用var定义的变量. delete返回布尔 删除不存在的属性,返回true 无法删除原形中的属性 如 delete obj.toString() resu= ...

  9. Mysql导入表信息[Err] 1067 - Invalid default value for '字段名'

    修改mysql配置文件 vi /etc/my.cnf //添加以下配置 sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISI ...

  10. 十一、无事勿扰,有事通知(2)——KVO

    概述 Key-Value-Observe,简称KVO,和上节介绍的Notification师出同门,主要目的都是为了实现观察者模式. 虽说是同门师兄弟,但是各自精通的技艺却是各不相同的. 不像Noti ...