session redis memcache mysql

本文介绍如何使用Redis和Memcache进行缓存操作,并展示了如何通过MySQL实现自定义会话管理。文中提供了PHP代码示例,包括连接配置、数据存取及会话处理等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、redis

首先要安装redis服务 开启扩展  在redis根目录F:\redis\redis-2.4.5-win32-win64\32bit用cmd运行redis_server.exe
     //连接本地的 Redis 服务
   $redis = new Redis();
   $redis->connect('127.0.0.1', 6379);
   echo "Connection to server sucessfully";
         //查看服务是否运行
   echo "Server is running: " . $redis->ping();
   //存入redis
   echo $redis->set('a','aaabbbbbbbbbbbbbbbbbb');
   //取出
   echo $redis->get('a');

    //存储多个值  

    $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));  

2、memcache

<?php
ini_set("session.save_handler", "memcache");
ini_set("session.save_path", "127.0.0.1:11211");

//测试session读取是否正常   2 3 6 9 行是最重要的
session_start();
//$_SESSION['username'] = "1222";
//echo session_id();
echo $_SESSION['username'];

//从Memcache中读取session
$m = new Memcache();
$m->connect('localhost', 11211);



//或者这样
//$mem->addServer("127.0.0.1", 11211) or die ("Can't add Memcache server 127.0.0.1:12000");

//根据session_id获取数据

//本机
//$session = $m->get(session_id()); //session_id:d527b6f983bd5e941f9fff318a31206b

//另一台服务器,已知session id
//$session = $m->get("jk51p6mccprn886vlgacjrh9u2");

//echo $session."<br/>"; //会得到这样的数据:username|s:16:"pandao";,解析一下就可以得到相应的值了
//echo session_id()."<br/>";
exit;

?>

3、mysql

<?php  
ini_set("session.save_handler","user");    
//session.gc_probability = 1 分子    
ini_set("session.gc_probability",1);    
//session.gc_divisor = 1000 分母    
ini_set("session.gc_divisor",2);    
//session.gc_maxlifetime = 1440 垃圾回收时间,session有效期    
session_set_save_handler( "open","close","read","write","destroy","gc" );  
//连接数据库    
function open(){    
    @$link = mysql_connect('localhost', 'root', 'root');    
    mysql_query('set names utf8');    
    mysql_query('use yii');    
}    
function close(){    
    mysql_close();    
}    
function read($sess_id){    
    $sql = "select session_data from `session` where session_id = '$sess_id'";    
    $result = mysql_query($sql);    
    if($rows = mysql_fetch_assoc($result)){  
        return $rows['session_data']; }  
    else{  
        return '';  
    }    
}    
function write($sess_id,$sess_data){    
    $sql = "insert into `session` (session_id,session_data,session_time) values('$sess_id','$sess_data', now()) on duplicate key update session_data = '$sess_data' , session_time = now()";  //这是为了gc()    
    return mysql_query($sql);    
    
}    
function destroy($sess_id){    
    echo __FUNCTION__;    
    $sql = "delete from `session` where session_id = '$sess_id'";    
    return mysql_query($sql);    
    
}    
function gc($sess_id){    
    $maxlifetime = ini_get("session.gc_maxlifetime");    
    echo __FUNCTION__;    
    $sql = "delete from `session` where now()-session_time > '$maxlifetime' ";    
    return mysql_query($sql);    
}    
header("content-type:text/html;charset=utf8");    
session_start();    
$_SESSION['name']='aabbcc';
$_SESSION['sex']='yyyuuu';   
//echo session_id();    
echo $_SESSION['sex'];   


内容概要:本文介绍了多种开发者工具及其对开发效率的提升作用。首先,介绍了两款集成开发环境(IDE):IntelliJ IDEA 以其智能代码补全、强大的调试工具和项目管理功能适用于Java开发者;VS Code 则凭借轻量级和多种编程语言的插件支持成为前端开发者的常用工具。其次,提到了基于 GPT-4 的智能代码生成工具 Cursor,它通过对话式编程显著提高了开发效率。接着,阐述了版本控制系统 Git 的重要性,包括记录代码修改、分支管理和协作功能。然后,介绍了 Postman 作为 API 全生命周期管理工具,可创建、测试和文档化 API,缩短前后端联调时间。再者,提到 SonarQube 这款代码质量管理工具,能自动扫描代码并检测潜在的质量问题。还介绍了 Docker 容器化工具,通过定义应用的运行环境和依赖,确保环境一致性。最后,提及了线上诊断工具 Arthas 和性能调优工具 JProfiler,分别用于生产环境排障和性能优化。 适合人群:所有希望提高开发效率的程序员,尤其是有一定开发经验的软件工程师和技术团队。 使用场景及目标:①选择合适的 IDE 提升编码速度和代码质量;②利用 AI 编程助手加快开发进程;③通过 Git 实现高效的版本控制和团队协作;④使用 Postman 管理 API 的全生命周期;⑤借助 SonarQube 提高代码质量;⑥采用 Docker 实现环境一致性;⑦运用 Arthas 和 JProfiler 进行线上诊断和性能调优。 阅读建议:根据个人或团队的需求选择适合的工具,深入理解每种工具的功能特点,并在实际开发中不断实践和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值