在Node.js应用中使用Redis的方法简介
2015-06-24 00:00
1076 查看
在开始本文之前请确保安装好 Redis 和 Node.js 以及 Node.js 的 Redis 扩展 ―― node_redis
首先创建一个新文件夹并新建文本文件 app.js 文件内容如下:
var redis = require("redis") , client = redis.createClient(); client.on("error", function (err) { console.log("Error " + err); }); client.on("connect", runSample); function runSample() { // Set a value client.set("string key", "Hello World", function (err, reply) { console.log(reply.toString()); }); // Get a value client.get("string key", function (err, reply) { console.log(reply.toString()); }); }
当连接到 Redis 后会调用 runSample 函数并设置一个值,紧接着便读出该值,运行的结果如下:
OK Hello World
我们也可以使用 EXPIRE 命令来设置对象的失效时间,代码如下:
var redis = require('redis') , client = redis.createClient(); client.on('error', function (err) { console.log('Error ' + err); }); client.on('connect', runSample); function runSample() { // Set a value with an expiration client.set('string key', 'Hello World', redis.print); // Expire in 3 seconds client.expire('string key', 3); // This timer is only to demo the TTL // Runs every second until the timeout // occurs on the value var myTimer = setInterval(function() { client.get('string key', function (err, reply) { if(reply) { console.log('I live: ' + reply.toString()); } else { clearTimeout(myTimer); console.log('I expired'); client.quit(); } }); }, 1000); }
注意: 上述使用的定时器只是为了演示 EXPIRE 命令,你必须在 Node.js 项目中谨慎使用定时器。
运行上述程序的输出结果是:
Reply: OK I live: Hello World I live: Hello World I live: Hello World I expired
接下来我们检查一个值在失效之前存留了多长时间:
var redis = require('redis') , client = redis.createClient(); client.on('error', function (err) { console.log('Error ' + err); }); client.on('connect', runSample); function runSample() { // Set a value client.set('string key', 'Hello World', redis.print); // Expire in 3 seconds client.expire('string key', 3); // This timer is only to demo the TTL // Runs every second until the timeout // occurs on the value var myTimer = setInterval(function() { client.get('string key', function (err, reply) { if(reply) { console.log('I live: ' + reply.toString()); client.ttl('string key', writeTTL); } else { clearTimeout(myTimer); console.log('I expired'); client.quit(); } }); }, 1000); } function writeTTL(err, data) { console.log('I live for this long yet: ' + data); }
运行结果:
Reply: OK I live: Hello World I live for this long yet: 2 I live: Hello World I live for this long yet: 1 I live: Hello World I live for this long yet: 0 I expired
相关文章推荐
- Redis 简单动态字符串
- Redis命令学习-SortedSet(有序集合)
- Linux 下 Redis 安装详解
- Redis学习
- Redis配置文件详解,针对2.6.3--2.6.7
- java操作redis
- spark 写入 redis 和 org.apache.spark.SparkException: Task not serializable
- 使用 Redis 实现分布式系统轻量级协调技术
- python redis
- Redis String 类型和 Hash 类型学习笔记与总结
- Redis 3.0 源码注释
- Redis list 类型学习笔记与总结
- Redis的Python客户端redis-py安装使用说明文档
- Redis数据库的应用场景介绍
- Redis的LRU机制介绍
- Redis2.8配置文件中文详解
- redis2.8配置文件中文翻译版
- Redis中主键失效的原理及实现机制剖析
- 利用Redis实现亿级别用户登录统计(活跃度以及登录次数统计)
- Redis操作字符串(字符串最大值为512M)