You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
42 lines
1.2 KiB
42 lines
1.2 KiB
2 months ago
|
<?php
|
||
|
include '../vendor/autoload.php';
|
||
|
|
||
|
use Smf\ConnectionPool\ConnectionPool;
|
||
|
use Smf\ConnectionPool\Connectors\CoroutinePostgreSQLConnector;
|
||
|
use Swoole\Coroutine\PostgreSQL;
|
||
|
|
||
|
go(function () {
|
||
|
// All PostgreSQL connections: [10, 30]
|
||
|
$pool = new ConnectionPool(
|
||
|
[
|
||
|
'minActive' => 10,
|
||
|
'maxActive' => 30,
|
||
|
'maxWaitTime' => 5,
|
||
|
'maxIdleTime' => 20,
|
||
|
'idleCheckInterval' => 10,
|
||
|
],
|
||
|
new CoroutinePostgreSQLConnector,
|
||
|
[
|
||
|
'connection_strings' => 'host=127.0.0.1 port=5432 dbname=postgres user=postgres password=xy123456',
|
||
|
]
|
||
|
);
|
||
|
echo "Initializing connection pool\n";
|
||
|
$pool->init();
|
||
|
defer(function () use ($pool) {
|
||
|
echo "Closing connection pool\n";
|
||
|
$pool->close();
|
||
|
});
|
||
|
|
||
|
echo "Borrowing the connection from pool\n";
|
||
|
/**@var PostgreSQL $connection */
|
||
|
$connection = $pool->borrow();
|
||
|
|
||
|
$result = $connection->query("SELECT * FROM pg_stat_database where datname='postgres';");
|
||
|
|
||
|
$stat = $connection->fetchAssoc($result);
|
||
|
echo "Return the connection to pool as soon as possible\n";
|
||
|
$pool->return($connection);
|
||
|
|
||
|
var_dump($stat);
|
||
|
});
|