bind源码解析(二)
来源:互联网 发布:怎么用c语言玩单片机 编辑:程序博客网 时间:2024/06/14 22:17
bind9运行主要是两个线程和一个do while循环,这三部分构成了bind的核心代码。
result = isc_app_run();
if (result == ISC_R_RELOAD) {
ns_server_reloadwanted(ns_g_server);
} else if (result != ISC_R_SUCCESS) {
UNEXPECTED_ERROR(__FILE__, __LINE__,
"isc_app_run(): %s",
isc_result_totext(result));
/*
* Force exit.
*/
result = ISC_R_SUCCESS;
}
} while (result != ISC_R_SUCCESS);
这个do while循环,主要是result = isc_app_run();这个函数实际上等待各种结束程序信号,如果需要重启服务,就调用ns_server_reloadwanted。
在setup函数里中的create_managers(void)里,有两个函数要注意
isc_taskmgr_create、isc_socketmgr_create2这两个函数分别起两个线程,分别是run和watch。
下面是watch中的关键代码就是
cc = epoll_wait(manager->epoll_fd, manager->events,
done = process_fds(manager, manager->events, cc)这两句代码一看就知道是处理epool的。它是在isc_socketmgr_create2中的
if (isc_thread_create(watcher, manager, &manager->watcher) !=ISC_R_SUCCESS)中起的线程;process_fds执行到最后就是isc_task_send(ev->ev_sender, (isc_event_t **)&iev);这个函数执行完就会转到下面的run线程函数中。process_fd是具体的业务处理,process_ctlfd这个函数虽然不起眼但是很重要,在这个函数中有 wakeup_socket,里面最重要的就是result = watch_fd(manager, fd, msg);,在watch_fd中,关键代码就是epoll_ctl(manager->epoll_fd, EPOLL_CTL_ADD, fd, &event),这里重新注册时间,然后epool_wait再等待,而后再处理,如此反复。
result = isc_taskmgr_create(ns_g_mctx, ns_g_cpus, 0, &ns_g_taskmgr),#define isc_taskmgr_create isc__taskmgr_create,所以这里实际调用的是isc__taskmgr_create,这个函数里if (isc_thread_create(run, manager,&manager->threads[manager->workers])这里启动run线程函数,run主要执行的代码就是dispatch(manager),dispath主要执行的是(event->ev_action)( (isc_task_t *)task,event);ev->ev_action其实就是个函数指针;从这里可以看出,bind的处理模式和windows的消息处理机制很相似。
bind的epoll采用的是ET模式,边沿触发;只对新到的数据进行通知,而内核缓冲区中如果是旧数据则不进行通知,每次epoll_wait后,处理完毕后再调用epoll_ctl;这里实际是个循环处理过程,epoll_wait等待,然后加入到events数组中,然后处理,在调用cpoll_ctrl重新设置事件类型,再等待,如此循环。在bind中,sokcet.c中的线程函数watcher中有epooll_wait函数,在启动这个线程函数前在setup_watcher(isc_mem_t *mctx, isc__socketmgr_t *manager) 这个函数中已经调用了epoll_create。
转自:http://www.cppblog.com/zhangyq/archive/2011/03/10/141530.html
- bind源码解析(二)
- bind源码解析(二)
- bind源码解析(一)
- bind源码解析
- bind函数源码解析
- bind源码解析(一)
- bind源码解析(socket,thread)
- TFS源码解析二
- Volley源码解析(二)
- EventBus源码解析二
- springIOC源码解析(二)
- ThreadLocal源码解析(二)
- Retrofit源码解析(二)
- Volley源码解析(二)
- cinderclient源码解析之二
- AFNetworking2.0源码解析<二>
- AFNetworking2.0源码解析<二>
- AFNetworking2.0源码解析<二>
- 通过绝对路径删除某文件外其他文件
- 线程间同步机制的总结
- Unity--Pdf文件转图片
- HDOJ1175连连看
- Java序列化与反序列化
- bind源码解析(二)
- String和基本数据类型的比较方式
- Python图形用户界面-Tkinter
- 普元 EOS Platform 7.6 自行封装的webservice服务,报错
- POJ
- Dwarf tower
- caffe2 ubuntu16.04 安装错误 cannot find -lopencv_dep_cudart
- Gulp常用插件实践
- Junit4使用