swoole简单实现并发处理数据

来源:赵克立博客 分类: PHP 标签:Swoole发布时间:2021-11-22 14:49:48最后更新:2022-04-23 16:08:36浏览:246
版权声明:
本文为博主原创文章,转载请声明原文链接...谢谢。o_0。
更新时间:
2022-04-23 16:08:36
温馨提示:
学无止境,技术类文章有它的时效性,请留意文章更新时间,如发现内容有误请留言指出,防止别人"踩坑",我会及时更新文章
<?php

use mokuyu\Cache;
use Swoole\Coroutine;
use function Swoole\Coroutine\run;
use model\Company;

$loader      = require __DIR__ . '/vendor/autoload.php';
$dbConfig    = require_once __DIR__ . '/config.php';
$redisConfig = require_once __DIR__ . '/redis.php';
$max         = 50;
$dbQueue     = [];
for ($i = 0; $i <= $max; $i++) {
    $dbConfig['uuid'] = 'connection' . $i;
    $obj              = new Company($dbConfig);
    $obj->setCache(new Cache($redisConfig));
    $dbQueue[] = $obj;
}

run(function () use (&$dbQueue, $max) {
    while (true) {
        Swoole\Coroutine::sleep(1);
        if (!$dbQueue) {
            echo 'not connection!', PHP_EOL;
            continue;
        }
        $mod   = array_pop($dbQueue);
        $datas = $mod->where('is_parse_address', 0)
            ->limit($max)
            ->order('id asc')
            ->select();
        array_push($dbQueue, $mod);
        if (!$datas) {
            echo 'end!', PHP_EOL;
            break;
        }

        foreach ($datas as $data) {
            if (!$dbQueue) {
                continue;
            }
            $temCon = array_pop($dbQueue);
            Coroutine::create(function () use ($temCon, $data, &$dbQueue) {
                $updateData = [];
                $failData   = [];
                // $dbConfig['uuid'] = 'connection' . $key;
                // $mod              = new Company($dbConfig);
                $temCon->updateAddress($data, $updateData, $failData);
                if ($updateData) {
                    $res = $temCon->save($updateData);
                    echo date('Y-m-d H:i:s '), $res ? 'success' : 'fail', ': Update: ', count($updateData), ', latest Id: ', end($updateData)['id'], PHP_EOL;
                }
                if ($failData) {
                    $res = $temCon->save($failData);
                    echo date('Y-m-d H:i:s '), $res ? 'success' : 'fail', ': Skip: ', count($failData), ', latest Id: ', end($failData)['id'], PHP_EOL;
                }
                array_push($dbQueue, $temCon);
            });
        }
    }
});
echo 1;//可以得到执行



微信号:kelicom QQ群:215861553 紧急求助须知
Win32/PHP/JS/Android/Python