我已经尝试了php-memcache和php-memcached,如果其中一台服务器发生故障,它们都无法正常运行.我的最新尝试是使用此配置:
memcached 2.2.0版配置设置:
session.save_handler = memcached session.save_path = "172.29.104.13:11211,172.29.104.14:11211"
除了extension = memcached.so之外,我在memcached.ini中没有什么特别之处.
在服务器1和2上都进行了这种配置(我暂时删除了3个以进行测试),我将JMeter指向F5 VIP并启动流量.我可以在两个系统上看到memcached.log(守护进程),但没有花时间去破译,开始运行.
然后,如果我停止其中一个memcached守护进程,流量开始失败并返回
session_start():写入锁定失败
由留下的memcached留下.
在一天结束时,我的目标很简单 – 我需要能够a)不在单个服务器上运行memcached(单点故障),并且集群需要能够适应池成员的故障.
我也试过php-memcache但它也失败了.对于php-memcache,配置如下所示:
带有配置设置的memcache 3.0.8版(测试版):
session.save_handler = memcache session.save_path = "tcp://172.29.104.13:11211,tcp://172.29.104.14:11211"
在memcache.ini中:
extension=memcache.so [memcache] memcache.dbpath="/var/lib/memcache" memcache.maxreclevel=0 memcache.maxfiles=0 memcache.archivememlim=0 memcache.maxfilesize=0 memcache.maxratio=0 memcache.hash_strategy=consistent memcache.allow_failover=1 memcache.session_redundancy=2
这里的错误只是无效的会话令牌(暗示我剩下的服务器实际上没有存储会话令牌,这意味着保存会话的复制没有激活).
我没有考虑将会话持久性放回到F5上,但作为最后的手段,我可以这样做,并且尝试连接到丢失的成员的客户端将不得不重新进行身份验证.
对于一个实现,请参见https://github.com/ascorbic/php-stateless-cookies,还有许多其他实现.请注意,会话数据应加密,但必须通过HMAC或AEAD密码进行身份验证.除非你是密码学家,否则不要自己编写这段代码;使用经过严格审查的cryoto库.
Facebook使用这种技术,因此即使用户会话在另一个数据中心启动,任何服务器都可以回答任何用户请求.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。