rayswoole / memcache-pool
基于swoole + easyswoole/memcache实现的memcache连接池
v1.0.0
2020-09-07 08:39 UTC
Requires
- php: >=7.1.0
- ext-swoole: >=4.4.4
- easyswoole/memcache: ^1.0
This package is auto-updated.
Last update: 2024-11-07 18:03:02 UTC
README
基于PHP7.1+ 和 easyswoole/memcache协程连接,实现的memcache连接池:
- 直接使用TCP协议连接, 不依赖memcached扩展
- 实现了memcache的连接池, 减少频繁建立连接的开销
- 仅支持单机模式
- 支持自动保持连接
- 支持保持最小空闲连接数量, 满足突发连接
- 弹性伸缩
安装
composer require rayswoole/memcache-pool
文档
连接池配置
可以在onStart直接配置
每个worker进程都会生成同等配置的进程池, 请根据worker数量动态调整
//初始化连接配置 $redisConfig = new \rayswoole\memcache\MemcacheConfig(); //设置最小闲置连接数 $redisConfig->withMin(20); //设置最大连接数 $redisConfig->withMax(100); //设置定时器执行频率(毫秒),创建最小空间连接、回收空闲连接 $redisConfig->withIntervalTime(15*1000); //设置连接可空闲时间 $redisConfig->withIdleTime(30); //获取连接池对象超时时间, 如果连接池占满在指定时间无法释放新的连接, 将输出Exception, 需要自行捕获 $redisConfig->withTimeout(3.0); //数据库配置注入 $redisConfig->withExtraConf('memcache配置'); //初始化连接池 \rayswoole\memcache\facade\Memcache::init($redisConfig);
redis 配置结构
$config = [ 'server' => '127.0.0.1', 'port' => 11211, ];
进程池使用示例
use rayswoole\memcache\facade\Memcache; Memcache::getInstance()->set('aa',1234); Memcache::getInstance()->get('aa'); Memcache::getInstance()->clear();
不通过连接池直连
$config = [ 'server' => '127.0.0.1', 'port' => 11211, ]; $memcache = \rayswoole\memcache\MemcacheClient::get($config); $memcache->set('aa',1234);