1. <?php
  2.  
  3. /**
  4. * 分布式的 memcache set 实现
  5. */
  6.  
  7. /**
  8. * 创建缓存实现memcache 添加分布式服务器 并设置权限
  9. */
  10.  
  11. function createCache() {
  12. $arr = array(
  13. array("host" => "127.0.0.1", "port" => 11211, "weight" => 20), //127.0.0.1:11211的权重是20%
  14. array("host" => "127.0.0.1", "port" => 11212, "weight" => 80), //127.0.0.1:11212的权重是80%
  15. );
  16. $cache = new memcache();
  17. foreach ($arr as $ele) {
  18. //使用长连接,并且设置不同memcache服务器的权重,将memcache服务器添加到连接池
  19. $cache->addServer($ele["host"], $ele["port"], true, $ele["weight"]);
  20. }
  21. return $cache;
  22. }
  23.  
  24. header("content-type:text/html;charset=utf-8");
  25. $cache = createCache();
  26. for ($i = 0; $i < 10; $i++) {
  27. //由于使用了分布式,所以这里不需要使用connect或者pconnect打开链接,
    //set方法会调用memcache的分布式缓存分配算法,按照权重将缓存项缓存到连接池的某个服务器
  28. if ($cache->set($i, $i, 0, 3600)) {
  29. echo "缓存成功,key:$i,value:$i";
  30. } else {
  31. echo "缓存失败";
  32. }
  33. echo "<br/>";
  34. }
  35. ?>
  1. <?php
  2.  
  3. /**
  4. * 分布式的 memcache get 实现
  5. */
  6.  
  7. function createCache() {
  8. $arr = array(
  9. array("host" => "127.0.0.1", "port" => 11211, "weight" => 20),
  10. array("host" => "127.0.0.1", "port" => 11212, "weight" => 80)
  11. );
  12. $cache = new memcache();
  13. foreach ($arr as $ele) {
  14. $cache->addServer($ele ["host"], $ele ["port"], true, $ele ["weight"], 1);
  15. }
  16. return $cache;
  17. }
  18.  
  19. header('content-type:text/html;charset=utf-8');
  20. $cache = createCache();
  21. $val;
  22. for ($i = 0; $i < 10; $i ++) {
  23. $val = $cache->get($i);
  24. if (false === $val) {
  25. echo "缓存获取失败";
  26. } else {
  27. echo "缓存获取成功:,key:$val,value:$val";
  28. }
  29. echo "<br/>";
  30. }
  31. $cache->close();
  32. ?>

memcache分布式小实例的更多相关文章

  1. MemCache分布式内存对象缓存系统

    MemCache超详细解读 MemCache是一个自由.源码开放.高性能.分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而 ...

  2. memcache分布式 [一致性hash算法] 的php实现

    最近在看一些分布式方面的文章,所以就用php实现一致性hash来练练手,以前一般用的是最原始的hash取模做分布式,当生产过程中添加或删除一台memcache都会造成数据的全部失效,一致性hash就是 ...

  3. Memcache分布式锁 转发 https://www.cnblogs.com/li150dan/p/9529090.html

    在分布式缓存的应用中,会遇到多个客户端同时争用的问题.这个时候,需要用到分布式锁,得到锁的客户端才有操作权限 下面通过一个简单例子介绍: 这里引用的是Memcached.ClientLibrary.d ...

  4. 记录memcache分布式策略及算法

    摘要 http://wenku.baidu.com/link?url=eUmpWDGFiFguyQLxwmXwRYmbnW7Wm1Bo79dGoomSnmOPWDIA5-FFSTNRI7MBQq8QG ...

  5. Python_爬虫小实例

    爬虫小实例 一.问题描述与分析 Q:查询某一只股票,在百度搜索页面的结果的个数以及搜索结果的变化. 分析: 搜索结果个数如下图: 搜索结果的变化:通过观察可以看到,每个一段时间搜索结果的个数是有所变化 ...

  6. Memcache分布式锁

    在分布式缓存的应用中,会遇到多个客户端同时争用的问题.这个时候,需要用到分布式锁,得到锁的客户端才有操作权限 下面通过一个简单例子介绍: 这里引用的是Memcached.ClientLibrary.d ...

  7. winform 异步读取数据 小实例

    这几天对突然对委托事件,异步编程产生了兴趣,大量阅读前辈们的代码后自己总结了一下. 主要是实现 DataTable的导入导出,当然可以模拟从数据库读取大量数据,这可能需要一定的时间,然后 再把数据导入 ...

  8. MemCache分布式缓存的一个bug

    Memcached分布式缓存策略不是由服务器端至支持的,多台服务器之间并不知道彼此的存在.分布式的实现是由客户端代码(Memcached.ClientLibrary)通过缓存key-server映射来 ...

  9. CSS应用内容补充及小实例

    一.clear 清除浮动 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

随机推荐

  1. MappedByteBuffer高速缓存文件、RandomAccessFile随机访问

    说到高速缓存存储,处理读写文件,那就不得不说MappedByteBuffer. 看了好多文章以后写一下自己的总结. 在这里先介绍一下相关的类与方法. 先说一下Buffer.ByteBuffer.Map ...

  2. ajax+json数据传输

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  3. 玩转12款Linux开源机器人

    玩转12款Linux开源机器人 头条网2016-02-15 09:04 3DR Solo智能无人机发布于2015年中期.作为试图与大疆广受欢迎的Phantom系列无人机相抗衡的产品,它的双处理器运行L ...

  4. 【转】MTK Android Driver知识大全

    原文网址:http://www.cnblogs.com/biglucky/p/4413797.html 一.Display 1.lcm 相关概念1.1) MIPI接口:一共有三种接口:DBI(也做CP ...

  5. Javascript 操作select控件大全(新增、修改、删除、选中、清空、判断存在等)

    1判断select选项中 是否存在Value="paraValue"的Item 2向select选项中 加入一个Item 3从select选项中 删除一个Item 4删除selec ...

  6. Java中的不可变类

    概念:不可变类的意思是创建该类的实例后,该实例的属性是不可改变的.java中的8个包装类和String类都是不可变类.所以不可变类并不是指该类是被final修饰的,而是指该类的属性是被final修饰的 ...

  7. WORLD OPERATS

        word文章设置无法复制 通常我们会采用设置密码的方式,规定某个文档的使用范围. 但这种方法是有一个局限,那就是可以观看文档的人未必靠谱,万一复制了文档的重要内容怎么办? 因此,不妨考虑加上禁 ...

  8. [Flexbox] Using flex-direction to layout content horizontally and vertically

    The Flexbox css spec allows for more adjustable layouts. The flex-directionproperty allows you to ea ...

  9. 拿到手机ip住址

    转载自:http://blog.csdn.net/showhilllee/article/details/8746114 貌似ASI里获取ip地址的链接不能够了.也曾试过whatismyip,在其站点 ...

  10. android不自动弹出虚拟键盘

    如果是Activity的话 在 Manifest.xml 相应的 Activity 里添加 android:windowSoftInputMode="adjustPan|stateHidde ...