Using Redis to store php session

Using Redis to store php session



默认情况下,php将会将session信息存储在文件系统上,在单机情况下没有问题,但是当系统负载增大,或者在对系统可用性要求很高的场景下,当台机器不仅处理能力跟不上,而且当机器故障时整个系统就处于不可用状态了。所以多机器负载均衡就非常有必要了。
但是问题来了,假设现在系统有两台应用服务器serverA,serverB,用户X现在已经登录了,而登录状态众所周知是存储在应用服务器的session中的,如果用户X的登录请求是serverA响应的,那么其登录状态是存储在serverA上的,当用户X的下一个请求被转发给serverB时,serverB是会认为用户X尚未登录,因为他没有存储用户X的session信息。
当然你可以将负载均衡设置为,将相同IP的访问请求均转发给同一个服务器,但是这种方案并不完美,可以设想这样一种情形,应用服务器serverA进程死掉了,那么在serverA上登录的所有用户就无法正常访问服务了。
所以只有能够在多台应用服务器之间共享存储session才能够解决这一问题,而现有的常见的解决方案就使用memcache,redis来存储session。

windows下配置php+redis

1. 安装redis服务器

下载地址  Redis.msi
如果下载的非安装版,则需要通过命令行来启动,redis服务,而且命令行窗口不可以关闭,否则服务会关闭

redis-server.exe redis.conf

如果选择的是msi安装版,安装后会在windows服务中看到redis服务,默认是自动启动的,命令行去到安装目录,运行redis-cli.exe可以通过命令行来操作redis的读写。

keys *  //列出所有的键。
get "phpredis_session:xxxxxxxxxxxxx" //获取指定键的值
flushdb //清除所有的键值对。

redis.conf文件中可以配置redis-server的相关参数。

2. 安装php_redis扩展

2.1. 通过phpinfo()查看php编译脚本。

2.2. 下载与编译脚本一致的php_redis扩展

一定要一致,否则无法使用
下载地址php_redis extension

ts(thread safe), nts(thread not safe).

2.3. 将下载的php_redis.dll放在php扩展目录中(ext).

3. 配置php.ini添加扩展

extension=php_redis.dll

4. 重启apache服务,查看phpinfo()出现redis块表示成功。

5 设置php.ini的session存储模式

session.save_handler = redis

session.save_path=“tcp://127.0.0.1:6379”;

如果有多台redis服务器可以设置为:
session.save_path=“tcp://10.10.0.1:6379?weight=4,tcp://10.10.0.2:6379?weight=6”

6 测试

测试php代码

$redis = new Redis();
$redis->connect(“127.0.0.1","6379");  //php客户端设置的ip及端口
//存储一个 值
$redis->set("say","Hello World");
echo $redis->get("say");     //应输出Hello World  

//存储多个值
$array = array(‘first_key‘=>‘first_val‘,
          ‘second_key‘=>‘second_val‘,
          ‘third_key‘=>‘third_val‘);
$array_get = array(‘first_key‘,‘second_key‘,‘third_key‘);
$redis->mset($array);
var_dump($redis->mget($array_get));

命令行查看结果

redis-cli.exe

keys * 

CentOS下配置php+redis

1. 安装redis服务器

下载redis-server代码并安装

mkdir /tmp/redis
cd /tmp/redis
wget http://download.redis.io/releases/redis-2.8.8.tar.gz
tar xzf redis-*
cd redis-*

make
sudo make install clean

##copy configure file
mkdir /etc/redis
cp redis.conf /etc/redis/redis.conf

配置文件示例

#start as a daemon in background
daemonize yes
#set port, by default is 6379
port 6379
#set ip on which daemon will be listening for connections
bind 127.0.0.1
#where to dump database
dir /var/opt

检查服务安装位置:

whereis redis-server
#redis-server: /usr/local/bin/redis-serve

设置redis-server跟随系统启动

vi /etc/rc.local
#在exit 0之前插入如下命令
/usr/local/bin/redis-server /etc/redis/redis.conf
#开启服务
redis-server /etc/redis/redis.conf
#连接服务
redis-cli

2. 安装php_redis扩展

下载php-redis扩展并安装

cd /tmp
wget https://github.com/nicolasff/phpredis/zipball/master -O phpredis.zip
unzip phpredis.zip
cd phpredis-*
phpize
./configure
make && make install

3. 配置php.ini

插入redis配置

session.save_handler = redis
session.save_path = "tcp://10.44.64.8:6379"
extension=redis.so

设置完成。

时间: 2024-10-12 19:05:27

Using Redis to store php session的相关文章

PHP中Redis替代文件存储Session语句

php默认使用文件存储session,如果并发量大,效率非常低.而Redis对高并发的支持非常好,所以,可以使用redis替代文件存储session. 这里,介绍下php的 session_set_save_handler 函数的作用和使用方法.该函数定义用户级session保存函数(如打开.关闭.写入等).原型如下: bool session_set_save_hanler(callback open,callback close,callback read,callback write,ca

nginx+tomcat+redis负载均衡及session共享

概述 本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.org/download/nginx-1.6.0.tar.gz 负载均衡 commons-pool-2-2.4.2.jar http://mirrors.hust.edu.cn/apache//commons/pool/binaries/commons-pool2-2.4.2-bin.tar.gz j

用redis实现跨服务器session(转)

这个月我们新开发了一个项目,由于使用到了4台机器做web,使用dns做负载均衡, 上面图上用户通过DNS的调度(一个域名对应多个ip)分别访问到VM2-VM5上,四台机器都访问VM1上的redis,两个redis值主从结构. 因此需要使用跨服务器的session保存用户登录状态,于是我写了一个跨站的session共享的类 点击(此处)折叠或打开 <?php /* *用redis实现跨服务器session *注意需要安装phpredis模块 * *作者:yifangyou *日期:2012-07-

nginx+tomcat集群+redis(memcache)session共享!

nginx+tomcat+redissession共享 常用保持session的方式: 1.一些代理(比如nginxIP_hash) 1.使用数据库来存储Session 2.使用Cookie来存储Session                       3.使用Redis来存储Sesssion(memcache也可以) --   环境: 192.168.1.220   nginx    centos6.6   端口:80 版本:1.9.2 192.168.1.224   tomcatA  ce

nginx之 nginx + tomcat + redis 负载均衡且session一致性

说明: 本文描述的是 nginx + tomcat + redis 实现应用负载均衡且满足session一致性,从安装到配置的全部过程,供大家学习!nginx 代理服务器ip: 10.219.24.26tomcat_1 应用服务器ip与端口: 10.219.24.21:8080 tomcat_2 应用服务器ip与端口: 10.219.24.21:8081redis 缓存服务器ip: 10.219.24.23 一. nginx-1.9.7 编译安装 下载地址: http://nginx.org/d

Redis简单案例(四) Session的管理

负载均衡,这应该是一个永恒的话题,也是一个十分重要的话题.毕竟当网站成长到一定程度,访问量自然也是会跟着增长,这个时候, 一般都会对其进行负载均衡等相应的调整.现如今最常见的应该就是使用Nginx来进行处理了吧.当然Jexus也可以达到一样的效果.既然是 负载均衡,那就势必有多台服务器,如果不对session进行处理,那么就会造成Session丢失的情况.有个高大上的名字叫做分布式Session. 举个通俗易懂的例子,假设现在有3台服务器做了负载,用户在登陆的时候是在a服务器上进行的,此时的se

为Tornado框架加上基于Redis或Memcached的session 【第三方】

Tornado 没有session,只有cookie_secret,这在一些情况下是不利于开发的.所有我们可以给Tornado加上session的功能. 这篇文章讲解的是依靠第三方包来实现.以后的文章我们还可以自己写一套. 以下为步骤: 1,安装包pycket $ pip install pycket 2,使用时引入包 from pycket.session import SessionMixin 3,通过Handler传入(还可以创建一个BaseHandler,将其封装到BaseHandler

nginx+tomcat+redis的集群+session共享

环境准备 1.tomcat版本:tomcat7 tomcat下载及安装,目前很多好的资源和步骤,此处省略. 2.jdk版本:jdk1.7 jdk下载及安装,目前很多好的资源和步骤,此处省略. 3.redis版本以及下载地址.安装步骤 wget http://download.redis.io/redis-stable.tar.gztar xvzf redis-stable.tar.gzcd redis-stablemake 前面3步应该没有问题,主要的问题是执行make的时候,出现了异常.异常一

spring+redis+nginx 实现分布式session共享

1,spring 必须是4.3以上版本的 2,maven配置 添加两个重要的依赖 <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> <version>1.2.2.RELEASE</version> <type>pom</type>