博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Memcached入门
阅读量:5116 次
发布时间:2019-06-13

本文共 3525 字,大约阅读时间需要 11 分钟。

Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。

它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。

Memcached基于一个存储键值对的hashmap。其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信。

 

下面来了解下Memcached怎么用~~

一、准备工作

下载memcached的windows版

再下载一个java_memcached-release.jar

 

二、安装

解压memcached-1.2.5-win32-bin.zip,CMD进入其目录,然后执行如下命令:

c:>memcached.exe -d installc:>memcached.exe -l 127.0.0.1 -m 32 -d start

第一行是安装memcached成为服务,这样才能正常运行,否则运行失败!

第二行是启动memcached的,这里简单的只分配32M内存了(默认64M),然后监听本机端口和以守护进行运行。

执行完毕后,我们就可以在任务管理器中看到memcached.exe这个进程了。

如果想要在同一台Windows机器中安装2个Memcached,请看

三、使用

现在服务器已经正常运行了,下面我们就来写java的客户端连接程序。

将java_memcached-release.zip解压,把java_memcached-release.jar文件复制到java项目的lib目录下,

然后我们来编写代码,比如我提供的一个应用类如下:

 
MemCached

写个Main方法测试下:

public static void main(String[] args) {        MemCached cache = MemCached.getInstance();        boolean result1 = cache.add("hello", 1234, new Date(1000 * 2));// 设置2秒后过期        System.out.println("第一次add : " + result1);        System.out.println("Value : " + cache.get("hello"));                boolean result2 =cache.add("hello", 12345, new Date(1000 * 2));// add fail        System.out.println("第二次add : " + result2);                boolean result3 =cache.set("hello", 12345, new Date(1000 * 2));// set successes        System.out.println("调用set : " + result3);                System.out.println("Value : " + cache.get("hello"));        try {            Thread.sleep(1000 * 2);            System.out.println("已经sleep2秒了....");        } catch (InterruptedException e) {            e.printStackTrace();        }        System.out.println("Value : " + cache.get("hello"));    }

执行结果如下:

第一次add : trueValue : 1234第二次add : false调用set : trueValue : 12345已经sleep2秒了....Value : null

说明:

  1. 第二次add失败是因为"hello"这个key已经存在了。
  2. 调用set成功,是因为set的时候覆盖了已存在的键值对,这正是add和set的不同之处
  3. 设置过期之间之后,cache按时自动失效

 

上面的例子是对于基本数据类型,对于普通的POJO而言,如果要进行存储的话,那么比如让其实现java.io.Serializable接口。

因为memcached是一个分布式的缓存服务器,多台服务器间进行数据共享需要将对象序列化的,所以必须实现该接口,否则会报错的(java.io.NotSerializableException)。

下面来试试POJO的存储:

 
简单的POJO对象

Main方法如下:

public static void main(String[] args) {        MemCached cache = MemCached.getInstance();        Person p1 = new Person();        p1.setName("Jack");        cache.add("bean", p1);                Person p2 = (Person) cache.get("bean");        System.out.println("name=" + p2.getName());//Jack        p2.setName("Rose");                // cache.replace("bean", p2);        Person p3 = (Person) cache.get("bean");        System.out.println("name=" + p3.getName());    }

上面的代码中,我们通过p2.setName("Rose")修改了对象的名字,

最后一行打印的会是什么呢?

name=Jackname=Jack

Why?

这是因为我们修改的对象并不是缓存中的对象,而是通过序列化过来的一个实例对象

那么要修改怎么办?使用replace,注释掉的那一行把注释去掉就可以了。

 

四、其他

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                          显示帮助

 Memcached也可以在控制台中添加键值对,首先使用命令“telnet 127.0.0.1 11211”进入到Memcached控制台,

然后使用set、add、replace、get、delete来操作。

更详细操作可参照

 

五、Memcached的优势和不足

说到Memcached的优势,那当然是:速度快,操作简便,易扩展

不足的话,主要有2点:

  1. 数据的临时性(数据仅保存在内存中)
  2. 只能通过指定键来读取数据,不支持模糊查询

 

六、Memcached停止时的保障措施

如果数据库的访问量比较大,就需要提前做好准备,以便应对在memcached停止时发生的负载问题。

如果能在停止memcached之前,把数据复制到其他的server就好了。恩,这个可以通过repcached来实现。

repcached是日本人开发的实现memcached复制功能,

它是一个单master、单slave的方案,但它的master/slave都是可读写的,而且可以相互同步
如果master坏掉,slave侦测到连接断了,它会自动listen而成为master

 

 

 http://www.cnblogs.com/yejg1212/p/3186179.html

转载于:https://www.cnblogs.com/liuzhuqing/p/7480135.html

你可能感兴趣的文章
webView添加头视图
查看>>
php match_model的简单使用
查看>>
在NT中直接访问物理内存
查看>>
Intel HEX 文件格式
查看>>
SIP服务器性能测试工具SIPp使用指导(转)
查看>>
回调没用,加上iframe提交表单
查看>>
(安卓)一般安卓开始界面 Loding 跳转 实例 ---亲测!
查看>>
Mysql 索引优化 - 1
查看>>
LeetCode(3) || Median of Two Sorted Arrays
查看>>
大话文本检测经典模型:EAST
查看>>
待整理
查看>>
一次动态sql查询订单数据的设计
查看>>
C# 类(10) 抽象类.
查看>>
Vue_(组件通讯)子组件向父组件传值
查看>>
jvm参数
查看>>
我对前端MVC的理解
查看>>
Silverlight实用窍门系列:19.Silverlight调用webservice上传多个文件【附带源码实例】...
查看>>
2016.3.31考试心得
查看>>
mmap和MappedByteBuffer
查看>>
Linux的基本操作
查看>>