当前位置: 首页 > news >正文

PHP 界的扛把子 Swoole 异步通信利器

大家好,我是码农先森。

引言

我今天主要介绍的内容是包括但不仅限于 Swoole ,也有一部分 Go 语言的内容。

为什么要介绍 Swoole ?

先说一说背景吧,我们项目组之前要为《香港 01》开发一个积分系统的项目,这个系统的主要功能包括:会员积分的存储、积分的交易、积分的发放、积分的核销。当时我们项目组的架构师,首先考虑的技术选项是 Go 语言。但是,由于公司的技术栈主要是为 PHP,所以 CTO 在技术选项的审核时,就限定为 PHP 了。之后我们项目组的架构师,就不得已而为之,开始在 PHP 的领域考虑选择 Swoole 异步通信框架。刚开始时还调研了 Laravel-Swoole,因为它需要加载的依赖太多了,会影响程序的运行性能,所以放弃了。最后,还是敲定使用 Swoole 的原生框架。

届于我之前使用 Swoole 进行过一定的开发,所以把我对 Swoole 的了解及开发经验分享给大家,如果有那个地方讲的不好或者有什么问题,你们可以随时打断补充说明。

进程、线程、协程

在介绍 Swoole 之前,还是有必要先介绍一下进程、线程、协程的概念。因为在我们平常的 PHP 编程中,接触这几个概念会比较的少。当然如果对 PHP-FPM 比较熟悉的同学,对进程的概念也会比较的清楚。话不多说,我还是先介绍一下概念吧。

  • 进程是什么?

进程就是应用程序的启动实例。例如:打开一个软件,就是开启了一个进程。进程拥有代码和打开的文件资源,数据资源,独立的内存空间。

  • 线程是什么?

线程属于进程,是程序的执行者。一个进程至少包含一个主线程,也可以有更多的子线程。线程有两种调度策略,一是:分时调度,二是:抢占式调度。

  • 协程是什么?

协程是轻量级线程,协程的创建、切换、挂起、销毁全部为内存操作,消耗是非常低的。协程是属于线程,协程是在线程里执行的。协程的调度是用户手动切换的,所以又叫用户空间线程。协程的调度策略是:协作式调度。

PHP-FPM 与 Swoole 的运行流程

  • PHP-FPM 运行流程图

  • Swoole 运行流程图

  • php-fpm 优缺点

优点:
部署起来简单快捷、调试代码方便、支持平滑重启服务。

缺点:
一次 Http 请求需要加载所有的依赖文件、并发性能不佳。

  • swoole 优缺点

优点:
支持毫秒级的定时器、高性能异步网络通信、常用进程模式。

缺点:
默认不支持平滑重启服务、不支持手动 dump 调试。

Swoole 介绍

  • 这里引用一下官方的定义

Swoole 是一个 PHP 的协程高性能网络通信引擎,使用 C/C++ 语言编写,提供了多种通信协议的网络服务器和客户端模块。可以方便快速的实现 TCP/UDP服务、高性能Web、WebSocket服务、物联网、实时通讯、游戏、微服务等,使 PHP 不再局限于传统的 Web 领域。

  • Swoole 类图

Swoole 协程使用示例及详解

实战问题案例分析

在我们的积分发放系统中,使用到了 mongodb 存储,但是 swoole 没有提供 mongodb 协程客户端。 那么这种场景下,在连接及操作 Mongodb 时会发生同步阻塞,无法发生协程切换,导致整个进程都会阻塞。在这段时间内,进程将无法再处理新的请求,这使得系统的并发性大大降低。

使用同步的 mongodb 客户端

通过使用 Server->taskCo 来异步化对 mongodb 的操作

总结

今天我主要是介绍了 PHP-FPM 和 Swoole 的内部运行流程及 Swoole 协程的使用方法,Swoole 的应用场景还非常广泛。我经常听到网上有人说,PHP 快凉凉了。其实 Swoole 的出现又让 PHP 出现了新的生机。


欢迎关注、分享、点赞、收藏、在看,我是微信公众号「码农先森」作者。

http://www.lryc.cn/news/384336.html

相关文章:

  • 40.连接假死-空闲检测-发送心跳
  • hdfs高可用文件系统架构
  • 从官方源码精简出第1个FreeRTOS程序
  • 谷歌上搞下来的,无需付费,可以收藏!
  • 宿主机无法通过ip连接wsl2解决方案
  • Ruby编程语言学习
  • Redis实战—基于setnx的分布式锁与Redisson
  • ARM功耗管理框架之LPI
  • Unity太空避障Demo总结
  • SpringSecurity-重写默认配置
  • C# 判断值是否在枚举里
  • Interview preparation--elasticSearch倒排索引原理
  • 银河麒麟高级服务器操作系统V10SP2(X86)配置bond0的mac地址为指定子网卡的mac地址
  • python中不同维度的Tensor向量为何可以直接相加——广播机制
  • 38.MessageToMessageCodec线程安全可被共享Handler
  • Linux中的全局环境变量和局部环境变量
  • 【研究】AI大模型需要什么样的硬件?
  • 人工智能--自然语言处理NLP概述
  • 基于Java微信小程序火锅店点餐系统设计和实现(源码+LW+调试文档+讲解等)
  • SpringCloud_GateWay服务网关
  • 使用Dropout大幅优化PyTorch模型,实现图像识别
  • Vue3中的常见组件通信(超详细版)
  • Stm32的DMA的学习
  • 应用安全(补充)
  • 鸿蒙开发Ability Kit(程序框架服务):【FA模型切换Stage模型指导】 app和deviceConfig的切换
  • 通过命令行配置调整KVM的虚拟网络
  • Apache POI操作excel
  • Python错误集锦:faker模块生成xml文件时提示:`xml` requires the `xmltodict` Python library
  • Vue3-尚硅谷笔记
  • RockChip Android12 System之MultipleUsers