新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
本篇文章为大家展示了Swoole中如何理解进程和事件IO,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
为通海等地区用户提供了全套网页设计制作服务,及通海网站建设行业解决方案。主营业务为成都网站制作、成都做网站、外贸营销网站建设、通海网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!1.文件锁
子进程回复制父进程的IO句柄,但是不能让所有的子进程同时对同一个文件进行操作,所以需要文件锁。
2.进程间的通讯方式--管道
管道是一组(2个)特殊的描述符
管道需要在fork函数调用前创建
如果某一段主动关闭管道,另一端读取操作会直接返回0,之后会关闭管道
在父进程中创建管道的时候,父进程会创建一组描述符;子进程在进行复制父进程时,会复制这一组描述符。
3.进程间的通讯方式--消息队列
使用消息队列比流式管道的好处是,假如某一端服务挂了,但是因为消息还在队列中,所以数据不会丢失
消息队列的通讯方式很像共享内存
可以通过指定key创建一个消息队列
在消息队列中传递的数据大小有限制 默认65535k
消息队列会一直保留到被主动关闭
4.IO多路复用
epoll会监听注册再在自己名下所有的socket描述符
当有socket感兴趣的时间发生时,epoll函数才会响应,并返回有时间发生的socket集合
epoll的本事是阻塞IO,优点是能够处理大量的socket集合
5.Event Loop简介
Event loop是一个Reactor线程,其中运行了一个epoll实例
可通过接口添加到socket描述符的epoll监听中,并制定时间响应的回调函数
因为Event loop是单独线程,不能用于fpm的环境下。因为fpm是新起的进程,事件完毕后有可能被关闭,此时scoket便不能被监听了。
开启Event loop后,程序会启动一个线程并一直阻塞在epoll的监听上,开启了Event loop后,程序会一直运行不停止,这也是swoole开发者的本意。终止的方法是调用swoole_event_exit函数。
6.swoole进程
swoole process包含三个部分:管道,内存和IO句柄
swoole process有以下的几个优点:
是基于C语言封装的管理模块,方便PHP多进程编程;
内置管道、消息队列接口,方便实现进程间的通信;
提供自定义信号管理
上述内容就是Swoole中如何理解进程和事件IO,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。