swoole 学习笔记-做一顿饭来理解协程

简介

最近学习 swoole 接触到协程,记录一下我理解到的协程。

文章比较白话,而且目前理解的还非常浅,写出自己的想法,请大佬们多多指点。

 

协程

协程可以简单理解为线程,只不过这个线程是用户态的,不需要操作系统参与,创建销毁和切换的成本非常低,和线程不同的是协程没法利用多核 cpu 的,想利用多核 cpu 需要依赖 Swoole 的多进程模型。—— swoole 协程一章

 

我的理解

可以把协程看成一道小学数学的一道题目:“合理安排时间”,来我们先做一道题目:

 

小明下班后回家煮饭,煲汤需要 10 分钟,煮饭需要 8 分钟, 炒菜需要 5 分钟,,请问小明最少需要多少分钟能煮好饭?

 

下面用 sleep() 模拟 IO 操作

 

同步版煮饭

public function sync()

    {

        $startTime = time();

 

        echo "开始煲汤..." . PHP_EOL;

        sleep(10);

        echo "汤好了..." . PHP_EOL;

 

        echo "开始煮饭..." . PHP_EOL;

        sleep(8);

        echo "饭熟了..." . PHP_EOL;

 

        echo "放油..." . PHP_EOL;

        sleep(1);

        echo "煎鱼..." . PHP_EOL;

        sleep(3);

        echo "放盐..." . PHP_EOL;

        sleep(1);

        echo "出锅..." . PHP_EOL;

 

        var_dump('总耗时:' . (time() - $startTime) . ' 分钟');

    }

总耗时:23 分钟

 

代码很容易看懂,等待汤煮好之后再煮饭,然后再等待饭煮好再炒菜,生活中不会这样操作吧?这就要引入协程来解决这个问题了。

 

协程版煮饭

<?php

namespace Study\Co;

 

use Swoole\Coroutine;

use Swoole\Coroutine\WaitGroup;

use Swoole;

 

class co

{

    public function cookByCo()

    {

        $startTime = time();

 

        // 开启一键协程化: https://wiki.swoole.com/#/runtime?id=swoole_hook_all

        Swoole\Runtime::enableCoroutine($flags = SWOOLE_HOOK_ALL);

 

        // 创建一个协程容器: https://wiki.swoole.com/#/coroutine/scheduler

        // 相当于进入厨房

        \Co\run(function () {

            // 等待结果: https://wiki.swoole.com/#/coroutine/wait_group?id=waitgroup

            // 记录哪道菜做好了,哪道菜还需要多长时间

            $wg = new WaitGroup();

            // 保存数据的结果

            // 装好的菜

            $result = [];

 

            // 记录一下煲汤(记录一个任务)

            $wg->add();

            // 创建一个煲汤任务(开启一个新的协程)

            Coroutine::create(function () use ($wg, &$result) {

                echo "开始煲汤..." . PHP_EOL;

                // 煲汤需要6分钟,所以我们也不用在这里等汤煮好,

                // 直接去做下一个任务:炒菜(协程切换)

                sleep(8);

                echo "汤好了..." . PHP_EOL;

 

                // 装盘

                $result['soup'] = '一锅汤';

                $wg->done(); // 标记任务完成

            });

 

            // 记录一下煮饭(记录一个任务)

            $wg->add();

            // 创建一个煮饭任务(开启一个新的协程)

            Coroutine::create(function () use ($wg, &$result) {

                echo "开始煮饭..." . PHP_EOL;

                // 煮饭需要5分钟,所以我们不用在这里等饭煮熟,放在这里一会再来看看好了没有

                // 我们先去煲汤(协程切换)

                sleep(10);

                echo "饭熟了..." . PHP_EOL;

 

                // 装盘

                $result['rice'] = '一锅米饭';

                $wg->done(); // 标记任务完成

            });

 

            // 记录一下炒菜

            $wg->add();

            // 创建一个炒菜任务(再开启一个新的协程)

            Coroutine::create(function () use ($wg, &$result) {

                // 煎鱼的过程必须放在一个协程里面执行,如果不是的话可能鱼还没煎好就出锅了

                // 因为开启协程后,IO全是异步了,在此demo中每次遇到sleep都会挂起当前协程

                // 切换到下一个协程执行。

                // 例如把出锅这一步开启一个新协程执行,则在煎鱼的时候鱼,鱼就出锅了。

                echo "放油..." . PHP_EOL;

                sleep(1);

                echo "煎鱼..." . PHP_EOL;

                sleep(3);

                echo "放盐..." . PHP_EOL;

                sleep(1);

                echo "出锅..." . PHP_EOL;

 

                // 装盘

                $result['food'] = '鱼香肉丝';

                $wg->done();

            });

 

            // 等待全部任务完成

            $wg->wait();

 

            // 返回数据(上菜!)

            var_dump($result);

        });

 

        var_dump('总耗时:' . (time() - $startTime) . ' 分钟');

    }

}

总耗时:10 分钟

 

 

已标记关键词 清除标记
简介: 历经半个多月的时间,Debug亲自撸的 “企业员工角色权限管理平台” 终于完成了。正如字面意思,本课讲解的是一个真正意义上的、企业级的项目实战,主要介绍了企业级应用系统中后端应用权限的管理,其中主要涵盖了六大核心业务模块、十几张数据库表。 其中的核心业务模块主要包括用户模块、部门模块、岗位模块、角色模块、菜单模块和系统日志模块;与此同时,Debug还亲自撸了额外的附属模块,包括字典管理模块、商品分类模块以及考勤管理模块等等,主要是为了更好地巩固相应的技术栈以及企业应用系统业务模块的开发流! 核心技术栈列表: 值得介绍的是,本课在技术栈层面涵盖了前端和后端的大部分常用技术,包括Spring Boot、Spring MVC、Mybatis、Mybatis-Plus、Shiro(身份认证与资源授权跟会话等等)、Spring AOP、防止XSS攻击、防止SQL注入攻击、过滤器Filter、验证码Kaptcha、热部署插件Devtools、POI、Vue、LayUI、ElementUI、JQuery、HTML、Bootstrap、Freemarker、一键打包部署运行工具Wagon等等,如下图所示: 课内容与收益: 总的来说,本课是一门具有很强实践性质的“项目实战”课,即“企业应用员工角色权限管理平台”,主要介绍了当前企业级应用系统中员工、部门、岗位、角色、权限、菜单以及其他实体模块的管理;其中,还重点讲解了如何基于Shiro的资源授权实现员工-角色-操作权限、员工-角色-数据权限的管理;在课的最后,还介绍了如何实现一键打包上传部署运行项目等等。如下图所示为本权限管理平台的数据库设计图: 以下为项目整体的运行效果截图: 值得一提的是,在本课中,Debug也向各位小伙伴介绍了如何在企业级应用系统业务模块的开发中,前端到后端再到数据库,最后再到服务器的上线部署运行等流,如下图所示:
限时福利1:原价 129 元,最后2天仅需 69 元!后天涨价至98元 限时福利2:购课进答疑群专享柳峰(刘运强)老师答疑服务 限时福利3:购课添加助教领取价值 800 元的编大礼包 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是序员的必备技能,也是衡量一个序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课设计】 课分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合序员面试高频MySQL问题精讲精练,帮助序员吊打面试官,获得心仪的工作机会。
©️2020 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页