注册 登陆

    2021-05-11 00:23:11yac扩展详解及安装

    您现在的位置是: 首页 >  php >  yac扩展详解及安装

    介绍

    Yac 是一个同族进程间(典型的如PHP-FPM及其子进程)共享数据的无锁的缓存,无锁的目的是提高CPU多进程的效率。据说 Apc 的效率是 Memcached 的一倍以上,而 Yac 比 Apc 更快。这就是它最大的特点

    而解决无锁的数据一致性问题主要靠两个方面

    1. 1.读锁的替代方案: 返回数据前的校验机制(CRC校验)
    2. 2.写锁的替代方案: 启动时就确定key空间的分布,写操作将数据哈希到对应的slot,对同一个slot写操作冲突问题,客观上允许这种操作的存在,但主观上忽略之(鸟哥自己的测试脚本(脚本地址)结果是千万分之一)

    注意事项

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

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

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


    相关方法

    具体的方法使用,可以看https://github.com/laruence/yac

    需要说明的几点:
    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内存重新分配的次数。


    php扩展Yac的安装

    1.git clone https://github.com/laruence/yac
    cd yac
    2.phpize //生成configure
    3../configure --with-php-config=/usr/local/php/bin/php-config
    4.make && make install
    5.修改php.ini 加一句
    extension = yac.so
    然后重启服务器 重启 php php -m 查看yac扩展


    参考

    yac的github地址
    鸟哥的博客


关键字词: yac扩展详解及安装,yac

0




时间:2021-07-28 18:09:26 土工布:
资深程序员不简单www.dzfdy.com