yac缓存

Yac是用于PHP的共享和无锁内存用户数据缓存。它可以用来替换APC或本地memcached。

要求

  • PHP 7 +

Install

$/path/to/phpize
$./configure --with-php-config=/path/to/php-config
$make && make install

Note

  1. Yac是无锁缓存,您应该尽量避免或减少多个进程设置一个相同键的概率

  1. Yac使用部分crc,您最好重新排列缓存内容,将最重要 (可变) 的字节放在头部或尾部

Restrictions

  1. 缓存key不能大于 48 (YAC_MAX_KEY_LEN) bytes

  1. 缓存内容不能大于 64M (YAC_MAX_VALUE_RAW_LEN) bytes

  1. 压缩后的缓存值不能大于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
<?php
use Doraemon\pockets\datebase\ShareCache;
//实例化缓存封装类
$cache  = new ShareCache('test');
//设置缓存
$cache->set([1,2,3,5,6]);
//获取缓存
$a = $cache->get();//备注 1.由于yac的缓存是共享的,所以在多个项目中使用时,需要注意key的唯一性,否则会出现缓存覆盖的情况
//备注 2.由于cli在执行后会自动退出,所以在cli中使用时,需要注意缓存的有效期,当再次执行时候换存是拿不到的
//例如//例
//step 1
<?php
use Doraemon\pockets\datebase\ShareCache;
$cache  = new ShareCache('test');
//设置缓存
$cache->set([1,2,3,5,6]);
//php step1.php //执行后会自动退出,缓存失效<?php
use Doraemon\pockets\datebase\ShareCache;
//step 2
$cache  = new ShareCache('test');
//设置缓存
$arr = $cache->get();
var_dump($arr);// 空
//php step2.php //执行事后上一个进程已经退出,所以缓存失效

方法

Yac::__construct

   Yac::__construct([string $prefix = ""])

Yac的构造函数,您可以指定一个前缀,该前缀将用于在执行设置/获取/删除时预先添加到任何键

<?php$yac = new Yac("myproduct_");
?>

Yac::set

   Yac::set($key, $value[, $ttl = 0])Yac::set(array $kvs[, $ttl = 0])

将一个值存储到Yac缓存中,键是缓存唯一的,因此使用相同的键存储第二个值将覆盖原始值。

成功时返回true,错误时返回false (如无内存,无法获得cas write right)

<?php
$yac = new Yac();
$yac->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

<?php
$yac = new Yac();
$yac->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)

获取缓存信息

<?php....var_dump($yac->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)}*/
<?phpnamespace Test\Cacheuse Yac;
use RuntimeException;/*** 共享缓存类* Date: 2023/2/22* Time: 16:13* docs:*/
class ShareCache
{public bool $isEnable = true;public string $key = '';/**** 共享内存块实例化。*/public function __construct($key){if (!extension_loaded("yac")) {$this->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 共享缓存之yac 快来替换掉APCU memcache相关推荐

  1. 【Excle数据透视表】如何创建非共享缓存的数据透视表

    一般情况下,利用同一个数据源创建多个数据表时,默认创建的是共享缓存的数据透视表.刷新一个数据透视表时会影响其他数据透视表的展示结果. 解决方案 创建非共享缓存的多个数据透视表 步骤一 单击工作表数据任 ...

  2. SQLite剖析之异步IO模式、共享缓存模式和解锁通知

    1.异步I/O模式     通常,当SQLite写一个数据库文件时,会等待,直到写操作完成,然后控制返回到调用程序.相比于CPU操作,写文件系统是非常耗时的,这是一个性能瓶颈.异步I/O后端是SQLi ...

  3. 让世界没有陌生的角落共享单车时代的快与慢

    摘要:本文的整理自2017云栖大会-上海峰会上ofo小黄车梅嘉祺的分享讲义,讲义主要分为三部分,分别是唯快不破的共享单车行业,阿里赋能加速小黄车前行及共享单车放慢城市的步调. 在2017云栖大会-上海 ...

  4. 厉害了!不重启JVM,替换掉已经加载的类

    欢迎关注方志朋的博客,回复"666"获面试宝典 在遥远的希艾斯星球爪哇国塞沃城中,两名年轻的程序员正在为一件事情苦恼,程序出问题了,一时看不出问题出在哪里,于是有了以下对话: &q ...

  5. 骚操作 | 不重启 JVM,替换掉已经加载的类,偷天换日?

    点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 来源:美团技术博客 Java对象行为 java.lang.inst ...

  6. 骚操作:不重启 JVM,如何替换掉已经加载的类?

    本文来源:美团技术博客 Java对象行为 java.lang.instrument.Instrumentation 直接操作字节码 BTrace Arthas 三生万物 在遥远的希艾斯星球爪哇国塞沃城 ...

  7. excel:替换问号?时会所有数据被替换掉(通配符问题)

    如图,替换问号?为#,会替换掉所有数据.因为?是通配符,可代表任意单个字符 解决方法:用~?转译? 总结:在Excel中通配符有3个,分别为?(问号).*(星号).~(波形符). ?代表任意单个字符: ...

  8. handlebars.js 用 br替换掉 内容的换行符

    handlebars.js 用 <br>替换掉 内容的换行符 JS: Handlebars.registerHelper('breaklines', function(text) {    ...

  9. 不重启JVM,替换掉已经加载的类,偷天换日?

    来源 | 美团技术博客 在遥远的希艾斯星球爪哇国塞沃城中,两名年轻的程序员正在为一件事情苦恼,程序出问题了,一时看不出问题出在哪里,于是有了以下对话: "Debug一下吧." &q ...

最新文章

  1. poj2019(二维RMQ)
  2. Debug Tensorflow: Object was never used (type <class ‘tensorflow.python.ops.tensor_array_ops.TensorA
  3. 技术QA:如何安装并启用BITS和WebDAV?
  4. sqlserver 建表指定主键_3-自增字段;主键约束
  5. linux命令增删改查,hw_linux_study_day003,Linux系统终端中的增删改查命令
  6. LintCode—链表倒数第n个节点(166)
  7. python 录制键盘宏_宏命令如何录制_海盗船 K70RGB版红轴机械键盘_键鼠导购-中关村在线...
  8. 第一次在CSDN上写博客
  9. Nacos:快速不停打印获取配置 c.a.n.client.config.impl.ClientWorker : get changedGroupKeys[${dataId}+${grou
  10. Alexa世界排名作弊分析
  11. 我看肖老师的《明日世界-云端计算下的程序设计需求》视频时,做的简单笔记
  12. [java学习笔记]-注解和反射
  13. matlab gui双音拨号,电子信息毕业设计---双音多频拨号系统的MATLAB仿真实现
  14. 1660_MIT 6.828 JOS初始化boot_alloc的初步实现
  15. 逐帧绘制毕达哥拉斯树
  16. ISC2022 HackingClub白帽峰会倒计时1天!最全议程正式公布!元宇宙集结,精彩绝伦!
  17. (14)Delphi下利用JVCL组件包快速实现——解释Pascal语言的脚本引擎
  18. 力扣【25】K个一组翻转链表(字节跳动面试题)
  19. 虚拟机中通过docker创建docker run -itd -p 8080:8080 -p 8088:8088 镜像ID /bin/bash创建后无法访问
  20. 图书推荐:《战略地图:化无形资产为有形成果》Strategy maps: converting intangible assets into tangible outcomes By Robert S

热门文章

  1. 卓训教育:如何批评孩子,正确批评孩子的方法
  2. IE浏览器缓存第二次请求的解决方案
  3. android自动划屏实现,OSC首发:android中的左右滑屏实现By ViewPager
  4. android textview截断,Android Textview文字在底部被截断
  5. 使用prometheus(普罗米修斯)监控redis容器详解
  6. Kubernetes利用CNI-bridge插件打通网络
  7. android camera使用ISO值录制视频
  8. HTML 学习总结2 框架 表单
  9. BK3432和BK3431Q芯片开发问题
  10. C# 源代码+ SQLserver数据库点餐软件