php+redis实现多台服务器内网存储session并读取
来源:互联网 发布:最好的数据统计软件 编辑:程序博客网 时间:2024/05/16 17:19
大型网站由于大并发的问题会导致系统出现诡异的崩溃性问题这着实让人很是蛋疼,首先考虑的就是负载均衡服务器来处理这个,当然数据库的性能也是非常非常重要的,今天就说下在负载均衡情况下对于session这个问题如何处理,说实话不处理session其实也是可以的,但是在实际的情况中会出现一些让用户体验非常蛋疼的问题,比如购物下单的时候负载均衡调配服务器来回切换的过程中session丢失了,这个时候就尴尬了,用户就会郁闷我擦这什么鬼,于是乎各种担心就会出现,这破网站是不是有什么安全问题等等。下面就来说说这个问题的解决方案,配置php结合redis来存储session,假如我现在有2个(至少)服务器在做负载均衡:
1,主服务器安装php-redis 以及redis服务器端这个不多说去执行命令行yum或apt-get什么的,辅服务器只需要安装php-redis(这两个服务器必须在一个内网中不然外网访问着实不安全的)
2,来吧骚年打开的你服务器上的php.ini文件:
先看看php extension=redis.so是否开启
session.save_handler = redis
session.save_path = "tcp://【redis主服务器的内网ip】:6379″
主和辅服务器的php-redis需要绑定一下ip(ip一致主服务器的redis-server)
redis.conf
bind【redis主服务器的内网ip】
这个为了安全起见设置一个redis链接的密码:
打开 vim /etc/redis/redis.conf
requirepass 通信密码(修改这里)
ok配置好重启redis :sudo service redis-server restart
3,测试Redis连接和验证:
redis-cli -h 【redis主服务器内网ip】
如果设置了redis链接密码,现在尝试访问数据,应该得到一个AUTH错误接下来执行下
> redis-cli
redis内网ip:6397> keys *
ok了到这步的时候已经完成99%了还差一步就是各种重启额
service apache2 restart
service php5-fpm restart
4,测试session是否写入redis:
<?php session_start();$_SESSION['bieanju'] = array('name' => '别安驹', 'num' => 'http://www.bieanju.com/');//连接redis$redis = $this->connectRedis();////检查session_idecho 'session_id:' . session_id() . '<br/>';//redis存入的session(redis用session_id作为key,以string的形式存储)echo 'redis_session:' . $redis->get('PHPREDIS_SESSION:' . session_id()) . '<br/>';echo 'php_session:' . json_encode($_SESSION['class']);print_r($_SESSION['bieanju']);
?>
速来围观,没错session写入redis了可以读取了,ok至此对于负载均衡的session也就基本解决了,剩下的就是在项目如何应用那就看你自己的业务需要。
最后在说一下php是世界上最好的语言,呵呵……
- php+redis实现多台服务器内网存储session并读取
- php+redis实现多台服务器内网存储session并读取
- php多台服务器怎样实现session共享2:写入redis
- PHP实现redis存储session
- 实现多台服务器SESSION跨域——php
- PHP 实现多台服务器共用SESSION方案?
- 用redis实现跨服务器存储session
- PHP多台服务器如何共享session
- php Redis存储Session
- php多台服务器怎样实现session共享1:写入数据库
- PHP多台服务器跨域SESSION共享
- PHP多台服务器跨域SESSION共享
- php多台服务器跨域session共享
- PHP多台服务器跨域SESSION共享
- 多台memcache服务器(ubuntu)实现session共享
- 多台服务器共享session
- Redis SpringSession+Redis实现分布式Session存储
- PHP+Redis实现Session共享
- 简记tp的一个小知识点
- Spring--IoC--基于XML的DI-为应用指定多个配置文件-平等关系
- 获取全局Context
- (转)WinForm实现在服务器端创建文件夹
- 怎么查询馋乐比的生产日期?
- php+redis实现多台服务器内网存储session并读取
- 字符串的全排列
- springcloud 中使用eureka/ribbon/Hystrix负载均衡及断路器
- ios 截取view上内容 返回image 保证清晰度
- hadoop 2.8 简单数字排序
- static--修饰(局部变量、全局变量、函数)
- ajax 分页完全代码整理
- 最大子段和问题(dp大法)
- 前端之css遇到的问题