IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> 什么是 swoole channel? -> 正文阅读

[PHP知识库]什么是 swoole channel?

channel?可以理解为消息队列,只不过是协程间的消息队列,多个协程通过?push?和?pop?操作生产消息和消费消息,用来协程之间的通讯。需要注意的是?channel?是没法跨进程的,只能一个?Swoole?进程里的协程间通讯,最典型的应用是连接池并发调用

<?php


/***
 *
 *
 *
 * 此功能请求对方接口,使用协程方法,比如说发送微信模板消息。php-fpm 模式下, 只能一个一个发送。遇到阻塞 就不能全部发送。
 *
 *
 * 使用swoole 就可以直接全部发送。节省时间
 */
use Swoole\Coroutine;
use Swoole\Coroutine\WaitGroup;
use Swoole\Coroutine\Http\Client;
use function Swoole\Coroutine\run;

echo 'start_at: '. date('Y-m-d H:i:s') ."\r\n";
run(function () {
    $wg = new WaitGroup();
    $result = [];
    //启动第一个协程
    $openids = [1,2,3,4,5,6,7,8,9,10];
    $params= [
        'openids'       => json_encode($openids),
        'push_content'  => 111,
        'url'           => 'https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=',
        'func'          => 'wx_push',
    ];
    $wg = new \Swoole\Coroutine\WaitGroup();
    $result = []; // 结果信息
    $result['start_at'] = microtime(true); // 记录开始时间
    $result['num'] = 0; // 记录推送数量
    switch ($params['func']) {
        case 'wx_push':
            // 数据验证
            if (!isset($params['openids']) || !$params['openids'] ||
                !isset($params['push_content']) || !$params['push_content'] ||
                !isset($params['url']) || !$params['url']
            ) {
                $result['params'] = $params;
                $result['err_msg'] = '参数异常!';
                break;
            }
            $url_arr = parse_url($params['url']); // 解析url
            $params['openids'] = is_array($params['openids']) ? $params['openids'] : json_decode($params['openids'], 1); // 推送的用户ID 列表
            $content = [];  // 推送的内容
            foreach ($params['openids'] as $k => $openid) {
                // 一次推送3000条,推送完成再推下一轮3000条
                if ($k > 0 && $k % 3 == 0) {
                    //挂起当前协程,等待所有任务完成后恢复
                    $wg->wait();
                }
                $wg->add();
                $result['num']++; // 记录推送数量
                //启动第一个协程
                go(function () use ($wg, &$result, $openid, $content, $url_arr,$k) {
                    $content['touser'] = $openid;
                    if (is_array($content)) {
                        $content = json_encode($content,JSON_UNESCAPED_UNICODE);
                    }
                    //启动一个协程客户端client,请求淘宝首页
                    $cli = new \Swoole\Coroutine\Http\Client('cy.huazhanhao.top', 82);
                    $cli->setHeaders([
                        //'Host' => 'api.weixin.qq.com',
                        'Host' => 'cy.huazhanhao.top',
                        'Content-Length' => strlen($content),
                        'Content-type' => 'application/x-www-form-urlencoded', //'application/x-www-form-urlencoded',
                    ]);
                    $cli->set(['timeout' => 6]); // 设置请求超时时长
                    // 拼接请求地址和参数
                    $cli->post('/redis_mq/curl.php', $content);
                    echo $cli->body . "\r\n";
                    echo "第".$k.'轮';
                    $result['body'][$openid] = $cli->body; // 获取返回结果信息
                    $cli->close();
                    $wg->done();
                });
            }
            break;
        case 'ali':
            break;
        default:
            $result['default'] = 'no function';
            break;
    }

    // 挂起当前协程,等待所有任务完成后恢复
    $wg->wait();
    $result['end_at'] = microtime(true); // 记录结束时间
    $result['use_time'] = $result['end_at'] - $result['start_at']; // 记录结束时间
    //这里 $result 包含了 2 个任务执行结果
    var_dump($result);
});

开启N个协程,每次执行N个数据包请求

  • add?方法增加计数
  • done?表示任务已完成
  • wait?等待所有任务完成恢复当前协程的执行
  • WaitGroup?对象可以复用,adddonewait?之后可以再次使用

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-08-07 11:46:44  更:2021-08-07 11:47:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/24 16:15:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码