集群环境中一般是用的session复制来同步各个server中的session,但是如果集群中server很多的话会引起session复制风暴。
Memcached 将session放在一个地方,就不存在session复制的问题了。
但是memcached那台机器down了话,则session就不可用了, zookeeper解决了这个问题将memcached进行复制
--------------
ehcache也可以支持分布式缓存,(默认是单机缓存,在集群环境下命中率不高)
memcached服务端是基于C语言的高性能集中式缓存组件,客户端支持多种语言如java, c, php等
缓存只能存储在内存中,与分布式不同的是,集中式缓存为每个应用节点提供统一的缓存服务,因此
每个应用节点不涉及缓存同步问题。
使用Memcached实现Session共享
由于Cookie是保存的用户客户端的,安全性存在问题,为保证用户数据的安全性,我们必须使用Session机制来保存用户登录后的一些信息。
如果我们使用LVS对Apache实现负载均衡,就无法保证用户每次都能被分配到同一台Apache Server上,以取到自己的Session,虽然LVS可以加-p参数来保证客户端每次都被分配到同一台Apache Server上,但这种方式存在一些弊端,比如必须设置一个保持时间,如果时间太长了,LVS就需要缓存大量信息,时间太短了,又不能保证用户每次被分配到同一台Server上,而且这种方式也不易实现Session的冗余备份。
因此,我们需要Session共享,也就是说每台Apache都可以访问到所有的Session,这样用户被分配到哪台Server就不重要了。
Session共享主要有多种实现方式:
Session复制。Apache可以实现把Session同步到其他Server上去,但这种技术太复杂,而且影响性能,占用内存,所以不推荐使用。
Session集中存储。存储介质可以是NFS文件系统、数据库、Memcached,从性能上考虑,当然是Memcached最好,推荐使用。
Memcached 将session放在一个地方,就不存在session复制的问题了。
但是memcached那台机器down了话,则session就不可用了, zookeeper解决了这个问题将memcached进行复制
--------------
ehcache也可以支持分布式缓存,(默认是单机缓存,在集群环境下命中率不高)
memcached服务端是基于C语言的高性能集中式缓存组件,客户端支持多种语言如java, c, php等
缓存只能存储在内存中,与分布式不同的是,集中式缓存为每个应用节点提供统一的缓存服务,因此
每个应用节点不涉及缓存同步问题。
使用Memcached实现Session共享
由于Cookie是保存的用户客户端的,安全性存在问题,为保证用户数据的安全性,我们必须使用Session机制来保存用户登录后的一些信息。
如果我们使用LVS对Apache实现负载均衡,就无法保证用户每次都能被分配到同一台Apache Server上,以取到自己的Session,虽然LVS可以加-p参数来保证客户端每次都被分配到同一台Apache Server上,但这种方式存在一些弊端,比如必须设置一个保持时间,如果时间太长了,LVS就需要缓存大量信息,时间太短了,又不能保证用户每次被分配到同一台Server上,而且这种方式也不易实现Session的冗余备份。
因此,我们需要Session共享,也就是说每台Apache都可以访问到所有的Session,这样用户被分配到哪台Server就不重要了。
Session共享主要有多种实现方式:
Session复制。Apache可以实现把Session同步到其他Server上去,但这种技术太复杂,而且影响性能,占用内存,所以不推荐使用。
Session集中存储。存储介质可以是NFS文件系统、数据库、Memcached,从性能上考虑,当然是Memcached最好,推荐使用。