zoukankan      html  css  js  c++  java
  • WIN下PHP Memcache的安装和使用

    前几天就一直在想着测试下Memcache的了,可是总是抽不出时间,其实是自己很懒,不想去弄...昨天晚上开始搞,还在服务器上弄了下,折腾了下,因为没有安装Memcached,所以无法连接.就在笔记本上安装了下.GG了下说是需要加载memcache.dll的扩展,弄了还是无法连接比较胸闷了.今天到群里面问了下,在去GG了下就解决了.得到的结论是不要在心情浮躁的时候去弄程序,这样是解决不好问题的,需要平静下来,问题很快就解决了.

    WIN下安装方法 ,参考来源:http://www.ccvita.com/258.html  这位兄弟的文章很好都是实践所得...甚是敬佩....

    Windows下的Memcache安装
    1. 下载memcache的windows稳定版,解压放某个盘下面,比如在c:\memcached
    2. 在终端(也即cmd命令界面)下输入 ‘c:\memcached\memcached.exe -d install’ 安装
    3. 再输入: ‘c:\memcached\memcached.exe -d start’ 启动。NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了。
    4.下载php_memcache.dll,请自己查找对应的php版本的文件
    5. 在C:\winnt\php.ini 加入一行 ‘extension=php_memcache.dll’
    6.重新启动Apache,然后查看一下phpinfo,如果有memcache,那么就说明安装成功!
     

    memcached的基本设置

    -p 监听的端口
    -l 连接的IP地址, 默认是本机
    -d start 启动memcached服务
    -d restart 重起memcached服务
    -d stop|shutdown 关闭正在运行的memcached服务
    -d install 安装memcached服务
    -d uninstall 卸载memcached服务
    -u 的身份运行 (仅在以root运行的时候有效)
    -m 最大内存使用,单位MB。默认64MB
    -M 内存耗尽时返回错误,而不是删除项
    -c 
    最大同时连接数,默认是1024
    -f 块大小增长因子,默认是1.25
    -n 最小分配空间,key+value+flags默认是48
    -h 显示帮助

    Memcache环境测试
    运行下面的php文件,如果有输出This is a test!,就表示环境搭建成功。开始领略Memcache的魅力把!

    <?php
    $mem = new Memcache;
    $mem->connect(”127.0.0.1, 11211);
    $mem->set(’key, ‘This is a test!, 0, 60);
    $val = $mem->get(’key’);
    echo $val;
    ?>

    这里我做了下测试,使用了TP框架2.0版

    测试代码
    header('Content-type:text/html;charset=utf-8');
    debug_start(
    'a');

    $cache = Cache::getInstance('Memcache');

    //获得数据
    if(!$cache->get('district'))
    {
    $m = M('district');
    $result = $m->limit('4000')->select();
    //写入cache
    $cache->set('district',$result,0,-1);
    //dump('setok');
    }
    $results = $cache->get('district');

    //dump($results);
    debug_end('a');

    加载4K条数据的时间

    Process a: Times 0.427078s Memories 5,979 k

    使用缓存的

    Process a: Times 0.211823s Memories 2,765 k

    处理上性能还是有所提高,需要设置对所有缓存的管理,可以替代文件缓存了.使用过程中发现了问题,数据量大于5000条的时候就set不进去的了

    查了一下,信息来源 http://blog.myspace.cn/e/401447849.htm

    根据上面介绍的内容及参数设定,可以计算出的一些结果:

    1、在memcached中可以保存的item个数是没有软件上限的,之前我的100万的说法是错误的。
    2、假设NewHash算法碰撞均匀,查找item的循环次数是item总数除以hashtable大小(由hashpower决定),是线性的。
    3、Memcached限制了可以接受的最大item是1MB,大于1MB的数据不予理会。
    4、Memcached的空间利用率和数据特性有很大的关系,又与DONT_PREALLOC_SLABS常量有关。 在最差情况下,有198个slab会被浪费(所有item都集中在一个slab中,199个id全部分配满)。

    其他的几篇关于Memcached的文章

    http://tech.idv2.com/2008/07/10/memcached-001/

    http://www.ooso.net/archives/558

    http://blog.myspace.cn/e/401447849.htm

    http://blog.csdn.net/binger819623/archive/2008/12/10/3489062.aspx

  • 相关阅读:
    javascript数据结构
    uni-app — 一套前端开发跨平台应用的终极解决方案
    从函数式编程到Ramda函数库(二)
    从函数式编程到Ramda函数库(一)
    node.js爬取数据并定时发送HTML邮件
    vue cli3.0 结合echarts3.0和地图的使用方法
    vue加载优化策略
    C#时间格式化
    wpf 调用线程无法访问此对象,因为另一个线程拥有该对象。
    使用oracle数据库开发,异常总结
  • 原文地址:https://www.cnblogs.com/scotoma/p/1745011.html
Copyright © 2011-2022 走看看