嘿家伙存储会话,我设置了一个负载平衡器EC2集群。我有单独的数据库服务器上运行的MySQL。我有3个Web服务器正在运行,主要是为了获得高可用性,当然它的循环负载均衡似乎是这样,所以每个页面都会有一个不同的服务器,这会让您的会话失去。PHP - 在一个数据库
我想安装PHP将其存储在数据库中。我已经安装了一个表格,并设置了所有功能(打开,关闭等)。我已经设置:
session_set_save_handler('_open',
'_close',
'_read',
'_write',
'_destroy',
'_clean');
但是,当我登录或任何网站上我检查表,什么也没有写。我不确定如果我需要更改php.ini文件中的某些内容。如果是的话,改变的价值是什么?
谢谢!
编辑:功能:
function _open(){
global $con;
connect();
}
function _close(){
global $con;
//mysql_close();
}
function _read($id){
global $con;
$id = mysql_real_escape_string($id);
$sql = "SELECT data FROM sessions WHERE id = '$id'";
if ($result = mysql_query($sql, $con)) {
if (mysql_num_rows($result)) {
$record = mysql_fetch_assoc($result);
return $record['data'];
}
}
return '';
}
function _write($id, $data)
{
global $con;
$access = time();
$id = mysql_real_escape_string($id);
$access = mysql_real_escape_string($access);
$data = mysql_real_escape_string($data);
$sql = "REPLACE
INTO sessions
VALUES ('$id', '$access', '$data')";
return mysql_query($sql, $con);
}
function _destroy($id)
{
global $con;
$id = mysql_real_escape_string($id);
$sql = "DELETE
FROM sessions
WHERE id = '$id'";
return mysql_query($sql, $con);
}
function _clean($max)
{
global $con;
$old = time() - $max;
$old = mysql_real_escape_string($old);
$sql = "DELETE
FROM sessions
WHERE access < '$old'";
return mysql_query($sql, $con);
}
session_set_save_handler('_open',
'_close',
'_read',
'_write',
'_destroy',
'_clean');
你可以发布有问题的功能吗?他们是在一个班,他们是独立的职能,等等... – 2011-03-13 18:43:57
刚刚编辑帖子,谢谢:) – 2011-03-13 18:48:32