在Swoole官网的自我介绍是“面向生产环境的PHP异步网络通信引擎”,首先Swoole它是一个网络应用的开发工具,它支持Http、TCP、UDP、WebSocket。

Swoole和我们传统的PHP开发差别是有的,需要理解的概念也是有的。使用目前一些基于Swoole的框架开发的话,从开发习惯上和传统的TP、LV框架相差不多。

那为什么要使用Swoole?

有以下几点:

常驻内存,避免重复加载带来的性能损耗,提升海量性能
协程异步,提高对I/O密集型场景并发处理能力(如:微信开发、支付、登录等)
方便地开发Http、WebSocket、TCP、UDP等应用,可以与硬件通信
PHP高性能微服务架构成为现实

常驻内存

目前传统PHP框架,在处理每个请求之前,都要做一遍加载框架文件、配置的操作。这可能已经成为性能问题的一大原因,而使用Swoole则没有这个问题,一次加载多次使用。

协程

说到协程,就得先简单说说进程和线程,众所周知进程是很占用资源的,为了处理请求大量创建进程肯定是得不偿失的。而多线程应用就比较多了,在CPU层面有几个核心就会执行几个任务,线程一旦创建的多了,就会有线程调度的损耗。

协程是在单线程基础上实现的,它可以最大限度利用CPU资源,而不会在等待I/O时白白浪费。当然,协程数越多占用的内存也就越多,不过这个是可以接受的,相比进程和线程,占用的资源是相对较少的。

使用协程时,遇到读写文件、请求接口等场景,会自动挂起协程,把CPU让给其它协程执行任务,这样可以提升单线程的CPU资源利用率,减少浪费,从而提高性能。

微服务

Tars是腾讯从2008年到今天一直在使用的后台逻辑层的统一应用框架TAF(TotalApplicationFramework),目前支持C++,Java,PHP,Nodejs语言。该框架为用户提供了涉及到开发、运维、以及测试的一整套解决方案,帮助一个产品或者服务快速开发、部署、测试、上线。它集可扩展协议编解码、高性能RPC通信框架、名字路由与发现、发布监控、日志统计、配置管理等于一体,通过它可以快速用微服务的方式构建自己的稳定可靠的分布式应用,并实现完整有效的服务治理。