zoukankan      html  css  js  c++  java
  • PHP MEMCACHE 详解(经典php缓存)

    Memcache函数库是在PECL(PHPExtensionCommunityLibrary)中,主要作 用是搭建大容量的内存数据的 临时存放区域,在分布式的时候作用体现的非常明显,否则不建议使用。 本人在ubuntu上安装 完运行的时候报错: /usr/local/memcached/bin/memcached:errorwhilelo
     
       

    Memcache函数库是在PECL(PHP Extension Community Library)中,主要作用是搭建大容量的内存数据的

    临时存放区域,在分布式的时候作用体现的非常明显,否则不建议使用。 本人在ubuntu上安装

    完运行的时候报错:
    /usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2: 

    cannot open shared object file: No such file or directory

    按照:《libeven、memcached、libmemcache安装》中的方法,使用:

    sudo ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2
    可以修正这个BUG

    通过新得立安装php的memcached模块,注销/etc/php5/conf.d/memcached.ini里面的“;”,重启apache

    ,调用phpinfo()出现memcached的信息

    执行:
    <?php
    $memcache 
    = new Memcache
    ;
    $memcache->connect('localhost'11211) or die ("Could not connect"
    );
    $version $memcache->getVersion
    ();
    echo 
    "Server's version: ".$version.
    "
    \n"
    ;
    ?>
    <?php
    $memcache 
    = new Memcache
    ;
    $memcache->connect('localhost'11211) or die ("Could not connect"
    );
    print_r($memcache->getStats
    ());
    /**
    * Array
    * (
    *     [pid] => 8052
    *     [uptime] => 9205
    *     [time] => 1205898428
    *     [version] => 1.2.5
    *     [pointer_size] => 32
    *     [rusage_user] => 0.008000
    *     [rusage_system] => 0.000000
    *     [curr_items] => 1
    *     [total_items] => 17
    *     [bytes] => 57
    *     [curr_connections] => 2
    *     [total_connections] => 15
    *     [connection_structures] => 3
    *     [cmd_get] => 9
    *     [cmd_set] => 23
    *     [get_hits] => 5
    *     [get_misses] => 4
    *     [evictions] => 0
    *     [bytes_read] => 671
    *     [bytes_written] => 850
    *     [limit_maxbytes] => 10485760
    *     [threads] => 1
    * )
    */
    ?>
    <?php
    $memcache 
    = new Memcache
    ;
    $memcache->connect('localhost'11211) or die ("Could not connect"
    );
    $memcache->set'name''leo'030
    );
    if(!
    $memcache->add'name''susan'030
    ))
    {
        echo 
    'susan is exist'
    ;
    };
    $memcache->replace'name''lion'0300
    );
    echo 
    $memcache->get'name'
    );
    $memcache->delete'name'5
    );
    ?> 
    <?php
    function _callback_memcache_failure($host$port
    ) {
        print 
    "memcache '$host:$port' failed"
    ;
    }
    $memcache = new Memcache
    ;
    $memcache->addServer('192.168.1.116'11211
    );
    $memcache->setServerParams('192.168.1.116'11211115true


    '_callback_memcache_failure'
    );
    echo 
    $memcache->getServerStatus('192.168.1.116'11211
    );
    ?>
    <?php
    $memcache 
    = new Memcache
    ;
    $memcache->connect('localhost'11211
    );
    $memcache->set('test_item'8
    );
    $memcache->increment('test_item'4
    );
    echo 
    $memcache->decrement('test_item'7
    );
    // 显示 5
    ?>


     

    /usr/local/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 11211 -c 256 -P 
                    /tmp/memcached.pid
    memcached的服务正式启动

    Memcache::add — 添加一个值,如果已经存在,则返回false
    Memcache::addServer — 添加一个可供使用的服务器地址
    Memcache::close — 关闭一个Memcache对象
    Memcache::connect — 创建一个Memcache对象
    memcache_debug — 控制调试功能
    Memcache::decrement — 对保存的某个key中的值进行减法操作
    Memcache::delete — 删除一个key值
    Memcache::flush — 清除所有缓存的数据
    Memcache::get — 获取一个key值
    Memcache::getExtendedStats — 获取进程池中所有进程的运行系统统计
    Memcache::getServerStatus — 获取运行服务器的参数
    Memcache::getStats — 返回服务器的一些运行统计信息
    Memcache::getVersion — 返回运行的Memcache的版本信息
    Memcache::increment — 对保存的某个key中的值进行加法操作
    Memcache::pconnect — 创建一个Memcache的持久连接对象
    Memcache::replace — R对一个已有的key进行覆写操作
    Memcache::set — 添加一个值,如果已经存在,则覆写
    Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩
    Memcache::setServerParams — 在运行时修改服务器的参数


    建议用面向对象的方式来测试这个库: 


    Memcache::getVersion方法的作用是返回运行的Memcache的版本信息。

    Memcache::getStats 方法的作用是返回服务器的一些运行统计信息。Memcache::getStats方法有三个参

    数,第一个参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;第二个

    参数和第三个参数是在第一个参数设置为“cachedump”时使用的。Memcache::getExtendedStats方法的

    作用是获取进程池中所有进程的运行系统统计。


    Memcache::connect方法的作用是创建一个Memcache对象。Memcache::pconnect方法的作用是创建一个

    Memcache的持久连接对象。Memcache::close方法的作用是关闭一个Memcache对象。

    Memcache::set 方法的作用是添加一个值,Memcache::set方法有四个参数,第一个参数是key,第二个参

    数是value,第三个参数可选,表示是否压缩保存,第四个参数可选,用来设置一个过期自动销毁的时间

    。Memcache::add方法的作用和Memcache::set方法类似,区别是如果 Memcache::add方法的返回值为

    false,表示这个key已经存在,而Memcache::set方法则会直接覆写。 Memcache::get方法的作用是获取

    一个key值,Memcache::get方法有一个参数,表示key。Memcache::replace 方法的作用是对一个已有的

    key进行覆写操作,Memcache::replace方法有四个参数,作用和Memcache::set方法的相同。 

    Memcache::delete方法的作用是删除一个key值,Memcache::delete方法有两个参数,第一个参数表示key

    ,第二个参数可选,表示删除延迟的时间。


    memcache_debug()函数的作用是控制调试功能,前提是php在编译的时候使用了–enable-debug选项,否

    则这个函数不会有作用。

    Memcache::addServer 方法的作用是添加一个可供使用的服务器地址,Memcache::addServer方法有8个参

    数,除了第一个参数意外,其他都是可选的,第一个参数表示服务器的地址,第二个参数表示端口,第三

    个参数表示是否是一个持久连接,第四个参数表示这台服务器在所有服务器中所占的权重,第五个参数表

    示连接的持续时间,第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,第七个

    参数用来控制服务器的在线状态,第8个参数允许设置一个回掉函数来处理错误信息。
    Memcache::setServerParams方法的作用是在运行时修改服务器的参数,Memcache::setServerParams方法

    有六个参数,Memcache::addServer方法少了第三和第四个参数。 Memcache::getServerStatus方法的作

    用是获取运行服务器的参数,两个参数分别表示的地址和端口。


    Memcache::flush方法的作用是清除所有缓存的数据,但是不会削去使用的内存空间。

    Memcache::increment方法的作用是对保存的某个key中的值进行加法操作,Memcache::decremen方法的作

    用是对保存的某个key中的值进行减法操作。

    详见:http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2010/0126/3868.html

  • 相关阅读:
    Springboot如何优雅的解决ajax+自定义headers的跨域请求
    提升开发效率的一款mybatis开发神器
    深究Spring中Bean的生命周期
    阿里Canal框架(数据同步中间件)初步实践
    从技术角度分析推荐系统案例
    记一次token安全认证的实践
    为什么Redis 单线程却能支撑高并发?
    Python 派生类子类继承类
    Python 定制类与其对象的创建和应用
    Python 字典的创建赋值和动态扩展
  • 原文地址:https://www.cnblogs.com/zcy_soft/p/1993657.html
Copyright © 2011-2022 走看看