php7.0扩展yac,php的yac拓展详解

介绍

yac拓展的作用是php进程之间共享数据缓存。这里我们不探讨如何安装yac拓展,而是探讨其详细用法。这篇文章的参考资料有鸟哥那篇yac拓展的文章与yac拓展github的描述。

注意事项

因为是php进程之间共享,所以它是单机的缓存,多台机器时还是用memcached或者redis更好。但是它可以和redis等形成互补,比如当缓存key比较大,使用又频繁,将缓存迁移到yac降低redis的压力。

yac是无锁的缓存,所以要尽量避免多个进程设置相同key。同时它还意味着有可能获取cache的时候拿到错误的数据,取决于分配了多少密钥槽和存储了多少密钥, 1/10000000(千万分之一)的概率会发生。

Yac使用部分crc校验,最好重新安排你的缓存内容,把最易变的字节放在头或尾。

使用限制

key名的长度不能超过48(YAC_MAX_KEY_LEN常量),如果key长度超过了,使用md5即可

value值不能超过64M(YAC_MAX_VALUE_RAW_LEN常量)

压缩后的value值不能超过1M(YAC_MAX_VALUE_COMPRESSED_LEN常量)

相关方法

看github就行了,github.com/laruence/ya…

需要说明的几点:

1.是可以一次性设置多个key的,但他们的过期时间都是一样的。

2.没有获取key过期时间的方法

3.flush方法,并不会释放任何资源,只是将所有项标记为无效

info方法返回的值的含义

Array

(

[memory_size] => 71303168

[slots_memory_size] => 4194304

[values_memory_size] => 67108864

[segment_size] => 4194304

[segment_num] => 16

[miss] => 23

[hits] => 90

[fails] => 0

[kicks] => 0

[recycles] => 0

[slots_size] => 32768

[slots_used] => 17

)

复制代码

1.miss代表没有命中的次数,hits缓存命中的次数,slots_size是key slot个数,也就是能存多少key,slots_used是已使用的key slot数,也就是当前key的个数。

2.memory_size:yac总共占用的内存,默认68M,slots_memory_size:key槽占用的内存默认4M,配置yac.keys_memory_size = 4M,4M有30K的key槽, 32M有100K的key槽,values_memory_size:value值占用的内存,配置yac.values_memory_size = 64M,默认64M,单位都是byte。 3.kicks被踢出的次数,recycles内存重新分配的次数。

参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
帮我优化一下这段代码(select uuid() as id , a.customerCode as customerCode , a.customerName as customerName , a.unifiedSocialCreditCode as unifiedSocialCreditCode , a.firstInsuranceCode as firstInsuranceCode , a.firstInsuranceName as firstInsuranceName , a.firstRiskCode as firstRiskCode , a.firstRiskName as firstRiskName , a.secondRiskCode as secondRiskCode, a.secondRiskName as secondRiskName, cast(a.secondRiskBasicScore as DECIMAL(6,2)) as secondRiskBasicScore , cast(a.secondRiskBasicScore as DECIMAL(6,2)) as secondRiskScore , to_date(date_add(now(),-1)) as createDate from ( select a.customerCode, a.customerName, a.unifiedSocialCreditCode,'ALL' AS firstInsuranceCode,'全险种' AS firstInsuranceName,c.firstRiskCode,c.firstRiskName,c.secondRiskCode,c.secondRiskName, sum((case when (a.POLICYSTATUS = 'A') then a.sumAssured when (a.POLICYSTATUS = 'B') then (a.PAYOUT+a.OUTSTANDING) else a.sumAssured end) / b.AllcustomersumAssured * c.secondRiskScore) as secondRiskBasicScore from ccic_fkyjrisk.FocusCustomerPolicyData a join ccic_fkyjrisk_orig.InsuranceProductGroup d on d.scoreCardType='0' and a.insuranceCode = d.insuranceCode join ccic_fkyjrisk.PolicyRiskSecondScore c on a.customerCode = c.customerCode and a.policycode=c.policycode and firstRiskCode = '002' join ccic_fkyjrisk.TargetcustomerRanking b on b.firstInsuranceCode ='ALL' and a.customerCode = b.customerCode where (case when (a.POLICYSTATUS = 'A') then a.sumAssured when (a.POLICYSTATUS = 'B') then (a.PAYOUT+a.OUTSTANDING) else a.sumAssured end)>0 and length(nvl(cast((case when (a.POLICYSTATUS = 'A') then a.sumAssured when (a.POLICYSTATUS = 'B') then (a.PAYOUT+a.OUTSTANDING) else a.sumAssured end) as string),''))>0 and (a.firstInsuranceName!='健康险' and a.insuranceCode not in('5IE','5VA','5XA','5XC','5XE','EFD','EFM','EFW','EGB','EGM', 'EGZ','EIA','EIB','EIE','EIF','EIH','EIZ','ERQ','ERW','ERY','ERZ','ESZ','ETB','ETC', 'ETR','ETX','ETZ','EVA','EVB','EXA','EXB','EXE','EYM','4DJ','EGD','5GD','ZCJ','ZCF') and a.secondInsuranceName not in('家庭财产保险','农业保险') and a.insuranceCode not like 'YEE%' and a.insuranceCode not like 'YAC%') group by a.customerCode, a.customerName, a.unifiedSocialCreditCode,c.firstRiskCode,c.firstRiskName,c.secondRiskCode,c.secondRiskName) a;)
06-08

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值