PHP中redis作为mysql的缓存服务器(读写分离)

本文介绍了一种使用PHP和Redis进行数据缓存与同步的方法。通过对比数据库查询与Redis缓存读取的方式,实现了高效的数据获取流程。具体涵盖了如何初始化Redis连接、设置及获取缓存数据,并在缓存失效时回退至数据库查询,确保数据的一致性和应用的高性能。
<?php
header("content-type:text/html;charset=utf8");

///version 1

// get data
//   $redis = new Redis();
//   $redis->connect('127.0.0.1', 6379);
//   $arr = $redis->get('data_from_class_all');


// if(!empty($arr)){
//   $data = $arr;
// }else{
//   $dsn = "mysql:host=localhost;dbname=cai";
//   $db = new PDO($dsn, 'root', 'root');
//   $db->query("set names utf8");
//   $data=$db->query('select * from `class`')->fetchAll(PDO::FETCH_ASSOC);

//   if(!empty($data)){
//     $redis->set('data_from_class_all',$data);
//   }
// }
//



/// version 2
$data = getData();
// print_r($data);die;

// 获取数据
function getData(){
  // to do somthing...
  $redisObj = getRedisInstance();
  $redisData = getRedisStr($redisObj, 'data_from_class_all');
  if(!empty($redisData)){
    $data = $redisData;
  }else{
    $db = getMysqlInstance();
    $data = getMysqlDataAll($db);
    if(!empty($data)){
      setRedisStr($redisObj, 'data_from_class_all', serialize($data));
    }
  }

  return $data;
}

// 获取redis实例
function getRedisInstance(){
  $redis = new Redis();
  $redis->connect('127.0.0.1', 6379);

  return $redis;
}

// 设置Redis的string类型值
function setRedisStr($redisObj, $redisKey, $data){
  $redisObj->set($redisKey,$data);
}


// 获取Redis的string类型值
function getRedisStr($redisObj, $redisKey){
  $redisData = $redisObj->get($redisKey);
  return unserialize($redisData);
}

// 获取mysql的实例
function getMysqlInstance(){
  $dsn = "mysql:host=localhost;dbname=cai";
  $db = new PDO($dsn, 'root', 'root');
  $db->query("set names utf8");

  return $db;
}

// 获取mysql的数据
function getMysqlDataAll($db){
  return $db->query('select * from `class`')->fetchAll(PDO::FETCH_ASSOC);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值