mochiweb源码分析(三)
继续(二)之前讲到的部分
1.看mochiweb_acceptor:start_link/4函数
proc_lib:spawn_link/3创建进程来调用init/4函数,在init/4函数中调用do_accept/2, do_accept/2中调用mochiweb_socket:transport_accept/1
这里会根据之前是否选择SSL安全协议选择accept方式,如果不选用SSL,则直接返回Socket,如果用SSL,则返回{ssl, Socket}
成功返回accept得到的套接字后,会通过gen_server:cast/2将时间差(开始等待客户端连接至成功连接客户端的时间)发送给mochiweb_socket_server这个进程,下面讲解mochiweb_socket_server这个进程收到消息后的处理
2.
将记录中active_sockets的数量加一,再看看profile_fun有没有定义,如果有,则调用定义的函数
最后是调用recycle_acceptor/2这函数
3.
这里可以看出每当有个客户端连接上来,Pool池就会把当前负责的acceptor进程移除,同时添加一个新的acceptor进程,也就是保证Pool池,始终和启动时拥有的数量一致。
如果之前的进程已经死掉并且它不在acceptor进程池中,那么它曾拥有的socket就是一个活跃的socket(用NewSize =:= sets:size(Pool)判断)。
最后看是否超出最大套接字数量和最大进程池数量,如果没有则创建新的进程。