【发布时间】:2014-09-17 03:43:21
【问题描述】:
我已经设置了几个 Memcached 服务器用作 PHP 会话存储,但尽管尝试了各种设置,但我无法让会话密钥出现在两个服务器中。
我的php.ini如下:
session.save_handler = memcached
session.save_path = "192.168.134.38:11211,192.168.134.234:11211"
我的 memcached.ini 是:
extension=memcached.so
memcached.sess_consistent_hash=1
memcached.sess_number_of_replicas=1
memcached.sess_binary=1
如果我使用 -vv 运行 memcached,我可以看到密钥正在写入第一台服务器:
<30 new auto-negotiating client connection
30: Client using the binary protocol
<30 Read binary protocol data:
<30 0x80 0x0c 0x00 0x28
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x28
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 GET memc.sess.key.9bn8cdu9c1j7ko1tmflgr433k1
>30 Writing bin response:
>30 0x81 0x0c 0x00 0x28
>30 0x04 0x00 0x00 0x00
>30 0x00 0x00 0x03 0xc6
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
<30 Read binary protocol data:
<30 0x80 0x01 0x00 0x28
<30 0x08 0x00 0x00 0x00
<30 0x00 0x00 0x03 0xcb
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 SET memc.sess.key.9bn8cdu9c1j7ko1tmflgr433k1 Value len is 923
>30 Writing bin response:
>30 0x81 0x01 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x05
<30 Read binary protocol data:
<30 0x80 0x07 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
<30 0x00 0x00 0x00 0x00
>30 Writing bin response:
>30 0x81 0x07 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
>30 0x00 0x00 0x00 0x00
<30 connection closed.
但是第二台服务器只是连接/断开连接,但没有存储任何内容:
<30 new auto-negotiating client connection
30: Client using the ascii protocol
<30 quit
<30 connection closed.
因此,一旦您终止第一个服务器会话,就会丢失并且没有故障转移。
有人知道这里发生了什么吗?
编辑:
我们在不同的浏览器中创建了几个会话,看起来密钥正在分发,但没有复制。
服务器 1:
stats cachedump 12 100
ITEM memc.sess.key.80iie5lhm36mddkekdk488q923 [922 b; 1406287763 s]
服务器 2:
stats cachedump 12 100
ITEM memc.sess.key.ehd1nsm6icc2qsotbkcp8i9sd7 [874 b; 1406287898 s]
ITEM memc.sess.key.d3p0id333ggbd0004n4rcc4890 [875 b; 1406287868 s]
ITEM memc.sess.key.7hek9e2aakgqv9sm2bcq5fbfb3 [922 b; 1406287842 s]
【问题讨论】: