erlang怎样有效监听大量并发连接
2016-03-09 17:56
302 查看
看了erlang的一些开源网络框架RabbitMQ、Ranch。他们都使用多个进程同一时候accept一个socket。
这样的方式在使得socketport监听的工作分担了很多其它的调度机会。可是,在erlang中,socket接受一个新连接后,假设想让还有一个进程处理消息,就要显式的调用gen_tcp:controlling_process(Socket, Pid)。
所以问题来了,erlang多个进程同一时候监听一个socket安全吗?
这样的方式在早期的erlang是不安全的,但R11B03 版本号之后,erlang做了改进,同意多个进程同一时候监听同一个socket。
erlang R11B03 更新日志
OTP-6416 gen_tcp now allows for several processes to issue accept calls to the same listen-socket simultaniously. The different accepting processes will get connected sockets on a first-come-first-served basis.
当多个进程同一时候accept一个socket,erlang 内部将使用队列保存acceptor信息。以先来先服务的原则将新的连接关联到acceptor,再给acceptor投递消息 {inet_async, L, Ref, Result}。
详细看\erts\emulator\drivers\common\inet_drv.c 的 tcp_inet_ctl 函数,erlang对socket的处理都集中在inet_drv.c
erlang配合{backlog, N},监听新连接效果更佳
backlog是erlang用来设置socket等待连接队列。N为队列的长度,默认值5,显然太小了
參考:
http://blog.csdn.net/mycwq/article/details/27108911
这样的方式在使得socketport监听的工作分担了很多其它的调度机会。可是,在erlang中,socket接受一个新连接后,假设想让还有一个进程处理消息,就要显式的调用gen_tcp:controlling_process(Socket, Pid)。
所以问题来了,erlang多个进程同一时候监听一个socket安全吗?
这样的方式在早期的erlang是不安全的,但R11B03 版本号之后,erlang做了改进,同意多个进程同一时候监听同一个socket。
erlang R11B03 更新日志
OTP-6416 gen_tcp now allows for several processes to issue accept calls to the same listen-socket simultaniously. The different accepting processes will get connected sockets on a first-come-first-served basis.
当多个进程同一时候accept一个socket,erlang 内部将使用队列保存acceptor信息。以先来先服务的原则将新的连接关联到acceptor,再给acceptor投递消息 {inet_async, L, Ref, Result}。
详细看\erts\emulator\drivers\common\inet_drv.c 的 tcp_inet_ctl 函数,erlang对socket的处理都集中在inet_drv.c
erlang配合{backlog, N},监听新连接效果更佳
backlog是erlang用来设置socket等待连接队列。N为队列的长度,默认值5,显然太小了
參考:
http://blog.csdn.net/mycwq/article/details/27108911
相关文章推荐
- 使用 Subversion (SVN) 的方式来访问 Github
- hdu1087最大流
- unity3d调用jar类中的方法和属性
- UI学习第08天
- Hello world S.B.S.
- grep检索文本
- 高项3.7日第一次课,第一章信息化基础知识与第二章信息系统服务管理要点梳理
- Oracle特殊字段处理--工作备忘2016/03/09
- 给select添加自定义值和选项
- Newtonsoft.Json.dll 中的序列化与反序列化
- Android 的 分发机制
- jersey spring shiro mybatis mysql集成配置
- socket
- 调试动态链接库(DLL)
- 如何在21天之内精通面向对象的编程
- 如何在Eclipse中嵌入外部工具
- Linux时间戳和标准时间的互转
- 3ds Max 切换渲染器
- 怎样提高网站访问速度缩短网页加载时间
- 自定义控件的自定义的属性attrs.xml下的declare-styleable中format详解