Memcached事实上,两次Hash算法

   第一次hash算法被用于定位Memcached示例

   第二次hash算法是底部HashMap中间hash算法





Hash算法

     1.依据余数来进行计算(事实上java中的HashMap的hash算法也是用的这样的方式)

     2.一致性hash算法

         C的client  --->libMemcached已经实现了该功能,C的开发者直接使用它。

新浪----->Memcachedb  实现了持久化功能





java的client

 a官方的 memcached client for java

    比較稳定

    用了jdk比較早的版本号。性能稍差,而且使用的BIO

 b.spyMemcached

    NIO,线程池框架

    一致性hash

    稳定性差,报timeout异常

 c.xMemcached 

     java nio

     java 线程池

     性能比spyMemcached要好

     而且比較稳定,且和spring等框架可以非常好的结合使用

     一致性hash

 d.淘宝包装的javaclient

   java nio

   线程池框架

   cluster机制

结合本地缓存

接下来我们使用第一种

这是须要的jar

package com.chengxi.memc.test;

import org.junit.Test;

import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool; public class MemcachedTest01 {
@Test
public void testOne() throws Exception { MemCachedClient client = new MemCachedClient();
//memserver地址
String[] addr = {"192.168.0.140:11211"};
//相应的权重
Integer[] weight = {3};
SockIOPool pool = SockIOPool.getInstance(); pool.setServers(addr);
pool.setWeights(weight);
pool.setInitConn(5);
pool.setMinConn(5);
pool.setMaxConn(200);
pool.setMaxIdle(1000*30*30);
pool.setMaintSleep(30); //socket param timeout
pool.setNagle(false);
pool.setSocketTO(30);
pool.setSocketConnectTO(0); //start
pool.initialize(); //client.set("name", "wzh");
//System.out.println(client.get("name"));
Student student = new Student();
student.setId(1);
student.setName("呵呵"); client.set("student1",student); System.out.println(client.get("student1"));
} @Test
public void two(){
MemCachedClient client = new MemCachedClient();
//memserver地址
String[] addr = {"192.168.0.140:11211","192.168.0.140:11212"};
//相应的权重
Integer[] weight = {5,5};
SockIOPool pool = SockIOPool.getInstance(); pool.setServers(addr);
pool.setWeights(weight);
pool.setInitConn(5);
pool.setMinConn(5);
pool.setMaxConn(200);
pool.setMaxIdle(1000*30*30);
pool.setMaintSleep(30); //socket param timeout
pool.setNagle(false);
pool.setSocketTO(30);
pool.setSocketConnectTO(0); //start
pool.initialize(); for(int i = 0;i<10;i++){
client.set("test"+i,"test"+i);
} }
}

官方的jar包实现了 哈希一致性

也就是说  上面的 two的方法  分别将test0-9 存进了两台memserver中

假设当中一台宕机了   获取数据的时候不会影响另外一台

假设没有实现一致哈希的话 就会影响其它server 导致全部的数据无法获取

package com.chengxi.memc.test;

import java.io.Serializable;

public class Student implements Serializable {
private Integer id;
private String name; public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "[id:"+this.id+",name"+this.name+"]";
}
}

这是实体类 为了实现系列化

版权声明:本文博主原创文章,博客,未经同意不得转载。

Java操作memcached(一)的更多相关文章

  1. Java操作Memcached

    本文复制其他播客,有好的技术文章希望各位大神能告知... 谢谢. 如何使用Java操作Memcached实例: 代码一: package com.ghj.packageoftool; import j ...

  2. memcached—Java操作Memcached实例

    前面博客介绍了如何在Windows操作系统中安装Memcached,总结一下如何使用Java操作Memcached实例: 代码一: package com.ghj.packageoftool; imp ...

  3. Java操作memcache

    [本文出自天外归云的博客园] 准备工作 Java操作memcache需要spymemcache类库的支持,在Eclipse中修改maven项目的pom.xml文件—— 添加仓库: <reposi ...

  4. Redis基础知识、命令以及java操作Redis

    1 nosql的概念 sql:操作(关系型)数据库的标准查询语言 关系型数据库(rdbms):以关系(由行和列组成的二维表)模型为核心数据库,有表的储存系统.(mysql.oracle.sqlserv ...

  5. Redis-基本概念、java操作redis、springboot整合redis,分布式缓存,分布式session管理等

    NoSQL的引言 Redis数据库相关指令 Redis持久化相关机制 SpringBoot操作Redis Redis分布式缓存实现 Resis中主从复制架构和哨兵机制 Redis集群搭建 Redis实 ...

  6. Java操作Sqlite数据库-jdbc连接

    Java操作Sqlite数据库步骤: 1. 导入Sqlite jdbc 本文使用sqlite-jdbc-3.7.2.jar,下载地址 http://pan.baidu.com/s/1kVHAGdD 2 ...

  7. 【MongoDB for Java】Java操作MongoDB

    上一篇文章: http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html介绍到了在MongoDB的控制台完成MongoDB的数据操作,通过 ...

  8. Java操作Oracle

    public class DBCon { // 数据库驱动对象 public static final String DRIVER = "oracle.jdbc.driver.OracleD ...

  9. JAVA操作ORACLE数据库的存储过程

    一.任务提出 JAVA操作oracle11g存储过程实验需要完成以下几个实例: 1.调用没有返回参数的过程(插入记录.更新记录) 2.有返回参数的过程 3.返回列表的过程 4.返回带分页的列表的过程. ...

随机推荐

  1. PHP草根论之设计模式-訪问者模式

    关于模式本身的概念,请參考网上其他文章 此处仅仅讨论在PHP实际开发过程中的应用 此模式适用范围极为受限,适用情景: 1.适用于项目维护过程,不适用于项目开发过程 2.新增需求,要求为一个/多个类添加 ...

  2. UVA 11235 Frequent values(RMQ)

    Frequent values TimeLimit:3000Ms , ... , an in non-decreasing order. In addition to that, you are gi ...

  3. 一个简单而经典的RTX51 Tiny应用实例

    关于RTX51 Tiny嵌入式实时操作系统的描写叙述请參考本人的上一篇博文(RTX51 Tiny实时操作系统学习笔记-初识RTX51 Tiny). 本篇博文.我将通过一个实例代码,带大家深入了解一下R ...

  4. CentOS7 编译安装LNMP

    (文章来自:http://www.cnblogs.com/i-it/p/3841840.html,请各位到这个网址去看原文的) LNMP(Linux-Nginx-Mysql-PHP),本文在CentO ...

  5. 用 Apache James 搭建邮件服务器来收发邮件实践(一)(转)

    Apache James 简称 James, 是 Java Apache Mail Enterprise Server的缩写.James 是100%基于Java的电子邮件服务器.它是一种独立的邮件服务 ...

  6. Android 大约Dialog弹出窗口

    直接效果图: 实现步骤: 1.主界面activity_main.xml非常easy,一个button <RelativeLayout xmlns:android="http://sch ...

  7. Windows Phone开发(10):常用控件(上)

    原文:Windows Phone开发(10):常用控件(上) Windows Phone的控件有几个来源,和传统的桌面应用程序开发或Web开发一样,有默认提供的控件和第三方开者发布的控件.一般而言,如 ...

  8. veridata实验例(3)验证veridata发现insert操作不会导致同步

    veridata实验例(3)验证veridata发现insert操作不会导致同步 续接:<veridata实验举例(2)验证表BONUS与表SALGRADE两节点同步情况>,地址:点击打开 ...

  9. 垂死或涅槃重生 -- Delphi XE5 我们将宣布感情的回归

    Delphi 在很大程度上是一个被遗忘我的工具. 无论是在使用RapidSql , 我还没有收到Embarcadero 本公司发行参与邀请Delphi XE5该公告将. 可能有人会问,为什么Embar ...

  10. uva-11234 Expressions

    Arithmetic expressions are usually written with the operators in between the two operands (which is ...