摘要: 问题产生 一个完整的业务可能会被TCP拆分成多个包进行发送,也有可能把多个小的包封装成一个大的数据包发送,这个就是TCP的拆包和封包问题。 下面可以看一张图,是客户端向服务端发送包: 1. 第一种情况,Data1和Data2都分开发送到了Server端,没有产生粘包和拆包的情况。 2. 第二种情况, 阅读全文
posted @ 2016-02-24 14:26 孟环标 阅读(258) 评论(0) 推荐(0) 编辑
摘要: 传输层: 对于UDP协议来说,整个包的最大长度为65535,其中包头长度是65535-20=65515; 对于TCP协议来说,整个包的最大长度是由最大传输大小(MSS,Maxitum Segment Size)决定,MSS就是TCP数据包每次能够传 输的最大数据分段。为了达到最佳的传输效能TCP协议 阅读全文
posted @ 2016-02-24 14:17 孟环标 阅读(672) 评论(0) 推荐(0) 编辑
摘要: 网卡工作原理 Linux操作系统的功能可以概括为进程管理、内存管理、文件系统管理、设备管理、网络等几部分。所有的系统操作最终都可以映射到对物理设备的操作。除去对CPU、内存以及其他少数几个物理实体的操作之外,系统对其他设备的所有操作都通过专门的称为驱动程序的代码完成。系统中存在的每种外设在内核中都必 阅读全文
posted @ 2016-02-24 11:06 孟环标 阅读(4533) 评论(0) 推荐(0) 编辑
摘要: 最近看了一些网络编程的书籍,一直以来总感觉网络编程神秘莫测,其实网络编程入门还是很容易学的,下面这些代码是我在linux下编写的,已经运行过了,编译之后就可以运行了。有不足之处希望大家多多指出,共同学习交流。 套接字是一种进程间的通信的方法,不同于以往介绍的进程间通信方法的是,它并不局限于同一台计算 阅读全文
posted @ 2016-02-24 10:59 孟环标 阅读(260) 评论(0) 推荐(0) 编辑
摘要: LINUX下SYN攻防战 (一)SYN攻击原理SYN攻击属于DOS攻击的一种,它利用TCP协议缺陷,通过发送大量的半连接请求,耗费服务器CPU和内存资源.SYN攻击聊了能影响主机外,还可以危害路由器,防火墙等网络系统,事实上SYN攻击并不管目标是什么系统,只要这些系统打开TCP服务就可以实施.我们知 阅读全文
posted @ 2016-02-24 10:54 孟环标 阅读(1468) 评论(0) 推荐(1) 编辑
摘要: 引言 本篇属于TCP/IP协议的基础知识,重点介绍了TCP/IP协议簇的内容、作用以及TCP、UDP、IP三种常见网络协议相关的基础知识。 内容 TCP/IP协议簇是由OSI七层模型发展而来的,之所以存在OSI互联参考模型主要有以下几点好处: 1、用于解决不同厂商的设备互联问题:即兼容性考虑; 2、 阅读全文
posted @ 2016-02-24 10:52 孟环标 阅读(252) 评论(0) 推荐(0) 编辑
摘要: 所谓三次握手(Three-Way Handshake)即建立TCP连接,就是指建立一个TCP连接时,需要客户端和服务端总共发送3个包以确认连接的建立。所谓四次挥手(Four-Way Wavehand)即终止TCP连接,就是指断开一个TCP连接时,需要客户端和服务端总共发送4个包以确认连接的断开。 A 阅读全文
posted @ 2016-02-24 10:50 孟环标 阅读(199) 评论(0) 推荐(0) 编辑
摘要: tcp服务器在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接。 第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认; 第二次握手:服务器收到syn包,必须确认客户的SYN(ack=j+1),同时自己也发送一个SYN 阅读全文
posted @ 2016-02-24 10:49 孟环标 阅读(499) 评论(0) 推荐(0) 编辑
摘要: 最近项目需要做单机100万长连接与高并发的服务器,我们开发完服务器以后,通过自己搭的高速压测框架压测服务端的时候,发生了奇怪的现象,就是服务端莫名其妙的少接收了连接,造成了数据包的丢失,通过网上查资料,和自己的实践,下面是我做实验,抓包分析的过程如下: 总共5个连接 其中全连接队列somaxconn 阅读全文
posted @ 2016-02-24 10:46 孟环标 阅读(3619) 评论(0) 推荐(0) 编辑