测试环境:两台配置完全的虚拟机,用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")
>>>

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




Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐