以下以默认情况举例:
session_start();之后,会生成一个唯一的session_id,每一个用户对应唯一一个session_id,每一个session_id对应服务器端的一个session文件。这个session文件存储着当前session_id的信息,比如下面,就存储了name和age的键值。
1、设置Session存储的引擎(本地服务器的文件还是redis等),【php.ini 文件】
[Session]
session.save_handler = files
session.save_path = /data/SessionLogs
2、默认情况下的Session的使用
";
$_SESSION['age'] = 26;
$_SESSION['name'] = 'xiaobudiu';
var_dump($_SESSION);
3、在服务器中存储的形式是这样的
在网站访问量较大时,我们通常会做集群(比如nginx负载均衡等),这时,如何解决session会话的共享问题。
(1)使用ip_hash或者自定义key做负载均衡轮询策略是一个办法,但由于有时候用户可能走代理,所以这个方法其实并不是那么完美。
(2)另一个解决session共享问题的方法就是使用redis或者memcache缓存数据库去存储session,进而实现session共享问题。
1、设置php.ini 文件中的session.save_handle 和session.save_path
session.save_handler = Redis
session.save_path = "tcp://localhost:6379"
注1:如果连接的是远程redis,需要将localhost换成对应的远程ip地址。像这样,
session.save_handler = Redis
session.save_path = "tcp://47.94.203.119:6379"
注2:如果为redis已经添加了auth权限(requirpass),session.save_path项则应该这样写
session.save_handler = Redis
session.save_path = "tcp://47.94.203.119:6379?persistent=1&database=10&auth=myredisG506"
2、使用redis存储session信息
";
$_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
封装session类 b.php
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
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中显示: