Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5119208
  • 博文数量: 921
  • 博客积分: 16037
  • 博客等级: 上将
  • 技术积分: 8469
  • 用 户 组: 普通用户
  • 注册时间: 2006-04-05 02:08
文章分类

全部博文(921)

文章存档

2020年(1)

2019年(3)

2018年(3)

2017年(6)

2016年(47)

2015年(72)

2014年(25)

2013年(72)

2012年(125)

2011年(182)

2010年(42)

2009年(14)

2008年(85)

2007年(89)

2006年(155)

分类: Erlang

2014-06-22 17:38:15



  1. 一. ranch app启动:
  2. ranch_sup ->
  3.     ranch_server % 创建ets, 并提供接口给其他进程读写
  4. 二. 启动diy app (监听模块: 用ranch_tcp -> gen_tcp中的方法, 而不是prim_inet)
  5. ranch:start_listener方法 -> ranch_sup:start_child
  6. ranch_listener_sup -> % 默认每个acceptor最大1024个连接
  7. ranch_conn_sup % 等待acceptor发送消息
  8. ranch_acceptor_sup -> % 如果没传listen socket, 自动开启
  9. ranch_acceptor
  10. % 根据ranch:start_listener第二个参数启动N个acceptor
  11. % 等待新的请求
  12. 三. 收到请求:
  13. 1. ranch_acceptor接收到Client Socket
  14. (新版erlang支持多进程同时调用gen_tcp:recv)
  15. 将Client Socket控制权(ranch_tcp:controlling_process)交给ranch_conn_sup
  16. 向ranch_conn_sup发消息
  17. {ranch_conn_sup, start_protocol, acceptor pid(), Client Socket}
  18. 等待ranch_conn_sup返回消息
  19. ( ranch_conn_sup在这里延长时间回复, 实现限制最大连接数 )
  20. 2. ranch_conn_sup(非supervisor)收到client socket
  21. 根据protocol参数启动protocol_handler
  22. 然后计算当前连接数是否超标
  23. 超标就不给当前的acceptor回消息( 对应第二小步最后 )
  24. 并将当前acceptor pid保存到一个休眠列表
  25. 3. protocol_handler处理完退出消息发给ranch_conn_sup
  26. ranch_conn_sup收到后递减连接数
  27. 弹出一个休眠列表的acceptor并发消息回复使其激活


单端口最大连接数 = max connection + acceptor总数 – 1








原链接:
阅读(2899) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~