专栏首页木头编程 - moTzxxRedis 在PHP中的使用笔记

Redis 在PHP中的使用笔记

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/details/79403675

♩ 背景

  • Redis 对于程序开发者来说,拥有很大的优势,能学好这些重点知识一定能提高我们的能力,所以闲时充充电多加了解,在此做一点笔记.
  • 当然,其中的内容参考了很多的教学视频以及文章,可以从后面推荐的链接所了解到,毕竟笔记比较简单化,主要用于自己的备忘参考,也欢迎批评指摘.

♪ 概念

前期学习推荐:

继续推荐:

  1. Redis 类的命名空间是根 \
  2. phpredis 的命令和参数和 redis.io 中的实际命令对应

♫ 笔记

①. 数据类型

  • 首先我们需要根据 Redis 提供的 7 种数据类型来了解它,分别是字符串 String、哈希 Hash、列表 List、集合 Set、有序集合 Sorted Set、发布订阅 Pub/Sub、事务 Transactions

②. 单线程的相关了解:

③. Transactions 事务

  • 我们一般认为 NoSQL 数据库都没有事务,恐怕要让你失望了。Redis 就支持事务,但并不是我们一般意义上的事务,如果你执行 exec 命令,途中断电或者服务器挂掉了,我们还是会发现 Redis 里一部分插入了,一部分未插入。
  • 不过 Redis 提供了 WATCH 命令,我们可以对某个 key 来 watch 一下,然后再执行 Transactions。如果这个被Watch 的值进行了修改,那么这个 Transactions 会发现并拒绝执行。

常用命令有 MULTI、EXEC、DISCARD。

MULTI:标记一个事务块的开始;
EXEC:执行所有事务块内的命令;
DISCARD:取消事务,放弃执行事务块内的所有命令;
UNWATCH:取消 WATCH 命令对所有 key 的监视;
WATCH key:监视 key,如果在事务执行之前 key 被其他命令所改动,那么事务将被打断
  • Redis 作为一个数据库,很多开发者还可以单独使用它。事实上,更多时候 Redis 是在数据库和代码中间作为一个中间件使用,如果你发现你目前的数据库出现瓶颈,那么你就可以通过 Redis 来优化

♬ 代码使用

 $redis = new \Redis();
 $redis->pconnect('192.168.236.131', '6379'); #连接redis服务
 $redis->set('say','moTzxx say hello !');
 //echo $redis->get('say');

 $redis->delete('myname');
 $redis->set('myname','moTzxx');
 echo $redis->get('myname').'<br>'; # 返回:moTzxx

 var_dump($redis->del('myname'));# 返回 TRUE(1)
 var_dump($redis->get('myname')); # 返回 bool(false)

 //$redis->set('tag',10);
 $redis->delete('tag');
 $redis->incr('tag');
 //$redis->incrBy('tag',3);
 var_dump($redis->get('tag'));
 echo '<hr/>';

 $redis->delete('list1');
 $redis->lPush('list1','hello');
 $redis->rPush('list1','miss');
 var_dump($redis->rPop('list1')); #string(4) "miss"
 echo '<hr/>';

 $redis->delete('set1');
 $redis->sAdd('set1','a');
 $redis->sAdd('set1',2);
 $redis->sAdd('set1','ok');
 $redis->sAdd('set1','ok');//TODO 集合的唯一性

 $val = $redis->sCard('set1');
 var_dump($val); #int(3)
 $val2 = $redis->sMembers('set1');
 var_dump($val2);#array(3) { [0]=> string(2) "ok" [1]=> string(1) "2" [2]=> string(1) "a" }
 echo '<br/>';

 $redis->set('key1', 'value', 111);
 var_dump($redis->get('key1'));

 $redis->getSet('key1','value11');
 var_dump($redis->mget(['tag','key1']));
 var_dump($redis->type('tag'));
 echo '<hr/>';

 $redis->delete('driver1');
 $redis->hSet("driver1",'name','moTzxx');
 $redis->hSet("driver1",'age',12);
 $redis->hSet('driver1','gender',1);
 $val = $redis->hGet("driver1",'name');
 var_dump($val);#string(6) "moTzxx"
 $val = $redis->hMGet("driver1",['name','gender']);
 var_dump($val); #array(2) { ["name"]=> string(6) "moTzxx" ["gender"]=> string(1) "1" }
 echo '<hr/>';

 $redis->delete('pats');
 $redis->zAdd('pats',1,'cat1');  # 构建一个zset (sorted set) // int(1)
 $redis->zAdd('pats',3,'dog3');
 $redis->zAdd('pats',2,'monkey2');
 $redis->zAdd('pats',2,'pig2');
 $val = $redis->zRange('pats',0,-1); #从低到高
 var_dump($val); //array(4) { [0]=> string(4) "cat1" [1]=> string(7) "monkey2" [2]=> string(4) "pig2" [3]=> string(4) "dog3" }

 $val2 = $redis->zRevRange('pats',0,-1); #从高到低
 var_dump($val2);//array(4) { [0]=> string(4) "dog3" [1]=> string(4) "pig2" [2]=> string(7) "monkey2" [3]=> string(4) "cat1" }
 var_dump($redis->TYPE('pats')); //zset / int(4)
  • 执行效果截图:

♬ 扩展

①. 四种NoSQL数据库的比较:

②. rpoplpush 的使用场景

③. Redis 在现实世界的 5 个用法

  • 全页面缓存
  • 排行榜
  • 会话Session存储
  • 队列
  • pub/sub

附录

①. 推荐学习

②. 是否使用过Redis集群,集群的原理是什么?

Redis Sentinal 着眼于高可用,在 master 宕机时会自动将 slave 提升为 master,继续提供服务。 Redis Cluster 着眼于扩展性,在单个 redis 内存不足时,使用 Cluster 进行分片存储

③. 天下无难试之Redis面试刁难大全

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Redis 的安装与拓展操作指导(Windows+Linux)

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/de...

    泥豆芽儿 MT
  • PHP - 腾讯云防刷AA 服务的使用笔记

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/de...

    泥豆芽儿 MT
  • ThinkPHP5.1 Linux下命名空间问题

    随手把大写的 “A" 改为 “a”,同时对应的调用方式改为 “use app\uniapi\model\XinApiData” ,然后就发现,神奇的解决了问题 ...

    泥豆芽儿 MT
  • ELK的上线之路(五):—— Logstash进阶解耦

    path => "/var/log/ucdisk/ucdisk-error.log"

    江小白
  • 初学redis之windows服务配置与启动

    初学redis首先要配置好服务, redis在Linux上的安装只要按照官方指导来,很快很简单。 下面来谈谈redis在windows上的安装。 官网虽然没给r...

    lonelydawn
  • 【redis】安装与运行:Creating Server TCP listening socket 127.0.0.1:6379: bind: No error

    小小明童鞋
  • Docker 入门到实战教程(七)安装Redis

    Redis是有状态的,重启容器后数据和配置文件将清空,所以我将采用本地文件挂载方式

    小东啊
  • docker|docker安装redis

    本网站记录了最全的各种JavaDEMO ,保证下载,复制就是可用的,包括基础的, 集合的, spring的, Mybatis的等等各种,助力你从菜鸟到大牛,记得...

    微笑的小小刀
  • 面试官: 两个Redis集群 如何平滑数据迁移

    由于生产环境的各种原因,我们需要对现有服务器进行迁移,包括线上正在运行的 redis 集群环境 如何去做?

    冷冷
  • Windows下安装并设置Redis

    Redis对于Linux是官方支持的,安装和使用没有什么好说的,普通使用按照官方指导,5分钟以内就能搞定。详情请参考: http://redis.io/down...

    庞小明

扫码关注云+社区

领取腾讯云代金券