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

linux源码看socket阻塞阻塞

linux源码看socket阻塞阻塞 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。 大部分高性能网络框架采用的是非阻塞模式。...笔者这次就从linux源码的角度来阐述socket阻塞(block)和阻塞(non_block)的区别。 本文源码均来自采用Linux-2.6.24内核版本。...一个TCP阻塞client端简单的例子 如果我们要产生一个阻塞socket,在C语言中如下代码所示: // 创建socket int sock_fd = socket(AF_INET, SOCK_STREAM...的阻塞\阻塞状态 我们用fcntl修改socket阻塞\阻塞状态。...阻塞后什么时候恢复运行呢 情况1:有对应的网络数据到来 首先我们看下网络分组到来的内核路径,网卡发起中断后调用netif_rx将事件挂入CPU的等待队列,并唤起软中断(soft_irq),再通过linux

3.5K20
您找到你想要的搜索结果了吗?
是的
没有找到

ioctlsocket() 用法 socket recvfrom 阻塞 阻塞 设置

iMode);//阻塞设置 rs=recvfrom(socketc,rbuf,sizeof(rbuf),0,(SOCKADDR*)&addr,&len); int ioctlsocket (SOCKET...支持下列命令: FIONBIO:允许或禁止套接口s的阻塞模式。argp指向一个无符号长整型。如允许阻塞模式则零,如禁止阻塞模式则为零。...当创建一个套接口时,它就处于阻塞模式(也就是说阻塞模式被禁止)。这与BSD套接口是一致的。WSAAsynSelect()函数将套接口自动设置为阻塞模式。...支持下列命令: FIONBIO:允许或禁止套接口s的阻塞模式。argp指向一个无符号长整型。如 允许阻塞模式则零,如禁止阻塞模式则为零。...支持下列命令: FIONBIO:允许或禁止套接口s的阻塞模式。argp指向一个无符号长整型。如允许阻塞模式则零,如禁止阻塞模式则为零。

3.5K20

linux网络编程系列(七)--如何将socket设置成阻塞的,阻塞socket阻塞socket在收发数据上的区别

生成socket时设置 socket函数创建socket默认是阻塞的,也可以增加选项将socket设置为阻塞的: int s = socket(AF_INET, SOCK_STREAM | SOCK_NONBLOCK...使用fcntl设置 将socket设置为阻塞的 if ((nFlags = fcntl (nSock, F_GETFL, 0)) < 0) return 0; nFlags = nFlags...; send函数在阻塞模式下,会立即返回,但是会尽可能的多拷贝数据到缓冲区,但不保证全部拷贝后返回,因此阻塞模式下,send函数返回值可能比参数中发送长度小,而如果缓冲区满了的话,就会立即返回; 3.1.2...阻塞模式也一样。...3.2 接收时的区别 3.2.1 TCP接收(即recv函数) 在阻塞模式下, recv将会阻塞,直到缓冲区里有至少一个字节才返回,当没有数据到来时,recv会一直阻塞或者直到超时,不会返回; 在阻塞模式下

2.8K30

LinuxSocket编程(三)——阻塞select的使用简介

简介 什么叫阻塞阻塞 select fd_set类型的变量相关宏定义 fcntl 实例 select总是返回1的问题。...什么叫阻塞阻塞 阻塞方式block,顾名思义,就是进程或是线程执行到这些函数时必须等待某个事件的发生,如果事件没有发生,进程或线程就被阻塞,函数不能立即返回。...使用Select就可以完成阻塞(所谓阻塞方式non- block,就是进程或线程执行此函数时不必非要等待事件的发生,一旦执行肯定返回,以返回值的不同来反映函数的执行情况,如果事件发生则与阻塞方式相同...一定等到监视文件描述符集合中某个文件描述符发生变化为止 若将时间值设为0秒0毫秒,就变成一个纯粹的阻塞函数,不管文件描述符是否有变化,都立刻返回继续执行,文件无变化返回0,有变化返回一个正值 timeout...SELECT_fncl.png 示例 客户端创建socket 调用fcntl设置阻塞模式 调用connect开始连接。

3.9K10

socket阻塞阻塞,同步与异步、IO模型

阻塞IO和阻塞IO的区别就在于:应用程序的调用是否立即返回! 同步和异步都只针对于本机SOCKET而言的。同步和异步,阻塞阻塞,有些混用,其实它们完全不是一回事,而且它们修饰的对象也不相同。...二、Linux下的五种I/O模型: 1)阻塞I/O(blocking I/O) 2)阻塞I/O (nonblocking I/O) 3) I/O复用(select 和poll) (I/O multiplexing...我们把一个SOCKET接口设置为阻塞就是告诉内核,当所请求的I/O操作无法完成时,不要将进程睡眠,而是返回一个错误。...当使用socket()函数和WSASocket()函数创建套接字时,默认都是阻塞的。在创建套接字之后,通过调用ioctlsocket()函数,将该套接字设置为阻塞模式。...Linux下的函数是:fcntl()。 套接字设置为阻塞模式后,在调用Windows Sockets API函数时,调用函数会立即返回。

1.6K30

socket阻塞阻塞,同步与异步、IO模型

阻塞IO和阻塞IO的区别就在于:应用程序的调用是否立即返回! 同步和异步都只针对于本机SOCKET而言的。...Linux下的五种I/O模型 1)阻塞I/O(blocking I/O) 2)阻塞I/O (nonblocking I/O) 3) I/O复用(select 和poll) (I/O multiplexing...阻塞IO模型 : 简介:阻塞IO通过进程反复调用IO函数( 多次系统调用,并马上返回 ); 在数据拷贝的过程中,进程是阻塞的 ; 我们把一个SOCKET接口设置为阻塞就是告诉内核...当使用socket()函数和WSASocket()函数创建套接字时,默认都是阻塞的。在创建套接字之后,通过调用ioctlsocket()函数,将该套接字设置为阻塞模式。...Linux下的函数是:fcntl(). 套接字设置为阻塞模式后,在调用Windows Sockets API函数时,调用函数会立即返回。

1.4K20

socket阻塞阻塞,同步与异步IO模型

作者:huangguisu 原文出处:http://blog.csdn.net/hguisu/article/details/7453390 socket阻塞阻塞,同步与异步 1....Linux下的五种I/O模型 1)阻塞I/O(blocking I/O) 2)阻塞I/O (nonblocking I/O) 3) I/O复用(select 和poll) (I/O multiplexing...我们把一个SOCKET接口设置为阻塞就是告诉内核,当所请求的I/O操作无法完成时,不要将进程睡眠,而是返回一个错误。...当使用socket()函数和WSASocket()函数创建套接字时,默认都是阻塞的。在创建套接字之后,通过调用ioctlsocket()函数,将该套接字设置为阻塞模式。...Linux下的函数是:fcntl().     套接字设置为阻塞模式后,在调用Windows Sockets API函数时,调用函数会立即返回。

2.9K10

Linux编程(阻塞阻塞IO)

Linux设备驱动中的阻塞阻塞I/0,简单来说就是对I/O操作的两种不同的方式,驱动程序可以灵活的支持用户空间对设备的这两种访问方式。...阻塞操作:在不能进行设备操作时,并不挂起,它或者放弃,或者不停地查询,直到可以进行操作。...阻塞应用程序通常使用select系统调用查询是否可以对设备进行无阻塞的访问最终会引发设备驱动中 poll 函数执行。...|O_NONBLOCK); //O_NONBLOCK 阻塞标识 ..... while(read(fd,&buf,1)!...阻塞I/O的操作在应用层通常会用到select()和poll()系统调用查询是否可对设备进行无阻塞访问。select()和poll()系统调用最终会引发设备驱动中的poll()函数被调用。

5.4K20

linux阻塞阻塞(connect连接超时)

阻塞connect详情介绍可以参见文章:https://blog.csdn.net/qq_41453285/article/details/89890429 一、阻塞connect概述 man手册...解析文档,阻塞connect如何使用: ①当我们将sock设置为阻塞之后,使用connect去连接服务端,即使服务端开启了,connect系统调用也不会连接成功,connect而是以失败告终,并返回错误...,进一步来等待阻塞connect客户端与服务端建立完整地连接,在等待的过程中,如果阻塞connect建立成功了,客户端的sock_fd就会变成可写的(这个在本人的IO复用文章中介绍过,见下图) ④当阻塞...connect建立成功之后还可以利用getsockopt来读取错误码并清除该socket上的错误: 如果错误码为0,表示连接成功建立 否则连接失败 二、阻塞connect的移植性问题 移植性问题如下...: 1.首先,阻塞socket可能导致connect始终失败 2.其次,select对处于EINPROGRESS状态下的socket可能不起作用 3.最后,对于出错的socket,getsockopt

6.1K10

从Java Socket阻塞到Netty入门流程

本博客 猫叔的博客,转载请申明出处 阅读本文约 “4分钟” 适读人群:同学 Java IO,Socket阻塞通信流程 这里我们使用一个内嵌的永久循环,来让Socket成为一个阻塞的通信流程...如上图所示,ServerSocket是我们自建的一个类,通过启动线程,且线程内置一个真循环,防止accept阻塞; 在客户端监听类上,将监听到的socket作为参数,传递到客户端监听类上,并再次启动线程...,获取一个InputStream,同时再次在这个刚刚启动线程内置一个真循环,为的是不断获取信息并回写; 这里要注意的是,第一个真循环是保证获取新连接不会阻塞,第二个真循环是保证不停的获取客户端信息并回写...NioEventLoop(事件循环) 1、新连接接入 2、连接上的数据读取 Channel(抽象连接) Socket、SocektChannel(IO\NIO)抽象 ChannelHandler(业务逻辑处理

59120

(四) 如何将socket设置为阻塞模式

另外,windows和linux平台上accept()函数返回的socekt也是阻塞的,linux另外提供了一个accept4()函数,可以直接将返回的socket设置为阻塞模式: int accept...除了创建socket时,将socket设置成阻塞模式,还可以通过以下API函数来设置: linux平台上可以调用fcntl()或者ioctl()函数,实例如下: fcntl(sockfd, F_SETFL.../details/44306993),linux下如果调用fcntl()设置socket阻塞模式,不仅要设置O_NONBLOCK模式,还需要在接收和发送数据时,需要使用MSG_DONTWAIT标志,...u_long *argp ); 将cmd参数设置为FIONBIO,*argp=0即设置成阻塞模式,而*argp0即可设置成阻塞模式。...再次调用ioctlsocket()将该socket设置成阻塞模式才会成功。因为调用WSAAsyncSelect()或WSAEventSelect()函数会自动将socket设置成阻塞模式。

4.4K70

使用epoll时需要将socket设为阻塞吗?

listenfd 为什么一定要设置成阻塞的,我在另外一篇文章中写的很清楚: 高性能网络通信库中为何要将侦听 socket 设置成阻塞的?...五、总结与学习建议 题主提出这样的问题,建议还是加强基础原理和概念的理解,搞清楚每一种技术用于何种场景,例如阻塞 socket 用于何种场景、影响哪些返回,I/O 复用函数为何阻塞或等待。...API,通过这本书你能学会常用的操作系统 Socket API 和常用的网络模型,认真学完之后,你不会再纠结同步异步、阻塞阻塞等概念。...上的select函数 302 4.5.2 Windows上的select函数 317 4.6 socket阻塞模式和阻塞模式 318 4.6.1 如何将socket设置为阻塞模式 318 4.6.2...send和recv函数在阻塞阻塞模式下的表现 320 4.6.3 阻塞模式下send和recv函数的返回值总结 331 4.6.4 阻塞阻塞socket的各自适用场景 333 4.7 发送0

2.2K10

同步、异步、阻塞阻塞

阻塞阻塞   应用进程请求I/O操作时,如果数据未准备好,如果请求立即返回就是非阻塞,不立即返回就是阻塞。简单说就是做一件事如果不能立即获得返回,需要等待,就是阻塞,否则就可以理解为阻塞。...socket接收数据的另外一个函数recv则是一个阻塞调用的例子。当socket工作在阻塞模式的时候, 如果没有数据的情况下调用该函数,则当前线程就会被挂起,直到有数据为止。...阻塞 阻塞阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。...同步/异步与阻塞/阻塞的组合 同步阻塞形式: 等待执行结果是一直等待,执行时线程挂起(未对fd 设置O_NONBLOCK 标志位的read/write 操作) 同步阻塞形式:等待执行结果是一直等待,...异步阻塞形式:在处理消息是不等待,在执行消息是也不等待。

2.9K40

同步异步,阻塞阻塞

什么是阻塞阻塞 阻塞阻塞是针对于进程在访问数据的时候,根据IO操作的就绪状态来采取的不同方式,阻塞方式下读取或者写入函数将一直等待,而非阻塞方式下,读取或者写入函数会立即返回一个状态值。...阻塞阻塞:针对函数(程序)运行的方式,在IO未就绪时,是等待就绪还是直接返回(执行别的操作)。...阻塞阻塞的区别: 阻塞是程序在调用系统函数IO时,在系统执行系统调用时由CPU通过轮询等方式来实现数据的IO。 阻塞是在程序级别通过轮询/信号/事件的机制,去查看IO数据是否就绪。...可以是阻塞阻塞阻塞则一直在等待内核/应用程序把IO数据准备好,阻塞则是直接返回内核/应用程序是否已经准备好数据。 应用程序框架:同步或异步。...IO多路复用,同步,异步,阻塞阻塞 区别 关于异步,同步,阻塞阻塞 解读I/O多路复用技术

3.1K60

阻塞 & 阻塞 | 同步 & 异步

这里讲的都是基于IO的 阻塞阻塞、同步、异步 ---- 一个典型的IO操作包括了两个阶段,数据准备和数据读写。比如说现在要使用 recv 执行一个读操作,数据就绪就是远端是否有数据可读。...当IO工作在阻塞状态下的时候,如果数据没有就绪,recv就会阻塞当前线程;如果说IO工作在阻塞状态下,会立即返回。...返回值-1的话,就说明连接出现问题,连接异常;如果返回值是0,且errno是EAGIN的话,就说明这是一个正常的阻塞,返回数据未就绪状态。...一个同步IO接口的示例: char buf[1024]; int sz = recv(sockfd,buf,1024,0); //阻塞:一直在这儿死等 //阻塞:时不时的回来问一下 if(sz>0)...---- 五种IO模型 阻塞阻塞: 多路IO复用 信号驱动: 这里就完全放飞自我了 异步: ---- Reactor反应堆模型 One loop per thread

2.8K10

同步、异步、阻塞阻塞

当连接真正建立起来以后,socket底层会发送一个消息通知该对象。这里提到执行部件和调用者通过三种途径返回结果:状态、通知和回调。...socket接收数据的另外一个函数recv则是一个阻塞调用的例子。当socket工作在阻塞模式的时候,如果没有数据的情况下调用该函数,则当前线程就会被挂起,直到有数据为止。...阻塞 阻塞阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。...阻塞对象上可以有阻塞的调用方式,我们可以通过一定的API去轮询状态,在适当的时候调用阻塞函数,就可以避免阻塞。而对于阻塞对象,调用特殊的函数也可以进入阻塞调用。...阻塞/阻塞则是小明的等待方式,或者说 API 调用者的等待方式。 在不同的场景下,同步/异步、阻塞/阻塞的四种组合都有应用。

2.2K50
领券