Node.js封装redis操作及代码是什么
Admin 2022-08-17 群英技术资讯 981 次浏览
今天这篇我们来学习和了解“Node.js封装redis操作及代码是什么”,下文的讲解详细,步骤过程清晰,对大家进一步学习和理解“Node.js封装redis操作及代码是什么”有一定的帮助。有这方面学习需要的朋友就继续往下看吧!const options = { host: '208.167.233.104', port: 15001, password: '123456', detect_buffers: true // 传入buffer 返回也是buffer 否则会转换成String } module.exports = options封装redis操作:RedisConfig.js 需要安装redis的npm包 (3.0.2)
const redis = require('redis')
const redisOptions = require('./RedisOptions')
const options = {
host: redisOptions.host,
port: redisOptions.port,
password: redisOptions.password,
detect_buffers: redisOptions.detect_buffers, // 传入buffer 返回也是buffer 否则会转换成String
retry_strategy: function (options) {
// 重连机制
if (options.error && options.error.code === "ECONNREFUSED") {
// End reconnecting on a specific error and flush all commands with
// a individual error
return new Error("The server refused the connection");
}
if (options.total_retry_time > 1000 * 60 * 60) {
// End reconnecting after a specific timeout and flush all commands
// with a individual error
return new Error("Retry time exhausted");
}
if (options.attempt > 10) {
// End reconnecting with built in error
return undefined;
}
// reconnect after
return Math.min(options.attempt * 100, 3000);
}
}
// 生成redis的client
const client = redis.createClient(options)
// 存储值
const setValue = (key, value) => {
if (typeof value === 'string') {
client.set(key, value)
} else if (typeof value === 'object') {
for (let item in value) {
client.hmset(key, item, value[item],redis.print)
}
}
}
// 获取string
const getValue = (key) => {
return new Promise((resolve, reject) => {
client.get(key, (err, res) => {
if (err) {
reject(err)
}else{
resolve(res)
}
})
})
}
// 获取hash
const getHValue = (key) => {
return new Promise((resolve, reject) => {
client.hgetall(key, function (err, value) {
if (err) {
reject(err)
} else {
resolve(value)
}
})
})
}
// 导出
module.exports = {
setValue,
getValue,
getHValue
} 使用:test.js
const redis = require('./RedisConfig')
redis.setValue('student', {
name: 'xiaoming',
age: 18,
sex: 1
})
redis.setValue('book', 'yuwen')
redis.getValue('book').then(res => {
console.log(res)
}).catch(err => {
throw new Error(err)
})
redis.getHValue('student').then(res => {
console.log(res)
}).catch(err => {
throw new Error(err)
})
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文主要介绍了vue前端RSA加密java后端解密的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
vue防抖功能怎样实现?首先防抖就是防止重复点击触发事件,对按钮做防抖是很有必要的,防抖功能能够避免用户在较短时间内进行过快点击,从而引发一系列负面的影响。因此,下面就给大家分享一下关于vue实现防抖的方法,供大家参考。
目录引言class 第一个好:私有变量class 第二个好:super 继承引言在很早以前,写过一篇文章 “类”设计模式和“原型”设计模式——“复制”和“委托”的差异 ,大致意思就是说:代码复用,也就是继承、重写,有两种思路:1. 面向对象的类继承;2. 基于 JavaScript 原型链的原型继承;前者的主要特点是:
1、什么时候该用buffer,什么时候不该用看一下如下的测试代码,分别是拼接各种不同长度的字符串,最后直接拼接了10MB的字符串varstring,string2,string3;varbufstr,bufstr2,bufstr3;varj;console.time('write1000string');for(j=0;j<1000;j++){varx=j
这篇文章主要给大家介绍了关于利用JS判断元素是否为数组的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008