Redis 分布式缓存,是如何实现多台服务器SESSION 实时共享的
Posted hcfinal
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis 分布式缓存,是如何实现多台服务器SESSION 实时共享的相关的知识,希望对你有一定的参考价值。
现在提到多服务器的共享session,几乎都是回答用redis。
对于redis实现几台服务器共享session,不是很理解。
假如一个网站分别部署在A B C 3 台服务器上,他们的代码都是相同的。用户在访问的过程中是随机切换到其他服务器
,使用redis来共享session,那么是这3台服务器是如何实现session 实时共享的?
首先要明确session和cookie的区别。浏览器端存的是cookie每次浏览器发请求到服务端是http 报文头是会自动加上你的cookie信息的。服务端拿着用户的cookie作为key去存储里找对应的value(session).
同一域名下的网站的cookie都是一样的。所以无论几台服务器,无路请求分配到哪一台服务器上同一用户的cookie是
不变的。也就是说cookie对应的session也是唯一的。
只要保证多台业务服务器访问同一个redis服务器(或集群)就行了。
将REDIS 另外的部署到第四台服务器D, A B C 三台服务器上的php配置连接的REDIS是这台D服务器。那么就实现了统一的SESSION 实时共享,
PHP设置Session共享(php.ini 配置redis)
如果你使用的是PHP那么恭喜你,配置非常的简单。PHP通过两行配置就可以把Session存放在Memcached或者Redis中,当然你要提前配置好他们。修改php.ini:
session.save_handler = memcache
session.save_path = "tcp://192.168.56.11:11211"
使用Redis存储Session
session.save_handler = redis # 默认的设置是file,这里改成redis session.save_path = "tcp://192.168.2.11:6379?auth=passwd" # 这里填redis的连接配置参数 ;session.save_path = "tcp://192.168.2.11:6379" # 如果redis不带密码,则使用这种配置 ;session.save_path = "tcp://127.0.0.1:6379" # 如果redis不带密码,则使用这种配置
上面这个redis的session_save_path的路径可以写成具体的一个ip地址。这样就实现session共享了。
以上是关于Redis 分布式缓存,是如何实现多台服务器SESSION 实时共享的的主要内容,如果未能解决你的问题,请参考以下文章
缓存系列面试题Redis 集群模式的工作原理能说一下么?key 是如何寻址的?分布式寻址都有哪些算法?