初识Swoole

Swoole官网https://www.swoole.com/

Swoole官方文档:https://wiki.swoole.com/       

版本
已更新至4.3.x。swoole2.0增加协程。swoole3.0以上版本要求php>=7.0。

开发辅助工具

Swoole 4.X速查表:https://toxmc.github.io/swoole-cs.github.io/

ide提示工具:https://github.com/swoole/ide-helper

这2个工具挺实用的,截图如下:

 

IDE helper包下载后放进任意目录,然后IDE include path即可。

å¨è¿éæå¥å¾çæè¿°

Swoole入门指引

å¨è¿éæå¥å¾çæè¿°

swoole底层是C写的。swoole系列函数可以理解为swoole提供给php的api,php通过swoole系列函数调用swoole的api,来启动swoole服务、注册回调函数等,swoole的事件驱动来执行对应的回调函数。这完全区别于普通的php扩展只提供库函数,而对于swoole,php只是传递的作用,真正的程序控制权是swoole。

学习swoole的基础知识

linux是必须的。学习swoole需要对进程、线程、异步同步、IO复用、reactor模型、进程间通讯、信号等概念有所了解,可学习《tcp/ip网络编程》这本书做简单的理解,通过php对应的扩展,借鉴workman源码来理解机制,这样会对swoole的学习有很大帮助。

swoole并没有用libevent,所以不需要安装libevent。swoole并不依赖php的stream/sockets/pcntl/posix/sysvmsg等扩展

libevent是一个事件驱动库,php有对应的event扩展,可帮助理解swoole的io复用和事件机制。
stream/sockets是网络通讯的工具、可帮助理解swoole的tcp/udp/http。
pcntl/posix是进程控制扩展,可帮助理解swoole中的多进程、进程间通讯。
sysvmsg消息队列,可帮助理解swoole中的task模块。

 

Swoole提供的功能库

swoole提供了哪些功能给我们用,以为我们用到哪些服务时,可以用swoole来帮我们实现。

  • http服务 ,编写一个简单的web server。
  • TCP/UDP服务 ,编写一个消息接受处理系统。
  • 异步,可以异步的处理请求。
  • 并发 ,可以并发的处理同一个业务逻辑。
  • socket,socket通讯处理技术。
  • 毫秒级别定时器,可以在php中使用定时器了。
  • 协程,相比线程更稳定和好用。

     如果你的业务中,有用到以上等特性,你又在用使用php,那么完全可以用swoole来完成了,再具体点的场景如下:

    1、互联网;    2、移动通信;   3、企业软件;   4、云计算;   5、网络游戏;   6、物联网(IOT);   7、车联网;   8、智能家居等领域

 

Swoole的框架

       Swoft 首个基于 Swoole 原生协程的新时代 PHP 高性能协程全栈框架,内置协程网络服务器及常用的协程客户端,常驻内存,不依赖传统的 PHP-FPM,全异步非阻塞 IO 实现,以类似于同步客户端的写法实现异步客户端的使用,没有复杂的异步回调,没有繁琐的 yield, 有类似 Go 语言的协程、灵活的注解、强大的全局依赖注入容器、完善的服务治理、灵活强大的 AOP、标准的 PSR 规范实现等等,可以用于构建高性能的Web系统、API、中间件、基础服务等等。

        EasySwoole EasySwoole 是一款基于Swoole Server 开发的常驻内存型PHP框架,专为API而生,摆脱传统PHP运行模式在进程唤起和文件加载上带来的性能损失。EasySwoole 高度封装了Swoole Server 而依旧维持Swoole Server 原有特性,支持同时混合监听HTTP、自定义TCP、UDP协议,让开发者以最低的学习成本和精力编写出多进程,可异步,高可用的应用服务。

       SwooleDistributed SwooleDistributed 老牌Swoole框架拥有最完善的开发工具以及最强大的功能,首创SDHelper开发者工具包和开发者调试命令集,可以进行单元测试,捕获客户端流量分析,可视化的进行远程断点联调,还具备代码覆盖率检测的功能(swoole与xdebug扩展不兼容,SDHelper无需xdebug扩展),并且内置组件极其丰富(类MQTT强悍的订阅发布/Actor模型/内存高速缓存/事件派发/进程管理/定时任务/AMQP任务调度/后台监控/集群/微服务/RPC/异步连接池/自定义命令等等),开发者可以直接使用加快开发进度。几乎所有的功能都支持集群化,单机切换到集群无需对代码做任何的修改。如果业务开发比较复杂比如(游戏开发)那么SD框架将是你的不二之选。

swoole进程结构

  • Master主进程
  • manager管理进程
  • worker子进程
  • task任务进程
  • MainReactor主线程
  • reactor线程组

Swoole的进程/线程模型

Swoole程序的执行流程