数据库连接单例问题

我在laravel的command里使用了swoole协程,每个协程里会去连接数据库,希望每个协程的数据库连接是独立的连接,我查了Model和DB都是单例的,不知各位有没有解决办法?

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 4
xiaopi

试试这个 \Illuminate\Support\Facades\DB::disconnect();

2年前 评论
\Illuminate\Support\Facades\DB::purge();
2年前 评论

最后是用了swoole的连接池实现的,产线在用还挺稳定

    $size = 10;
    $pool = new \Swoole\Database\PDOPool((new \Swoole\Database\PDOConfig)
        ->withHost(config('database.connections.mysql.host'))
        ->withPort(config('database.connections.mysql.port'))
        // ->withUnixSocket('/tmp/mysql.sock')
        ->withDbName(config('database.connections.mysql.database'))
        ->withCharset(config('database.connections.mysql.charset'))
        ->withUsername(config('database.connections.mysql.username'))
        ->withPassword(config('database.connections.mysql.password'))
        ,$size);
    //填充连接
    $pool->fill();
    while(条件){
           go(function(){
                   $pdo = $pool->get();
                   // TODO
                  $pool->put($pdo);
           })
    }
2年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!