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

从linux源码看epoll

从linux源码看epoll 前言 在linux的高性能网络编程中,绕不开的就是epoll。...简单的epoll例子 下面的例子,是从笔者本人用c语言写的dbproxy中的一段代码。由于细节过多,所以做了一些删减。...(注:由于是tcp socket,所以这边sock->ops=inet_stream_ops,这个初始化的过程在我的另一篇博客从linux源码看socket的阻塞和非阻塞>>中,博客地址如下: https...ep_poll_callback,用于回调唤醒 // 注意,这边不是init_waitqueue_entry,即没有将当前KSE(current,当前进程/线程)写入到 // wait_queue当中,因为不一定是从当前安装的...总结 epoll作为linux下非常优秀的事件触发机制得到了广泛的运用。其源码还是比较复杂的,本文只是阐述了epoll读写事件的触发机制,探究linux kernel源码的过程非常快乐^_^。

5.2K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    从linux源码看socket的close

    从linux源码看socket的close 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。...上篇博客讲了socket的阻塞和非阻塞,这篇就开始谈一谈socket的close(以tcp为例且基于linux-2.6.24内核版本) TCP关闭状态转移图: 众所周知,TCP的close过程是四次挥手...但最终解决方案还是得从应用程序着手。...总结 linux内核源代码博大精深,阅读其代码很费周折。之前读>的时候由于有先辈引导和梳理,所以看书中所使用的BSD源码并不觉得十分费劲。...直到现在自己带着问题独立看linux源码的时候,尽管有之前的基础,仍旧被其中的各种细节所迷惑。希望笔者这篇文章能帮助到阅读linux网络协议栈代码的人。

    5.5K80

    从安装linux到安装hadoop

    www.oracle.com/technetwork/java/javase/downloads/java-se-6u24-download-338091.html cp /Downloads/jdk-6u24-linux-x64....bin /usr/java cd /usr/java sh /jdk-6u24-linux-x64.bin Set JAVA_HOME / PATH for single.../java export PATH=$PATH:/usr/java/jdk1.6.0_24/bin reference: http://www.cyberciti.biz/faq/linux-unix-set-java_home-path-variable...reference:http://www.jb51.net/os/Ubuntu/1049.html http://www.cyberciti.biz/tips/howto-ubuntu-linux-convert-dhcp-network-configuration-to-static-ip-configuration.html...9f65cb4a8c8507ed4fece7631046893b4c4380147d8c8c4668d4e419ce3b4c413037bfa6663f405a8e906b6075a94f5feef166253c0123b5998bdd0c81ac925f75ce786a6459db0144dc47f497016fd620e11eb2b81897ad813384daa3c4ae5744bd24127af1e7fd5d1764cb7881652697ad&p=8366de5985cc45ff57ec9e0c5552&user=baidu&fm=sc&query=linux

    1.9K120

    从Linux源码看Socket(TCP)的accept

    前言 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。...关于epoll的原理可以看下笔者之前的博客《从linux源码看epoll》: https://www.cnblogs.com/alchemystar/p/13161781.html 在这里描述一下原因,...在accept_queue被填充后,由用户线程通过accept系统调用从队列中获取对应的fd 值得注意的是,当用户线程来不及处理的时候,内核会drop掉三次握手成功的连接,导致一些诡异的现象,具体可以看笔者的另一篇博客...: https://www.cnblogs.com/alchemystar/p/13473999.html 另外,对于accept_queue具体的填充机制以及源码,可以见笔者另一篇博客的详细分析 《从Linux...源码看Socket(TCP)的listen及连接队列》: https://www.cnblogs.com/alchemystar/p/13845081.html 总结 Linux内核源码博大精深,每次扎进去探索时候都会废寝忘食

    1.8K00

    Linux系统从安装开始

    已经很久很久没来得及写博客了,想想之前自己开始安装使用Linux系统的尝试,好像很简单!...下面开始Linux系统的安装:这里推荐U盘安装   首先你必须下载一个U盘ISO镜像写入工具,本人使用USBWrite,下载地址:https://sourceforge.net/projects/usbwriter...第四步重启电脑,进入Bios设置从U盘启动,然后保存确定退出,系统开始进入Linux安装界面,选择操作的语言,所属时区等,设置管理员账号密码,如果电脑已经安装Windon系统,这时会有提示是否需要安装双系统还是完全格式化硬盘...,只安装Linux....然后就是分区,请记住:Linux中一切皆文件。   安装Ubuntu成功最后界面: ?   后续持续更新更多内容,不在创业公司,压力远远没有那么大了,也有时间做些自己的事情了。

    1.5K70

    从linux5.9看网络层的设计

    再也不怕过时了,当然,现在内核的代码量级非常大,不可能看得完也不可能都看,只是选取自己感兴趣的一些点看一下。...看内核代码,总的来说是非常有趣的,不仅是因为知其然知其所以然,而且看到朴素的c语言,还有世界级大佬写代码的思路、思想,甚至注释,都是非常有意思的事情。...今天分析的内容是从socket函数开始,看看linux网络层的设计。下面我们看一下我们平时写网络编程代码时的用法。...网络层的初始化 从socket函数的定义中我们看到有family和type两个参数,这两个属性都会对应不同的实现。我们先看看family的实现。...rcu_assign_pointer(net_families[ops->family], ops); spin_unlock(&net_family_lock); return err;} 那么哪里会调用

    81230

    Linux:如何从源码安装应用

    可能有些应用程序只能通过源码安装。以下是操作方法。 译自 Linux: How To Install Apps From the Source,作者 Jack Wallen。...我刚开始使用Linux时,安装应用程序只有一种方法……从原始源代码安装。...接下来是AppImage,它允许你在任何平台上安装 Linux 应用程序。 剩下的就是从源代码安装。 为什么安装 Linux 应用程序的最古老方法排在列表的最后?这不仅仅是包管理器提供的简单性。...这可能是从源代码安装中最能阻止大多数人继续前进的部分。从源代码安装的问题在于,你必须首先满足所有依赖关系,然后才能尝试编译和安装该应用程序。...现在您已经从源代码安装了应用程序,您需要定期检查是否有新的更新可用。如果有,您将不得不再次执行相同的过程,这也是您应该坚持从默认包管理器安装应用程序的原因之一。

    9210

    从Linux源码看Socket(TCP)Client端的Connect

    前言 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。...今天笔者就来从Linux源码的角度看下Client端的Socket在进行Connect的时候到底做了哪些事情。由于篇幅原因,关于Server端的Accept源码讲解留给下一篇博客。...(基于Linux 3.10内核) 一个最简单的Connect例子 int clientSocket; if((clientSocket = socket(AF_INET, SOCK_STREAM, 0)...我们先看一下搜索端口号的逻辑,如下图所示: 获取端口号范围 首先,我们从内核中获取connect能够使用的端口号范围,在这里采用了Linux中的顺序锁(seqlock) void inet_get_local_port_range...重传的超时时间和 /proc/sys/net/ipv4/tcp_syn_retries 息息相关,Linux默认设置为5,建议设置成3,下面是不同设置的超时时间参照图。

    73420

    从Linux源码看Socket(TCP)Client端的Connect

    前言 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。...今天笔者就来从Linux源码的角度看下Client端的Socket在进行Connect的时候到底做了哪些事情。...获取端口号范围 首先,我们从内核中获取connect能够使用的端口号范围,在这里采用了Linux中的顺序锁(seqlock) void inet_get_local_port_range(int *low...内核中修改的地方为: cat /proc/sys/net/ipv4/ip_local_port_range 32768 61000 通过hash决定端口号起始搜索范围 在Linux上进行connect...重传的超时时间和 /proc/sys/net/ipv4/tcp_syn_retries 息息相关,Linux默认设置为5,建议设置成3,下面是不同设置的超时时间参照图。 ?

    1.5K41
    领券