redis在nodejs中应用实战项目分享

这次给大家带来redis在nodejs中应用实战项目分享,redis在nodejs中应用的注意事项有哪些,下面就是实战案例,一起来看一下。

redis是一个性能非常好的内存数据库,部署在应用程序和mysql数据中间做注意事项库,可以极大的提升应用程序的性能,这里简单介绍nodejs客户端操作redis的demo程序

redis里面总共可以存储5种注意事项,分别是注意事项,列表、集合、三列、有序集合;这里将会对这5种数据类型的增删查改一一处理;

1、redis在mac上的安装:

注意事项redis.io/download,当前我用的版本稳定版本是4.0.9,解压之后,进入redis-4.0.9目录,执行make && sudo make install,稍等几分钟就可以安装好;

2、redis启动:

命令行执行 redis-server即可启动,默认端口是6379;

3、安装nodejs客户端:

创建redis-node目录,在该目录下yarn init -y之后,执行命令:yarn add redis 即可安装nodejs的redis客户端,参考文档:https://github.com/NodeRedis/node_redis

4、在redis-node目录下,终端上执行node,即可在终端上响应式的执行nodejs代码,用做测试,下面开始demo程序

首先要创建客户端,并连接redis服务器,在执行以下连接客户端代码之前,请确保已经运行了redis服务器:终端商执行redis-server即可,默认端口6379;

const redis = require('redis');const client = redis.createClient(); //默认连接localhost:6379,具体配置参数可以参考文档https://github.com/NodeRedis/node_redis

登录后复制

如果一切顺利,我们就已经创建好了连接redis服务器的客户端,后续操作都是在client对象上进行。

一、字符串类型

虽然说是字符串类型,但是可以存储的数据包括字符串、整数以及浮点数。

var res = client.set('name', 'abczhijia', (err, data) => { console.log('err: ', err, ' data: ', data);}); // err: null data: OK,res的值是trueclient.get('name', (err, data) => { console.log('err: ', err, ' data: ', data);}); // err: null data: abczhijia

登录后复制

为了简单起见,我们定义一个注意事项,用于输出数据:

const cb = (err, data) => { console.log('err: ', err, ' data: ', data, ' data type: ', typeof data);}

登录后复制

下面再针对整数做一个测试:

client.set('age', 20, cb); //err: null data: OK data type: stringclient.get('age', cb); //err: null data: 20 data type: string

登录后复制

可以看出,虽然设置的是整数,输出来的时候,其实还是字符串,所以如果要进行计算,需要自己在回调函数里面做转换

二、列表数据类型

//从右侧推入client.rpush('friends', 'mike', 'jhon', cb); //err: null data: 2 data type: numberclient.lrange('friends', 0, -1, cb); //err: null data: [ 'mike', 'jhon' ] data type: object//从左侧推入client.lpush('friends', 'sam', 'bob', cb); //err: null data: 4 data type: numberclient.lrange('friends', 0, -1, cb); // err: null data: [ 'bob', 'sam', 'mike', 'jhon' ] data type: object//从右侧弹出client.rpop('friends', cb); //err: null data: jhon data type: string//从左侧弹出client.lpop('friends', cb); //err: null data: bob data type: string//打印看看发生了啥client.lrange('friends', 0, -1, cb); // err: null data: [ 'sam', 'mike' ] data type: object//查看索引位置的值client.lindex('friends', 0, cb); // err: null data: sam data type: string//对列表进行裁剪client.rpush('friends', 'tom', 'bryant', cb)// err: null data: 4 data type: numberclient.ltrim('friends', 1, 2, cb); //err: null data: OK data type: stringclient.lrange('friends', 0, -1, cb); //err: null data: [ 'mike', 'tom' ] data type: object

登录后复制

这里注意,列表的操作可以从右边rpush推入一个或者多个数据,也可以从左边lpush推入一个或多个数据;另外,取值的时候,需要指明需要起止位置,如果要获取整个,可以把结束位置写成-1。

三、集合数据类型

//往集合ids中加几个元素client.sadd('ids', 1, 2, cb); //err: null data: 2 data type: number//查看集合元素client.smembers('ids', cb); //err: null data: [ '1', '2' ] data type: object//从集合中删除元素client.srem('ids', 2, cb); // err: null data: 1 data type: number//看看发生了啥client.smembers('ids', cb); //err: null data: [ '1' ] data type: object//看看集合有多少个元素client.scard('ids', cb); //err: null data: 1 data type: number//再加几个元素进去client.sadd('ids', 3, 5, 8, 9); ////判断元素是否在集合内client.sismember('ids', 8, cb); // err: null data: 1 data type: numberclient.sismember('ids', 80, cb); //err: null data: 0 data type: number

登录后复制

四、散列数据类型

//往散列上添加多组键值对client.hmset('phone', 'price', 5888, 'name', 'iphonex', cb); //err: null data: OK data type: string//查看多个键的值client.hmget('phone', 'price', 'name', cb); //err: null data: [ '5888', 'iphonex' ] data type: object//查看键值对的数量client.hlen('phone', cb); //err: null data: 2 data type: number//删掉其中一个键值对client.hdel('phone', 'price', cb); //err: null data: 1 data type: number//看看price是否还在?client.hmget('phone', 'price', cb); //err: null data: [ null ] data type: object,原来只留下了null//再加几个属性client.hmset('phone', 'vendor', 'apple', 'madein', 'china', cb);//取出所有的键值对client.hgetall('phone', cb); //err: null data: { name: 'iphonex', vendor: 'apple', madein: 'china' } data type: object//取出所有的键client.hkeys('phone', cb); //err: null data: [ 'name', 'vendor', 'madein' ] data type: object//取出所有的值client.hvals('phone', cb); //err: null data: [ 'iphonex', 'apple', 'china' ] data type: object//判断键是否存在client.hexists('phone', 'name', cb); //err: null data: 1 data type: numberclient.hexists('phone', 'price', cb); //err: null data: 0 data type: number

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

注意事项

注意事项

以上就是redis在nodejs中应用实战项目分享的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2751944.html

(0)
上一篇 2025年3月8日 06:04:07
下一篇 2025年3月8日 06:05:26

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 不用JS实现菜单打开关闭

    这次给大家带来不用JS实现菜单打开关闭,不用JS实现菜单打开关闭的注意事项有哪些,下面就是实战案例,一起来看一下。 我在写有菜单栏的网页时,基本都会用响应式设计来适配移动端,例如把不重要的菜单选项隐藏,或者创建一个菜单按钮来控制的菜单的打开…

    2025年3月8日
    200
  • 如何操作Vue项目内使用d3.js

    这次给大家带来如何操作Vue项目内使用d3.js,Vue项目内使用d3.js的注意事项有哪些,下面就是实战案例,一起来看一下。 之前写一个 Demo里面 有些东西要使用d3实现一些效果 但是在很多论坛找资源都找不到可以在Vue里面使用D3.…

    2025年3月8日
    200
  • 使用缓存调用链实现JS方法重载步骤详解

    这次给大家带来使用缓存调用链实现JS方法重载步骤详解,使用缓存调用链实现JS方法重载的注意事项有哪些,下面就是实战案例,一起来看一下。 1.什么是方法重载 方法重载是指在一个类中定义多个同名的方法,但要求每个方法具有不同的参数的类型或参数的…

    编程技术 2025年3月8日
    200
  • 怎样使用JS实现缓冲运动

    这次给大家带来怎样使用JS实现缓冲运动,使用JS实现缓冲运动的注意事项有哪些,下面就是实战案例,一起来看一下。 缓冲需要用到数值取整,向上取整:Math.ceil()  向下取整Math.floor() 移动的速度慢慢减慢的效果,移动速度=…

    编程技术 2025年3月8日
    200
  • 通过vue.js使用axios实现下载功能(详细教程)

    下面我就为大家分享一篇vue.js 使用axios实现下载功能的示例,具有很好的参考价值,希望对大家有所帮助。 本文主要来源于知乎一个回答,这里红色部分做了自己的处理,虽然自己的少,可是很有用的几句代码哦 只好回答一下axios如何拦截ge…

    编程技术 2025年3月8日
    200
  • 怎样进行JS内DOM节点使用

    这次给大家带来怎样进行JS内DOM节点使用,JS内DOM节点使用的注意事项有哪些,下面就是实战案例,一起来看一下。 DOM操作在JS中可以说是非常常见了吧,很多网页的小功能的实现,比如一些元素的增删操作等都可以用JS来实现。那么在DOM中我…

    2025年3月8日
    200
  • 利用nodejs爬虫使用superagent和cheerio的方法

    这篇文章主要介绍了nodejs爬虫初试superagent和cheerio的相关知识,非常不错,具有参考借鉴价值,需要的朋友可以参考下 前言   早就听过爬虫,这几天开始学习nodejs,写了个爬虫https://github.com/le…

    2025年3月8日
    200
  • 如何操作JS实现透明度渐变动画

    这次给大家带来如何操作JS实现透明度渐变动画,操作JS实现透明度渐变动画的注意事项有哪些,下面就是实战案例,一起来看一下。 JS透明度变化效果 body{ margin: 0px; padding: 0px; } .redb{ width:…

    编程技术 2025年3月8日
    200
  • 怎样操作JS实现简单折叠展开动画

    这次给大家带来怎样操作JS实现简单折叠展开动画,操作JS实现简单折叠展开动画的注意事项有哪些,下面就是实战案例,一起来看一下。 JS折叠展开动画 body{ margin: 0px; padding: 0px; } .red{ backgr…

    2025年3月8日
    200
  • 在Node.js中爬取豆瓣数据(详细教程)

    这篇文章通过实例给大家详细分析了node.js爬取豆瓣数据的过程以及具体方法步骤,有兴趣的朋友可以参考学习下。 一直自以为自己vue还可以,一直自以为webpack还可以,今天在慕课逛node的时候,才发现,自己还差的很远。众所周知,vue…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论