nodejs中如何使用redis nodejs reduce
wptr33 2024-12-18 17:32 25 浏览
nodejs中如何使用redis
一、Redis是什么?
Redis 是一个开源的内存数据结构存储器,一般可以用于数据库、缓存、消息代理等,我们常在项目中用redis解决高并发、高可用、高可扩展、大数据存储等问题; 它本质上是一个NoSql(非关系型数据库),我们常用的MySQL则是关系型数据库。它并不能替代关系型数据库,更多的时候是对关系型数据库的一种补充;
二、Redis的基本数据类型
- 字符串
- 哈希
- 列表
- 集合
- 有序集合
- HyperLogLog
- 位图
redis中共有七种数据类型,我这边会简单介绍下其中五种常见的数据类型;
2-1、字符串(String)
字符串的类型是Redis中最基础的键值对类型,可以保存普通文字,或者是序列化的二进制数据;字符串类型最大可以存储512M的数据;
字符串操作命令
- set 设置一个字符串值
- get 获取字符串键对应的值
- getrange 截取字符串的内容
- strlen 获取字符串长度
- setex 设置过期时间
- mset 设置多个key-value
- mget 获取多个value
- append 在字符串结尾加入内容
- incr 数字自增加1
- incrby 数字加上指定的整数值
- incrbyfloat 数字加上指定的浮点数
- decr 数字自减一
- decby 数字减去指定的整数值
2-2、哈希类型
常用于保存复杂的数据结构。
- hest 设置单个字段
- hmset 设置多个字段
- hget 获取单个字段值
- hmget 获取多个字段值
- hgetall 获取所有字段值
- hkeys 获取所有字段名
- hlen 获取哈希表中字段的数量
- hexists 判断哈希表中存在某个字段
- hvals 获取哈希表中所有字段值
- hdel 删除哈希表的字段
- hincrby 给某个字段加上指定的整数值
- hincrbyfloart 给某个字段加上指定的浮点数
2-3、列表类型
常用于保存序列化的数据。
- rpush 末尾新增值
- lpush 开头新增值
- llen 获取长度
- lindex 获取表某个元素
- linsert 在列表某个位置插入值
- lpop 删除最左边的值 -rpop 删除最右边的值
- lrem 删除某个位置的值
2-4、集合类型
如果你的需求是不允许数据重复,则你需要使用redis提供的结合类型。
- sadd 添加值
- scard 获取集合长度
- sismember 判断是否含有某个元素
- srem 删除某个元素
- srop 随机删除某个元素,并返回
- srandmember 随机返回集合中的元素
- sunion 组合两个或多个结合并返回所有元素的列表
- smove 将元素从一个集合移动到另一个结合
2-5、有序集合
结合将带有排序功能,redis将按照分数值进行排序。
- zcard 获取结合长度
- zcount 查询某个分数值区间内的值数量
- zscore 查询某个值的分数值
- zrange 获取集合内容的升序
- zrevrange 获取集合内容降序
- zrangebyscore 获取分数值区间内的集合内容升序
- zrevrangebyscore 获取分数值区间内的集合内容降序
- zrank 获取升序排序(从0开始)
- zrevrank 获取降序排序(从0开始)
- zrem 删除集合中的值(单个、多个)
- zremrangebyrank 删除排名区间内的值
- zremrangebyscore 删除分数值区间内的值
三、安装 redis 及辅助工具 Another Redis Desktop Manager
官网地址:redis.io/ 下载地址:download.redis.io/releases/re…
window环境下安装redis可以点击此链接
可视化工具: Another Redis Desktop Manager(goanother.com/cn/)
四、nodejs上安装 ioredis
接下来在nodejs后端项目中使用redis的话,可以安装ioredis这个库操作redis,如果是使用typescript的话,可以再安装 @types/ioredis。
js复制代码npm i ioredis
npm i --save-dev @types/ioredis
ioredis 官方文档
五、nodejs上使用 ioredis
5-1、基础的redis链接配置
ts复制代码import redis from 'ioredis'
const { REDIS_PORT, REDIS_HOST, REDIS_PASSWORD, REDIS_DB } = process.env as any
export default new redis({
port: REDIS_PORT, // redis的端口
host: REDIS_HOST, // redis的允许地址
password: REDIS_PASSWORD, // redis的密码
db: REDIS_DB // redis由16个db库,可以手动选择第几个,由0开始
})
5-2、项目中使用
ioredis 将redis命令全部更改为了函数调用的形式,我们调用redis就像平时开发调用函数一样即可,下面是最简单的使用案例:
typescript复制代码import redis from '@/redis'
/**
* 重置存储 session的过期时间
* @param key
* @param time 过期时间设置(min)
*/
export const resetTime = (key: string, time = 60) => {
redis.expire(key, time * 60)
recordNum(redisType.expire)
}
六、结语
本文当中简单介绍了redis的基础操作命令,在nodejs中如何使用redis,实际生产当中的redis操作更为复杂和多样,还是需要我们自己多进行摸索和实践;本文当中的操作只是常用的基础操作,如果想知道更多的redis操作,可以去查看redis的官方文档。
原文链接:https://juejin.cn/post/7245658681731235899
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
redission YYDS spring boot redission 使用
-
SparkSQL——DataFrame的创建与使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)