使用NodeJS 5分钟 连接 Redis 读写操作的详细过程

目录
  • 本文简介
  • Redis 基础
    • 安装
    • 写入
    • 读取
    • 查看所有key
    • 删除
  • NodeJS 操作 Redis
    • 初始化项目
    • 安装 Redis 依赖
    • 连接
    • 写入数据
    • 读取数据
    • 删除
    • 断开连接

本文简介

本文主要讲解使用 NodeJS 操作 Redis ,顺便会先带一带 Redis 基础用法。

在写本文时,使用 NPM 安装的 Redis 依赖包已经到了 4.1.0 版本了。我以前用过 2.8 ,这两个版本在用法上也是有差别的。可能一些老项目还在用老版本的依赖包。所以我会把2个版本的用法都简单讲讲。

Redis 基础

Redis 可以说是最最最简单的数据库了。大部分数据库的读写操作都是在硬盘上的,而 Redis 是在内存上的。所以读写速度会比其他传统数据库要快。但缺点是数据不能持久化,一旦断电重启,数据就没了。当然,Redis 也是可以将数据持久化的,但我觉得这样做的成本有点高,如果要将数据持久化不如直接用传统数据库。

Redis 可能用得最多的地方就是存储 session ,用来记录用户登录状态之类的操作。这类数据就算丢失了也不会对用户有多大影响。

安装

要使用 Redis ,首先就要安装它。windows版下载链接放在这里:https://github.com/tporadowski/redis/releases

我下载了 .msi 格式的安装包,下载后直接双击运行,一直点 “下一步” 就能安装成功。

在安装时记得勾选将 Redis 添加到全局环境。

安装成功后,打开终端,输入一下命令

redis-cli

进入交互模式就证明安装成功了,此时可以输入指令操作 Redis 了。

127.0.0.1 是本机 IP6379Redis 默认的端口号。

写入

写入数据使用 set 指令

set key value

key 是键名,value 是值。

我设置了一个 name ,值为 zhangsan

输入完按回车键,返回 OK 证明写入成功。

读取

读取数据使用 get

get key

key 是键名。

如果查到就返回值。

查看所有key

如果你不清楚当前存了什么 key ,可以使用 keys * 来查询所有 key

keys *

如果你有多个 key ,用上面的语句可以将所有 key 都列出来。

删除

删除使用 del

del key

我把刚刚创建的 name 这条数据给删掉了。

此时使用 get 或者 keys * 都差不回 name 这条数据了。

以上就是 Redis 的基础用法。

NodeJS 操作 Redis

初始化项目

我用默认模板初始化项目。

npm init -y

安装 Redis 依赖

在写本文时,使用以下命令安装的最新版 Redis4.1.0

npm install redis

如果你想用旧版语法,可以安装指定版本。

比如我之前用的是 2.8

npm install redis@2.8

连接

安装好 Redis 后就可以用 NodeJS 来连接了。

新建一个 js 文件。

v2.8语法

const redis = require('redis') // 引入 redis

// 创建客户端
const redisClient = redis.createClient('6379', '127.0.0.1') // 端口,主机

// 监听错误信息
redisClient.on('error', err => {
  console.error(err) // 打印监听到的错误信息
})

v4.1 语法

const redis = require('redis') // 引入 redis

const redisClient = redis.createClient() // 创建客户端

// 监听错误信息
redisClient.on('err', err => {
  console.log('redis client error: ', err)
})

// 连接
redisClient.connect(6379, '127.0.0.1')

写入数据

写入数据使用 set 方法

v2.8

// 省略部分代码
redisClient.set('name', 'zhangsan', redis.print)

第三个参数 redis.print 是打印方法,在执行完上面的命令,控制台会打印一条信息。

比如执行成功,会打印 Reply: OK

v4.1

const redis = require('redis') // 引入 redis

// 创建客户端
const redisClient = redis.createClient()

// 监听错误信息
redisClient.on('err', err => {
  console.log('redis client error: ', err)
})

// 创建连接,是个 promise
redisClient.connect(6379, '127.0.0.1')
  .then(() => {
    redisClient.set('name', 'zhangsan')
      .then(val => {
        console.log(val)
      })
  })

上面的代码意思是,使用 client.connect 连接,成功后再执行 set 操作。

你也可以将上面的代码改成 asyncawait 语法。

读取数据

使用 get 方法可以读取数据

v2.8

// 省略部分代码

redisClient.get('name', (err, val) => {
  if (err) {
    console.error(err)
    return
  }
  console.log(val)
})

v4.1

const redis = require('redis') // 引入 redis

// 创建客户端
const redisClient = redis.createClient()

// 创建连接,是个 promise
redisClient.connect(6379, '127.0.0.1')
  .then(() => {
    redisClient.get('name')
      .then(val => {
        console.log(val)
      })
  })

如果查找到就返回对应的值,否则返回 null

删除

使用 del 方法删除

v2.8

// 省略部分代码

redisClient.del('name', (err, val) => {
  if (err) {
    console.error(err)
    return
  }
  console.log(val)
})

v4.1

const redis = require('redis') // 引入 redis

// 创建客户端
const redisClient = redis.createClient()

// 创建连接,是个 promise
redisClient.connect(6379, '127.0.0.1')
  .then(() => {
    redisClient.del('name')
      .then(val => {
        console.log(val)
      })
  })

断开连接

用完就断,用 quit 方法可以断开连接。

在断开连接这件事上,v2.8 和 v4.1 的语法相同

redisClient.quit()

到此这篇关于NodeJS 5分钟 连接 Redis 读写操作的文章就介绍到这了,更多相关NodeJS连接 Redis 读写操作内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解redis在nodejs中的应用

    redis是一个性能非常好的内存数据库,部署在应用程序和mysql数据中间做缓存数据库,可以极大的提升应用程序的性能,这里简单介绍nodejs客户端操作redis的demo程序 redis里面总共可以存储5种数据类型,分别是字符串,列表.集合.三列.有序集合:这里将会对这5种数据类型的增删查改一一处理: 1.redis在mac上的安装: https://redis.io/download,当前我用的版本稳定版本是4.0.9,解压之后,进入redis-4.0.9目录,执行make && su

  • nodejs使用redis作为缓存介质实现的封装缓存类示例

    本文实例讲述了nodejs使用redis作为缓存介质实现的封装缓存类.分享给大家供大家参考,具体如下: 之前在node下使用redis作为缓存介质,对redis进行了一层封装 First: 安装npm包 redis const redis = require('redis'); Second: 进行封装 // cache.js const redis = require('redis'); const config = require('config'); const logger = requ

  • 详解nodejs express下使用redis管理session

    Session实现原理 实现请求身份验证的方式很多,其中一种广泛接受的方式是使用服务器端产生的Session ID结合浏览器的Cookie实现对Session的管理,一般来说包括以下4个步骤: 1.服务器端的产生Session ID 2.服务器端和客户端存储Session ID 3.从HTTP Header中提取Session ID 4.根据Session ID从服务器端的Hash中获取请求者身份信息 使用Express和Redis对Session管理的实现 var session = requ

  • nodejs redis 发布订阅机制封装实现方法及实例代码

     nodejs redis 发布订阅机制封装 最近项目使用redis,对publish 和 subscribe的使用进行了了解,并进行了封装. var config = require('../config/config'); var log = require("./loghelp"); var redis = require("redis"); function initialclient(param) { var option={ host: config.r

  • 使用NodeJS 5分钟 连接 Redis 读写操作的详细过程

    目录 本文简介 Redis 基础 安装 写入 读取 查看所有key 删除 NodeJS 操作 Redis 初始化项目 安装 Redis 依赖 连接 写入数据 读取数据 删除 断开连接 本文简介 本文主要讲解使用 NodeJS 操作 Redis ,顺便会先带一带 Redis 基础用法. 在写本文时,使用 NPM 安装的 Redis 依赖包已经到了 4.1.0 版本了.我以前用过 2.8 ,这两个版本在用法上也是有差别的.可能一些老项目还在用老版本的依赖包.所以我会把2个版本的用法都简单讲讲. Re

  • golang连接redis库及基本操作示例过程

    目录 Redis介绍 Redis支持的数据结构 Redis应用场景 准备Redis环境 go-redis库 安装 连接 V8新版本相关 连接Redis哨兵模式 连接Redis集群 基本使用 HVals set/get示例 zset示例 根据前缀获取Key 执行自定义命令 按通配符删除key Pipeline 事务 Watch Redis介绍 Redis是一个开源的内存数据库,Redis提供了多种不同类型的数据结构,很多业务场景下的问题都可以很自然地映射到这些数据结构上.除此之外,通过复制.持久化

  • SpringBoot整合redis及mongodb的详细过程

    目录 一.先看Redis的使用: 1. 在pom.xml中添加Redis相关依赖项 2. 在application.properties中添加Redis的相关配置 3. 新建 service/RedisService 接口及其实现类 service/impl/RedisServiceImpl 4. 新建 controller/RedisController 5. 通过Postman进行结果验证 二.MongoDB的使用 1. 首先还是先添加MongoDB相关依赖项 2. 然后是添加MongoDB

  • 使用Mybatis Plus整合多数据源和读写分离的详细过程

    目录 一.简介 二.准备 2.1 数据库 2.2 代码 三.案例 3.1 查询用户库主库用户表记录 3.2 查询用户库从库用户表记录 3.3 新增用户库主库用户记录 3.4 商品库查询商品记录 3.5 商品库新增商品记录 3.6 用户库商品库多数据源嵌套 四.总结 一.简介 俩年前用AOP自己封装过一个多数据源,连接地址:springboot + mybatis + druid + 多数据源 , 有兴趣的可以看下: 当时没有处理多数据源嵌套的情况,现在发现mybatis plus比较好用,所以该

  • SpringBoot2整合Redis实现读写操作

    目录 1. 启动 Redis Server 2. 工程实例 2.1 工程目录 2.2 pom.xml 2.3 Java 源文件 3. 测试 4. 问题 1. 启动 Redis Server 启动 redis server,如下图所示,端口号 6379: 2. 工程实例 2.1 工程目录 工程目录如下图所示: 2.2 pom.xml 引入依赖: <dependency> <groupId>org.springframework.boot</groupId> <art

  • python使用NumPy文件的读写操作

    一.使用NumPy读写文本文件 在数据分析中,经常需要从文件中读取数据或将数据写入文件,常用的存储文件的格式有文本文件.CSV格式文件.二进制格式文件和多维数据文件等. 1.将1维或2维数组写入TXT文件或CSV格式文件 在NumPy中,使用savetxt()函数可以将1维或2维数组写入后缀名为txt或csv的文件.函数格式为: **numpy.savetxt(fname,array,fmt='%.18e',delimiter=None,newline='\n', header='', foot

  • Python基于ssh远程连接Mysql数据库操作

    目录 背景 安装支持库 连接Mysql 自定义查询函数 背景 如果需要访问远程服务器的Mysql数据库,但是该Mysql数据库为了安全期间,安全措施设置为只允许本地连接(也就是你需要登录到该台服务器才能使用),其他远程连接是不可以直接访问,并且相应的端口也做了修改,那么就需要基于ssh来连接该数据库.这种方式连接数据库与Navicat里面界面化基于ssh连接一样. Navicat 连接数据库 安装支持库 如果要连接Mysql,首先需要安装pymysql pip install pymysql 安

  • python连接读写操作redis的完整代码实例

    python读写操作redis数据库 redis有16个逻辑数据库(编号db0到db15),每个逻辑数据库数据是隔离的,默认db0.选择第n个逻辑数据库,命令select n ,python连接时可指定数据库编号(0~15). 为python安装支持库: pip install redis 连接redis 第一种方式,直连: import redis def redis_opt(): redis_conn = redis.Redis(host='127.0.0.1', port=6379, pa

  • 浅析python redis的连接及相关操作

    redis简介 Redis是一个开源的使用ANSIC语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.是一个非关系型数据库,经常会用作缓存,消息中间件的操作 redis优势 速度快,因为数据存在内存中 支持丰富数据类型,支持字符串,哈希表,列表,集合,有序集合 支持事务,操作都是原子性 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除 1.redis连接.及存取值 import redis r = redis.Redis(h

  • 使用java连接Redis,Maven管理操作

    pom配置 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0

随机推荐