首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

tcp服务器进程的特征

TCP(Transmission Control Protocol,传输控制协议)服务器进程是一种基于TCP协议的网络服务器,它通过建立可靠的连接,确保数据的完整性和顺序性,适用于需要高可靠性的应用场景,如Web服务器、文件传输等。以下是TCP服务器进程的特征和工作原理:

TCP服务器进程的特征

  • 面向连接:TCP服务器在数据传输前需要与客户端建立连接,通过三次握手确保连接的可靠性。
  • 可靠性:通过序列号、确认应答、重传机制等确保数据的可靠传输。
  • 基于字节流:将数据分割成小的数据包进行传输,并在接收端重新组装。
  • 高效性:通过滑动窗口、拥塞控制等机制提高数据传输效率。
  • 并发处理:能够同时处理多个客户端的连接请求和数据传输,通常使用多线程或多进程实现。

TCP服务器进程的工作原理

  1. 建立连接:通过三次握手过程,客户端和服务器之间建立可靠的连接。
  2. 数据传输:一旦连接建立,服务器通过这个连接接收客户端的数据,或者向客户端发送数据。
  3. 关闭连接:数据交换完成后,通过四次挥手的过程关闭连接。

TCP服务器进程通过上述特征和工作原理,确保了在互联网上提供稳定、可靠的数据通信服务。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

TCP并发服务器(多进程与多线程)

多进程并发服务器 我们在上一节写的TCP服务器只能处理单连接,在代码实现时,多进程并发服务器与非并发服务器在创建监听套接字、绑定、监听这几个步骤是一样的,但是在接收连接请求的时候,多进程并发服务器是这样实现的...示意图如下: (1)什么是并发 单核CPU → 多进程/线程并发 → 时间片轮转 并发 → 某一个时间片/点所能处理的任务数 服务器并发:服务器在某个时间点/片所能处理的连接数所能接收的client连接越多...,并发量越大 (2)多进程并发服务器需要注意的几个要点 使用多进程的方式来解决服务器处理多连接的问题,需要注意下面几点: 共享:读时共享、写时复制。...同样是为了节省资源,子进程被fork()出来后也会拥有一个用于监听的文件描述符(因为子进程是对父进程的拷贝),但是子进程的作用是与客户端通信,所以用于监听的文件描述符对子进程而言并无用处,关闭以节省资源...多线程并发服务器 多线程并发服务器示意图如下: 在多进程模型中,fork得到的子进程会复制父进程的文件描述符cfd等信息,每个进程的cfd都是自己的,操作互不影响。

22310
  • TCP攻击的主要特征是什么?

    大多数人说知道DDOS攻击 、CC攻击就是不知道TCP攻击是什么,近期发现TCP攻击逐渐增加。因此得出,后续TCP攻击是DDOS攻击中新的发展趋势,给DDOS防御公司带来了新的挑战。...模型中,TCP属于第四层的负载均衡。...那么TCP攻击可以理解为:黑客伪造源服务器IP向公网的TCP服务器发起连接请求,致使被攻击服务器收到大量SYN/ACK请求数据,最终造成拒绝服务的手法。...而这种TCP攻击存在协议行为,导致此攻击方法愈演愈烈。 TCP主要特征有:3次握手连接和4次挥手断开;进行拥塞控制,服务端还需要单独解析协议内容有:少包、丢包、异常响应等。...,进而达到占用分配资源的目的,导致正常的数据请求因为服务器已经无法接收而被屏蔽,因此网络堵塞早晨服务器系统瘫痪。

    1K10

    Linux - lsof显示 tcp,udp 的端口和进程

    文章目录 功能 语法 示例 lsof -i 显示 tcp,udp 的端口和进程等相关 查看服务器 80 端口的占用情况 使用 -p 查看指定进程打开的文件 更多命令 功能 lsof(list open...:https (ESTABLISHED) 查看服务器 80 端口的占用情况 [root@VM-24-3-centos ~]# lsof -i:80 COMMAND PID USER FD TYPE...111507996 0t0 TCP *:http (LISTEN) [root@VM-24-3-centos ~]# COMMAND:进程的名称 PID进程标识符 USER:进程所有者 FD...:80 查看TCP协议80端口占用情况 lsof -c lsof 查看lsof命令使用的所有文件 lsof -p 1234:列出进程号为1234的进程所打开的文件 lsof -g gid:显示归属gid...的进程情况 lsof +d /usr/local/:显示目录下被进程开启的文件 lsof +D /usr/local/:同上,但是会搜索目录下的目录,时间较长 lsof -d 4:显示使用fd为4的进程

    3.2K20

    Nginx服务器的进程

    Nginx服务器的进程有3类:主进程、工作进程、缓存进程 (1)主进程 Nginx启动时运行的主要进程,主要功能是与外界通信和对内部其他进程进行管理 主要工作内容 1)读取配置文件,验证有效性和正确性...2)建立、绑定、关闭 socket 3)按照配置生成、管理、结束工作进程 4)接收指令,如 重启、升级、退出 5)不中断服务,平滑重启、升级,升级失败的回滚处理 6)开启日志文件,获取文件描述符 (2)...工作进程 由主进程生成,生成数量由配置文件指定,工作进程生存于主进程的整个生命周期 主要工作内容 1)接收请求 2)将请求依次送入各个功能模块进行过滤处理 3)IO调用,获取响应数据 4)与后端服务器通信...,接收后端服务器处理结果 5)数据缓存,访问缓存索引、查询、调用缓存数据 6)发送请求结果 7)接收主进程指令,如 重启、升级、退出 (3)缓存进程 缓存进程有两类 1)缓存索引重建进程 nginx启动后由主进程生成...,在缓存元数据重建完成后就自动退出 该进程启动后,对缓存文件的目录结构扫描,在内存中建立索引元数据库 2)缓存索引管理进程 生存于主进程的整个生命周期 负责在索引元数据更新完成后,对元数据是否过期进行判断

    4.4K40

    IOCP模型TCP服务器

    主线程创建监听套接字,创建额外工作线程,关联IOCP,负责等待和接受到来的连接。...调用GetQueuedCompletionStatus函数,函数返回: 1 调用失败 2 套接字被对方关闭 3 请求成功完成 程序首先定义per-handle per-IO的操作数据的结构类型 #define...define OP_WRITE 2 #define OP_ACCEPT 3 }PER_IO_DATA,*PPER_IO_DATA; 主要过程: 1 主线程创建完成端口对象,创建工作线程处理完成端口对象中的事件...2 创建监听套接字,开始监听服务器端口 3 进入无限循环,处理到来的请求 1)调用accept函数等待接受未决的连接请求   2)创建一个per-handle数据   3)投递一个接收请求 实现代码...:bind(sListen,(sockaddr*)&si,sizeof(si)); ::listen(sListen,5); while(TRUE){ //等待接收未决的请求

    1.8K70

    Python TCP服务器v1.6 - multiprocessing多进程及Ctrl-c(SIGINT)退出

    TCP聊天服务器套接字v1.6 所有版本记录: v1.0 : TCP聊天服务器套接字|PyQt5+socket(TCP端口映射+端口放行)+logging+Thread(含日志,html)+anaconda...TCP服务器v1.2 - 服务端新增用户登录注册(json, md5加密) v1.3 : python TCP服务器v1.3 - 服务器抗压测试及关闭套接字处理 v1.4 : python TCP服务器...v1.4 - 客户端连接服务器异常(异常情况分类)处理 v1.5 : PyQt5可编辑下拉框(comboBox):editable - python TCP服务器v1.5 - 客户端连接界面增加自定义参数...| 多线程threading 与 多进程multiprocess 线程:所有的线程运行在同一个进程中,共享相同的运行环境。...进程:程序的一次执行(程序载入内存,系统分配资源运行)。每个进程有自己的内存空间,数据栈等,进程之间可以进行通讯,但是不能共享信息。

    74240

    2.1.1 操作系统之进程的定义、特征、组成、组织

    文章目录 1.进程的定义 (1)程序的概念 (2)进程的概念 (3)进程的定义 2.进程的特征 3.进程的组成 4.进程的组织 (1)链接方式 (2)索引方式 ---- 1.进程的定义 (1)程序的概念...(2)进程的概念 进程和程序的区别和联系: 区别: 1)进程是动态的;程序是静态的。...(2)进程有独立性,能并发执行;程序不能并发执行。 (3)二者无一一对应关系。 (4)进程异步运行,会相互制约;程序不具备此特征。...(3)进程的定义 2.进程的特征 3.进程的组成 而其中最重要的就是进程控制块PCB(Process Control Block) PCB简介: PCB中记录了操作系统所需的...可见,在进程的整个生命期中,系统总是通过PCB对进程进行控制的,即系统是根据进程的PCB而不是任何别的什么而感知到该进程的存在的。 所以说,PCB是进程存在的唯一标志。

    41720

    多进程服务器

    一、思路 先与客户端建立好连接, 每次监听到一个客户端之后,都需要产生一个子进程去处理这个连接,然后父进程继续去等待监听,唯一一个要注意的点就是要使用信号来监听子进程是否结束,从而对其进行回收,防止僵尸进程的产生...二、步骤 1、建立连接 (1)socket函数 这里使用的是Ipv4,TCP套接字,所以使用的接口是:lfd = socket(AF_INET, SOCK_STREAM, 0)如果是IPV6把AF_INET...&opt, sizeof(opt)); (3)bind函数 bind(lfd, (struct sockaddr*)&ser_addr, sizeof(ser_addr));b这个函数主要目的就是将服务器的地址结构绑定到套接字...lfd上,所以开始要设置服务器的ser_addr:ser_addr.sin_family = AF_INET, ser_addr.sin_port = htons(8888);ser_addr.sin_addr.s_addr..., buf, n); } } 4、父进程回收子进程 父进程使用信号机制来对子进程回收 主要是通过sigaction函数 struct sigaction act; act.sa_handler

    4.7K20

    速读原著-TCPIP(TCP 服务器的设计)

    第18章 TCP连接的建立与终止 18.11 TCP 服务器的设计 我们在1 . 8节说过大多数的T C P服务器进程是并发的。...当一个新的连接请求到达服务器时,服务器接受这个请求,并调用一个新进程来处理这个新的客户请求。不同的操作系统使用不同的技术来调用新的服务器进程。...18.11.1 TCP服务器端口号 通过观察任何一个 T C P服务器,我们能了解 T C P如何处理端口号。我们使用 n e t s t a t命令来观察 Te l n e t服务器。...处于L I S T E N状态的服务器进程仍然存在。这个服务器进程是当前 Te l n e t服务器用于接收其他的连接请求。...ESTABLISHED tcp 0 0 140.252.1.29.8888 *.* LISTEN 但如果我们试图从以太网( 1 4 0 . 2 5 2 . 1 3)中的主机与这个服务器进行连接,连接请求将被

    79820

    Netty搭建TCP服务器实践

    在netty基本组件介绍中,我们大致了解了netty的一些基本组件,今天我们来搭建一个基于netty的Tcp服务端程序,通过代码来了解和熟悉这些组件的功能和使用方法。...首先我们自己创建一个Server类,命名为TCPServer 第一步初始化ServerBootstrap,ServerBootstrap是netty中的一个服务器引导类,对ServerBootstrap...的实例化就是创建netty服务器的入口 public class TCPServer {     private Logger log = LoggerFactory.getLogger(getClass...通过以上的代码我们可以看到,一个基于netty的TCP服务的搭建基本就是三大块: 1、对引导服务器类ServerBootstrap的初始化; 2、对ChannelPipeline的定义,也就是把多个ChannelHandler...组成一条任务链; 3、对 ChannelHandler的具体实现,其中可以有编解码器,可以有对收发数据的业务处理逻辑; 以上代码只是在基于netty框架搭建一个最基本的TCP服务,其中包含了一些netty

    2K20

    Go Web---tcp服务器

    Go Web---tcp服务器 tcp 服务器 优化版本 ---- tcp 服务器 这部分我们将使用 TCP 协议和之前讲到的协程范式编写一个简单的客户端-服务器应用,一个(web)服务器应用需要响应众多客户端的并发请求...listener,他实现了服务器的基本功能:用来监听和接收来自客户端的请求(在 localhost 即 IP 地址为 127.0.0.1 端口为 50000 基于TCP协议)。...如果在服务器没有开始监听的情况下运行客户端程序,客户端会停止并打印出以下错误信息:对tcp 127.0.0.1:50000发起连接时产生错误:由于目标计算机的积极拒绝而无法创建连接。...simple_tcp_server.go 从很多方面优化了第一个tcp服务器的示例 server.go 并且拥有更好的结构,它只用了 80 行代码!...在命令行中输入 simple_tcp_server localhost 50000 来启动服务器程序,然后在独立的命令行窗口启动一些 client.go 的客户端。

    1.7K30
    领券