Memcache分布式存储测试

7 篇文章 0 订阅
4 篇文章 0 订阅

测试环境:两台配置完全的虚拟机,用python进行测试

memcache和python以及相关软件的下载安装请参考上一篇文章:http://blog.csdn.net/lrenjundk/article/details/7179889


在两台虚拟机上都启动了memcache进程:

memcached -d -m 100 -u root -p 12345 -c 256 -P /tmp/memcached.pid

memcached -d -m 1024 -u root -l 10.197.32.91 -p 12000 -c 256 -P /memcached/memcached.pid


启动python客户端1,链接到第一台memcache上(第一台虚拟机):

>>>mc1 = pylibmc.Client(["10.197.32.159:12345"])


启动python客户端2,链接到第二台memcache上(第二台虚拟机):

>>>mc2 =pylibmc.Client(["10.197.32.91:12000"])


启动python客户端2,同时链接到两台memcache上:

>>>mc3 =pylibmc.Client(["10.197.32.159:12345","10.197.32.91:12000"])


然后用mc3向memcache插入一个新的记录:

>>> mc3.set("foo","da")
True

然后用mc1和mc2分别检查“foo”的存在:

>>> mc1.get("foo")
>>>

>>> mc2.get("foo")
'da'

结果表明:分布式memcache中只有一条记录,并且记录在第二台虚拟机的memcache上。此时运行:

>>> mc3.get("foo")
'da'

一切都十分正常


现在强行关闭其中一台memcache,再运行相同的命令,去查找刚才插入的值,结果如下:

>>> mc3.get("foo")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
_pylibmc.UnknownReadFailure: error 7 from memcached_get: UNKNOWN READ FAILURE


>>> mc3.set("foo","fe")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
_pylibmc.UnknownReadFailure: error 7 from memcached_set: UNKNOWN READ FAILURE


>>> mc3.set("fes","fe")
True


mc3将找不到第二台memcache而返回异常,也不能设置已经设置过的值(没设置过的值是可以的)整个系统还能继续工作。

>>> mc3.set("fe","er")
True

此时我们再重启被关掉的memcache
>>> mc3.get("foo")
>>>

已经不能找到当初设的值,但是系统也不会再抛异常




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值