本篇文章给大家带来了关于php+yac的相关知识,其中主要跟大家聊一聊怎么用Yac替换APCU memcache,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。
(资料图片)
yac 缓存
Yac 是用于 PHP 的共享和无锁内存用户数据缓存。它可以用来替换 APC 或本地 memcached。鸟哥出品必属精品
要求
PHP 7 +
Install
$/path/to/phpize$./configure --with-php-config=/path/to/php-config$make && make install
登录后复制
Note
Yac 是无锁缓存,您应该尽量避免或减少多个进程设置一个相同键的概率
Yac 使用部分 crc,您最好重新排列缓存内容,将最重要 (可变) 的字节放在头部或尾部
Restrictions
缓存 key 不能大于 48 (YAC_MAX_KEY_LEN) bytes
缓存内容不能大于 64M (YAC_MAX_VALUE_RAW_LEN) bytes
压缩后的缓存值不能大于 1M 1M (YAC_MAX_VALUE_COMPRESSED_LEN) bytes
ini 配置
yac.enable = 1yac.keys_memory_size = 4M ; 4M can get 30K key slots, 32M can get 100K key slotsyac.values_memory_size = 64Myac.compress_threshold = -1yac.enable_cli = 0 ; 是否使用cli启用yac,默认为0yac.serializer = php ; yac2.2.0以来,yac使用的特定seralizer json(-- enable-json) 、msgpack(-- enable-msgpack) 或igbinary(-- enable-igbinary)
登录后复制
常量
YAC_VERSIONYAC_MAX_KEY_LEN = 48 ; if your key is longer than this, maybe you can use md5 result as the keyYAC_MAX_VALUE_RAW_LEN = 64MYAC_MAX_VALUE_COMPRESSED_LEN = 1MYAC_SERIALIZER_PHP = 0 ; since yac-2.2.0YAC_SERIALIZER_JSON = 1 ; since yac-2.2.0YAC_SERIALIZER_MSGPACK = 2 ; since yac-2.2.0YAC_SERIALIZER_IGBINARY = 3 ; since yac-2.2.0YAC_SERIALIZER ; serializer according to yac.serializer, default is YAC_SERIALIZER_PHP
登录后复制
注意 cli 下会出现的问题
如果 cli情况下 一定ini配置开启cli-enable
set([1,2,3,5,6]);//获取缓存$a = $cache->get();//备注 1.由于yac的缓存是共享的,所以在多个项目中使用时,需要注意key的唯一性,否则会出现缓存覆盖的情况//备注 2.由于cli在执行后会自动退出,所以在cli中使用时,需要注意缓存的有效期,当再次执行时候换存是拿不到的//例如//例//step 1set([1,2,3,5,6]);//php step1.php //执行后会自动退出,缓存失效get();var_dump($arr);// 空//php step2.php //执行事后上一个进程已经退出,所以缓存失效
登录后复制
方法
Yac::__construct
Yac::__construct([string $prefix = ""])
登录后复制
Yac 的构造函数,您可以指定一个前缀,该前缀将用于在执行设置 / 获取 / 删除时预先添加到任何键
登录后复制
Yac::set
Yac::set($key, $value[, $ttl = 0]) Yac::set(array $kvs[, $ttl = 0])
登录后复制
将一个值存储到 Yac 缓存中,键是缓存唯一的,因此使用相同的键存储第二个值将覆盖原始值。
成功时返回 true,错误时返回 false (如无内存,无法获得 cas write right)
set("foo", "bar");$yac->set( array( "dummy" => "foo", "dummy2" => "foo", ) );?>
登录后复制
Note:
如 Yac 2.1,如果 cas 竞争失败,可能会失败,您可能需要执行以下操作:
while (!($yac->set("important", "value")));
登录后复制
Yac::get
Yac::get(array|string $key[, &$cas = NULL])
登录后复制
从缓存中获取存储变量。如果一个数组被传递,那么每个元素都被获取并返回。成功时返回值,错误时返回 false
set("foo", "bar");$yac->set( array( "dummy" => "foo", "dummy2" => "foo", ) );$yac->get("dummy");$yac->get(array("dummy", "dummy2"));?>
登录后复制
Yac::delete
Yac::delete(array|string $keys[, $delay=0])
登录后复制
从缓存中删除存储的变量。如果指定了延迟,则该值将在 $delay 秒后删除。
Yac::flush
Yac::flush()
登录后复制
立即使所有现有项目无效。它实际上并没有释放任何资源,它只将所有项目标记为无效。
Yac::info
Yac::info(void)
登录后复制
获取缓存信息
info()); /* will return an array like: array(11) { ["memory_size"]=> int(541065216) ["slots_memory_size"]=> int(4194304) ["values_memory_size"]=> int(536870912) ["segment_size"]=> int(4194304) ["segment_num"]=> int(128) ["miss"]=> int(0) ["hits"]=> int(955) ["fails"]=> int(0) ["kicks"]=> int(0) ["slots_size"]=> int(32768) ["slots_used"]=> int(955) } */
登录后复制
isEnable = false; throw new RuntimeException("yac 扩展不存在!"); } if (!$key) { throw new RuntimeException("key 不能为空!"); } $this->key = md5($key); } /** * * 获取共享内存块的值。 */ public function get() { if ($this->isEnable) { return (new Yac("db_"))->get($this->key); } throw new RuntimeException("yac is not enable ,skip getCache"); } /** * * 设置共享内存块的值。 */ public function set($var): bool { if ($this->isEnable) { return (new Yac("db_"))->set($this->key, $var, 3600); } throw new RuntimeException("yac is not enable ,skip setCache"); } /** * * 删除共享内存块的值。 */ public function del(): bool { if ($this->isEnable) { return (new Yac("db_"))->delete($this->key); } throw new RuntimeException("yac is not enable ,skip delCache"); } /** * * 获取共享内存块的信息。 */ public function info(): array { if ($this->isEnable) { return (new Yac("db_"))->info(); } throw new RuntimeException("yac is not enable ,skip info"); } /** * * 清空共享内存块的值。 */ public function flush(): bool { if ($this->isEnable) { return (new Yac)->flush(); } throw new RuntimeException("yac is not enable ,skip flush"); }}
登录后复制
推荐学习:《PHP视频教程》
以上就是php共享缓存之Yac替换APCU memcache!的详细内容,更多请关注php中文网其它相关文章!