swoole协程 是单线程的,还是多线程的

news2024/9/23 17:11:34

Swoole 协程本质上是单线程的,但它可以在多个线程中运行。因此,Swoole 协程既可以看作是单线程的,也可以在多线程的环境下运行,这取决于你如何使用 Swoole。

理解 Swoole 协程的运行模式

1 单线程中的协程

  • 在一个单独的线程中,Swoole 协程是单线程的。协程本质上是在一个线程中通过让出控制权来实现并发的。因此,在一个线程内运行的所有协程都是并发执行的,而不是并行的。

  • 例如,如果你在一个线程中启动了多个协程,这些协程之间不会被多个CPU核心并行地执行,它们只是通过调度器在单个线程中轮流执行。

2 多线程中的协程

  • Swoole 支持在多个 Worker 进程或多个线程中运行。每个 Worker 进程或线程都可以独立运行自己的协程。这样你可以通过多个 Worker 进程或线程来充分利用多核 CPU 的优势,实现并行处理。

  • 每个 Worker 进程或线程都可以被视为一个“容器”,在这个容器内,所有协程依然是单线程执行的。但在多个 Worker 或线程之间,协程的执行是并行的。

例子

use Swoole\Coroutine;
use Swoole\Coroutine\Scheduler;

$scheduler = new Scheduler();

$scheduler->add(function () {
    Coroutine::create(function () {
        // 协程1,在一个线程中运行
        echo "Coroutine 1 Start\n";
        Coroutine::sleep(1);
        echo "Coroutine 1 End\n";
    });

    Coroutine::create(function () {
        // 协程2,同样在一个线程中运行
        echo "Coroutine 2 Start\n";
        Coroutine::sleep(2);
        echo "Coroutine 2 End\n";
    });
});

$scheduler->start();

在上面的例子中,两个协程在同一个线程中并发运行。虽然代码中有多个协程,但它们是在同一线程中通过协作式调度来运行的。

总的来说

  • 单线程:在每个 Worker 进程或线程中,Swoole 协程是单线程的。协程之间是通过协作式调度器来并发运行的,并且不会利用多个 CPU 核心进行并行执行。

  • 多线程/多进程:如果你使用 Swoole 的多进程或多线程模型,那么可以在多个进程或线程中运行多个协程。这时,从宏观上看,协程可以在多个 CPU 核心上并行运行。

在这里插入图片描述

彩虹括号 IDE插件体验激活码获取:点击领取

swoole协程的调度方式是什么

Swoole 协程的调度方式是协作式调度(Cooperative Scheduling)。在协作式调度中,协程的调度是由协程自身控制的,也就是说,协程必须显式地让出控制权才能切换到其他协程。这种调度方式与抢占式调度(如操作系统线程调度)不同,抢占式调度由操作系统内核来决定任务的切换时机,而协作式调度完全依赖于程序的主动行为。

协作式调度的特点

  1. 手动让出控制权:在协作式调度中,协程需要显式调用一些特定的函数来让出控制权,例如 Coroutine::sleep()Co::yield()Co::await() 等。这些函数会暂停当前协程的执行并让出控制权,使得调度器可以切换到其他协程继续执行。
  2. 不会强制打断:由于是协作式调度,Swoole 不会在协程运行中强制打断协程执行来切换任务。这意味着协程代码中如果没有调用让出控制权的操作,当前协程会一直运行下去,可能导致其他协程无法及时得到执行的机会。
  3. 轻量级调度:协作式调度的开销很小,因为它不涉及复杂的上下文切换。每个协程切换时只需要保存当前协程的栈和寄存器状态即可。这使得协程切换比传统的线程或进程切换快得多。

例子

以下是一个使用 Swoole 协程的示例,演示协程的调度:

php
复制代码
use Swoole\Coroutine;

Coroutine::create(function () {
    echo "Coroutine 1: Start\n";
    // 显式让出控制权,这里会切换到其他协程
    Coroutine::sleep(1);
    echo "Coroutine 1: End\n";
});

Coroutine::create(function () {
    echo "Coroutine 2: Start\n";
    // 显式让出控制权,这里会切换到其他协程
    Coroutine::sleep(2);
    echo "Coroutine 2: End\n";
});

echo "Main Process: Waiting...\n";

// 输出结果可能类似于:
// Main Process: Waiting...
// Coroutine 1: Start
// Coroutine 2: Start
// Coroutine 1: End
// Coroutine 2: End

在上面的示例中:

  • 协程 1 和协程 2 分别启动,并各自运行。
  • Coroutine::sleep(1)Coroutine::sleep(2) 是协程的让出控制权操作,这些操作会暂停当前协程的执行,使得调度器有机会切换到其他协程。
  • 由于协作式调度,不同协程之间可以相互协作,通过让出控制权实现并发执行。

调度器机制

Swoole 的协程调度器是一个事件驱动的调度器。它基于事件循环机制来管理和调度协程。协程的调度和切换是由 Swoole 内部的事件循环机制来处理的,当协程进行 I/O 操作(如网络请求、文件操作)或显式让出控制权时,调度器会挂起当前协程,并切换到下一个可以执行的协程。

总结:

Swoole 协程采用协作式调度,通过显式的控制权让出实现协程之间的切换,这使得协程切换非常轻量且高效。协作式调度在编写异步并发代码时更加直观和可控,适合处理 I/O 密集型任务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2126812.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

构建常态化安全防线:XDR的态势感知与自动化响应机制

当前,网络安全威胁日益复杂多变,企业正面临前所未有的严峻挑战。为有效应对这些挑战,态势感知与自动化响应机制在提升网络安全运营效率与防御效果中扮演着至关重要的角色。它们能够实时监测网络状态,智能分析潜在威胁,…

浏览器中的JavaScript核心BOM(浏览器对象模型)重点掌握对象之History对象的属性与方法

History对象是用来把网页浏览历史用类似栈的方式进行表示。 这定义听起来非常的抽象,其实History对象的作用就跟浏览器的前进和后退很像,我们来用几幅图来理解一下。首先我们先回顾一下浏览器的返回上一个页面 和 跳转到下一个页面 这两个功能。 就类似…

【计算机网络】网络通信中的端口号

文章目录 一、引入端口号二、端口号的作用三、端口号的确定 在TCP/IP协议中,传输层有两个重要的协议:TCP(传输控制协议)和UDP(用户数据报协议)。TCP用于提供可靠的数据传输,而UDP则适合用于广播…

labview对位项目

带角度对位 1、上下拍照对照 项目类型:模组、PACK入箱,以下以模组入箱为例 项目目标:机器人抓起模组,通过上相机定位箱体上的销钉,通过下相机定位模组上的端板孔,计算出旋转偏移量XYR,让模组上…

苹果能引领端侧AI大模型时代吗?

苹果能引领端侧AI时代吗? 这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】 北京时间9月10日凌晨,苹果正式发布了iPhone 16,这是苹果第一款真正意义上的 …

精品PPT | 离散制造行业智能工厂总体解决方案

一、建设背景 离散制造业,包括机械制造业、汽车制造业和家电制造业等,其生产过程涉及多个不连续的工序,产品通常由多个零件装配而成。这类行业面临的挑战包括品种多、批量小、订单变化快、临时插单频繁以及外协件管理困难等问题,…

相机光学(三十七)——自动对焦原理

1.自动对焦的三种方式 目前在手机上采用的自动对焦系统包括反差对焦、相位对焦和激光对焦三种方案,下面我们来看一下它们的工作原理和相互之间的区别是什么。 1.1反差对焦【CDAF】- Contrast Detection Auto Focus 反差对焦是目前普及率最高、使用最广泛、成本相对…

Leetcode 701-二叉搜索树中的插入操作

给定二叉搜索树(BST)的根节点 root 和要插入树中的值 value ,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据 保证 ,新值和原始二叉搜索树中的任意节点值都不同。 注意,可能存在多种有效的插入方式&a…

QT之QML学习五:添加自定义Qml组件

开发环境: 1、Qt 6.7.2 2、Pyside6 3、Python 3.11.4 4、Windows 10 重要的事情说三遍,使用自定义qml参考链接: Qt官网参考网址!!! 重要的事情说三遍,使用自定义qml参考链接: Qt官网参考网址!!! 重要的事情说三遍,使用自定义qml参考链接: Qt官网参考网址!!!…

2024年华为杯数学建模研赛 最全赛中助攻|选题建议+思路+代码+成品论文预定

2024年华为杯研究生数学建模竞赛(以下简研赛)将于9月21日上午8时正式开始。 下文包含:2024研赛思路解析​、研赛参赛时间及规则信息说明、好用的数模技巧及如何备战数学建模竞赛 C君将会第一时间发布选题建议、所有题目的思路解析、相关代码…

【2024】Benchmarking Foundation Models with Language-Model-as-an-Examiner

信息 阅读目的:李娟子老师团队,了解模型中的知识评测的工作 白雨时1*、嘉豪英2*、曹义心2、吕新1、何玉泽1, 王笑之1 、于吉凡1 、曾凯生1 、小易佳3 , Haozhe Lyu 4张嘉荫1李娟子1 , Lei Hou 1 凶 1清华大学,北京,中国2新…

AI菜鸟向前飞 — LangGraph系列之一:深入浅出解读Graph(一)

前言 LangGraph是一个使用 LLM 和 LangChain 构建有状态多参与者应用程序的库。 LangChain 允许您使用 LCEL(LangChain 表达式语言)构建链 AI菜鸟向前飞 — LangChain系列之六 - 深入浅出LCEL与Chain(上篇) AI菜鸟向前飞 — LangChain系列之七 - 深入…

ALIENTEK电容按键按键的介绍与驱动代码

目录 前言 电容触摸按键原理 硬件接线 检测电容触摸按键过程 驱动代码 tpad.h tpad.c main.c 按键扫描函数 前言 我没有独立的电容触摸按键模块,所以使用正点原子STM32F103ZET6精英版开发板上的电容触摸按键。采用STM32F103C8T6检测电容触摸按键&#…

WEB渗透权限维持篇-隐藏windows服务

往期文章WEB渗透权限维持篇-DLL注入\劫持-CSDN博客 WEB渗透权限维持篇-CLR-Injection-CSDN博客 WEB渗透权限维持篇-计划任务-CSDN博客 WEB渗透权限维持篇-DLL注入-修改内存中的PE头-CSDN博客 WEB渗透权限维持篇-DLL注入-进程挖空(MitreT1055.012)-CSDN博客 WEB渗透权限维持…

mysql设置数据库隔离级别及各个隔离级别的作用

一、通过命令设置隔离级别 # 设置全局隔离级别 set global transaction isolation level REPEATABLE READ; set global transaction isolation level READ COMMITTED; set global transaction isolation level READ UNCOMMITTED; set global transaction isolation level SE…

Reduce:一款开源的短网址平台!!【送源码】

今天给大家介绍一款开源的短网址平台,Coody Framework首秀,自写IOC、MVC、ORM、TASK、JSON、DB连接池、服务器。百毫秒启动,全项目仅2.5M(低配服可运行)。 前端采用Amaze UI,后端采用Coody Framework MVC&…

NGINX开启HTTP3,给web应用提个速

环境说明 linuxdockernginx版本:1.27 HTTP3/QUIC介绍 HTTP3是由IETF于2022年发布的一个标准,文档地址为:https://datatracker.ietf.org/doc/html/rfc9114 如rfc9114所述,http3主要基于QUIC协议实现,在具备高性能的同时又兼备了…

模拟面试后端开发复盘

目录 一:项目的系统开发和设计思路 二:Java的反射是什么?在项目中有用到吗? 三:多态的实现原理 四:项目中的redis是用在了哪里 五:Session和Cookie的区别,Cookie可以被修改吗&a…

socket通讯原理及例程(详解)

里面有疑问或者不正确的地方可以给我留言。 对TCP/IP、UDP、Socket编程这些词你不会很陌生吧?随着网络技术的发展,这些词充斥着我们的耳朵。那么我想问: 什么是TCP/IP、UDP?Socket在哪里呢?Socket是什么呢&#xff1…

又一款强大好用的Shell脚本项目,支持Bash,Sh、Dash、Ksh等,甚至可以在编辑器中直接用,程序员必备!(附源码)

作为一个程序员,肯定经常都要和shell脚本打交道,Shell脚本可以帮我们自动化各种任务,但也经常有格式错误、拼写错误、逻辑错误等等麻烦,而且它不会告诉你错在哪里! 今天就给大家分享一个超级实用的开源项目 - ShellCh…