docker 基本命令
今天介绍一些docker基本命令,自己最近在学习。docker安装就不介绍了,接下来介绍一些docker常用命令
目前很著名的轮子有libevent,boost等高并发的网络库,可以说著名的网络库我都用过,用过才知道当要实现一些定制化的功能时并不方便,不但要了解底层源码,而且还要进行适当的改造,总有种黑盒开发的感觉,所以在15年我就开始自己封装一些epoll,select模型,当时基于多路复用用reactor模式封装了betternet,虽然稳定性不如成熟的网络库,但是可以根据需求灵活修改网络层和应用层,这是难能可贵的。市面上也有一些成型的即时通信server,使用过kbengine,origine等集成度较高的server,当要实现一些心跳,逻辑检测,连接管理等需求时,还是要修改底层的源码,感觉很糟糕。18年接触golang,net包里封装的网络模型和协程管理,很完善的调度策略让我眼前一亮,所以考虑能不能基于golang的官方net包做一些框架上的设计,搭建一个高可用的网络服务。19年基于net包实现了wentby这个服务器,并发和稳定性都不错,最近又翻看了原来的代码,觉得很多地方可以精简一下,而且不想为了兼容别人的开发习惯降低服务器的效率,也不想增加复杂度,所以干脆做一个精简的server给自己用,只要他稳定高效就可以了,线程安全这种问题交由开发者考虑。读了redis网络服务那块也就500行,简约而不简单。
接上文我们查看了bind和listen流程,直到了listen操作会在内核初始化一个epoll表,并将listen的描述符加入到epoll表中
前文我们看到pollDesc的init函数中调用了runtime的pollOpen函数完成的epoll创建和描述符加入,这里再贴一次代码
1 | func (pd *pollDesc) init(fd *FD) error { |
runtime_pollServerInit link的是runtime/netpoll.go中的poll_runtime_pollServerInit函数
由于serverInit是sync.Once类型,所以runtime_pollServerInit只被初始化一次,而epoll模型的初始化就是在该函数完成