Memcache分布式存储测试
测试环境:两台配置完全的虚拟机,用python进行测试memcache和python以及相关软件的下载安装请参考上一篇文章:http://blog.csdn.net/lrenjundk/article/details/7179889在两台虚拟机上都启动了memcache进程:memcached -d -m 100 -u root -p 12345 -c 256 -P /tmp/
测试环境:两台配置完全的虚拟机,用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)