一、Session的原理
以下以默认情况举例:
session_start();之后,会生成一个唯一的session_id,每一个用户对应唯一一个session_id,每一个session_id对应服务器端的一个session文件。这个session文件存储着当前session_id的信息,比如下面,就存储了name和age的键值。
1、设置Session存储的引擎(本地服务器的文件还是redis等),【php.ini 文件】
[Session]session.save_handler = filessession.save_path = /data/SessionLogs
2、默认情况下的Session的使用
<?php
/*** session的使用* 默认情况(不更改session.save_handle参数时),是存储在文件file中的* 默认情况下使用session的情况(用户24分钟内没有刷新操作会过期)* 每个用户对应唯一session_id,每一个session_id对应服务器中存储的一个session文件,这个文件中存储了当前session_id的信息,比如下面,就存储了name和age的键值*/
session_start();
echo session_id();
echo "<br>";
$_SESSION['age'] = 26;
$_SESSION['name'] = 'xiaobudiu';
var_dump($_SESSION);
3、在服务器中存储的形式是这样的
二、使用Redis存储Session
在网站访问量较大时,我们通常会做集群(比如nginx负载均衡等),这时,如何解决session会话的共享问题。
(1)使用ip_hash或者自定义key做负载均衡轮询策略是一个办法,但由于有时候用户可能走代理,所以这个方法其实并不是那么完美。
(2)另一个解决session共享问题的方法就是使用redis或者memcache缓存数据库去存储session,进而实现session共享问题。
1、设置php.ini 文件中的session.save_handle 和session.save_path
session.save_handler = Redissession.save_path = "tcp://localhost:6379"
注1:如果连接的是远程redis,需要将localhost换成对应的远程ip地址。像这样,
session.save_handler = Redissession.save_path = "tcp://47.94.203.119:6379"
注2:如果为redis已经添加了auth权限(requirpass),session.save_path项则应该这样写
session.save_handler = Redissession.save_path = "tcp://47.94.203.119:6379?persistent=1&database=10&auth=myredisG506"
2、使用redis存储session信息
<?php
/*** 将session存储在redis中*/
session_start();
echo session_id();
echo "<br>";
$_SESSION['age'] = 26;
$_SESSION['name'] = 'xiaobudiu';
$_SESSION['sex'] = 'man';
var_dump($_SESSION);
在redis上是以这样的形式进行存储的
注:
搭建nginx集群: https://blog.csdn.net/m_nanle_xiaobudiu/article/details/80862272
搭建mysql主从复制架构:https://blog.csdn.net/m_nanle_xiaobudiu/article/details/81086243
搭建redis集群: https://blog.csdn.net/m_nanle_xiaobudiu/article/details/81004557
三、使用Redis存储Session,并设置Session会话存活时间以及Session中某一元素存活时间
封装session类 b.php
<?php/*** session控制类**/class Session
{function __construct($lifetime = 3600){//初始化设置session会话存活时间ini_set('session.gc_maxlifetime',$lifetime);}/*** 设置当前会话session的key-value* @param String $name session name* @param Mixed $data session data* @param Int $expire 有效时间(秒)*/function set($name, $data, $expire = 600){$session_data = array();$session_data['data'] = $data;$session_data['expire'] = time()+$expire;$_SESSION[$name] = $session_data;}/*** 读取当前会话session中的key-value* @param String $name session name* @return Mixed*/function get($name){if(isset($_SESSION[$name])) {if($_SESSION[$name]['expire'] > time()) {return $_SESSION[$name]['data'];}else{self::clear($name);}}return false;}/*** 清除当前session会话中的某一key-value* @param String $name session name*/function clear($name){unset($_SESSION[$name]);}/*** 删除当前session_id对应的session文件(清空当前session会话存储)*/function destroy(){session_destroy();}}
session类的使用:d.php
<?phprequire_once 'b.php';session_start();$session = new Session();
$session->set('wan','kkkk',1966);$session->set('name','xiaobudiu');
$session->set('age',26);
$session->set('sex','man');//输出当前会话的session存储数据
var_dump($_SESSION);//unset掉某一个session属性
//$session->clear('name');//删除当前session_id对应session文件
//$session->destroy();
//echo $session->get('sex');
redis中显示: