数据库连接单例问题

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

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 4
xiaopi

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

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

最后是用了 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);
           })
    }
3年前 评论