node redis 实现服务端数据持久化

安装redis --ps 这里只说一下 Ubuntu,至于其他的请戳这里

sudo apt-get update
sudo apt-get install redis-server

启动 Redis

redis-server

查看是否启动成功?

redis-cli
redis 127.0.0.1:6379> ping
PONG

OK,redis就这么装好了,,,

然后是redis在node中咋使用

npm install redis --save

redis 链接

var redis = require('redis');
var client = redis.createrClient('6379', '127.0.0.1'); 
// 第一个参数是port, 第二个是ip,
// 也可以不带参数,那么上面的这个就是默认值

// 链接错误,输出
client.on("error", function(error) {
  console.log(error);
})

redis 存取值

// 存储字符串
client.set('id', '001', function(err, res){
  /*...*/
});

// 读取字符串
client.get('id', function(err, res){
  /*...*/
});

// 存储hash值
client.hset('hash', {id: '001'}, function(err, res){
  /*...*/
});

// 读取hash值
client.hget('hash', function(err, res){
  /*...*/
});

上面这几个是最常用的,如果还想用其他的,就去官网自己找吧

另外,再说一个现在用的比较多的 node session 持久化

var express = require('express');
var session = require('express-session');
var redisStore = require('connect-redis')(session);

var app = express();
app.listen(5000);

app.use(session({
  // 假如你不想使用 redis 而想要使用 memcached 的话,代码改动也不会超过 5 行。
  // 这些 store 都遵循着统一的接口,凡是实现了那些接口的库,都可以作为 session 的 store 使用,比如都需要实现 .get(keyString) 和 .set(keyString, value) 方法。
  // 编写自己的 store 也很简单
  store: new redisStore(),
  secret: 'somesecrettoken'
}));

app.get('/', function (req, res) {
  if(req.session.isVisit) {
    req.session.isVisit++;
    res.send('<p>第 ' + req.session.isVisit + '次来到此页面</p>');
  } else {
    req.session.isVisit = 1;
    res.send('欢迎第一次来这里');
  }
});

这是一个最简单的实例,其中就是将session持久化在本地,

但是缺点还是在node的单线程上,虽然能够持久化,但是只能应用在一次请求上,

当然,session持久化在redis上可以很好地实现负载均衡,只要不是很密集型的计算,就能减少对服务器内存的占用了

参考文档:

1.node.js下redis简单操作实例

2.cookie 和 session

3.Node.js之session实践

转载于:https://my.oschina.net/codingBingo/blog/842471

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis提供了两种方式来实现数据持久化:RDB(Redis Database)和AOF(Append-Only File)。 1. RDB持久化: RDB是Redis的默认持久化方式,它将当前内存中的数据保存到磁盘上的一个二进制文件。RDB持久化可以在指定的时间间隔内自动执行,也可以手动执行。当执行RDB持久化时,Redis会fork一个子进程来将数据写入到磁盘上的文件中,完成后再替换原有的文件。RDB持久化适用于数据备份和恢复,以及在重启Redis时快速加载大量数据。 配置RDB的方式: 在Redis配置文件中,可以通过设置`save`指令来配置RDB持久化的触发条件和频率。例如,`save 3600 1`表示在1个小时内,如果至少有1个键被修改,则执行RDB持久化。 2. AOF持久化: AOF持久化以日志追加的方式将每个写操作命令追加到一个文件中。通过重新执行这些命令,可以将数据恢复到Redis服务器重新启动之前的状态。AOF持久化方式相对于RDB更加耐久,因为它记录了每个写操作命令,可以在服务异常终止时更好地保证数据的完整性。 配置AOF的方式: 在Redis配置文件中,可以通过设置`appendonly`指令来启用AOF持久化。默认情况下,AOF持久化是关闭的。可以设置`appendfsync`指令来控制AOF文件何时被同步到磁盘。常用的选项有`always`(每个写命令都立即同步到磁盘,最安全但性能较差)、`everysec`(每秒同步一次,折衷方案)和`no`(操作系统决定何时同步,性能最好但风险较高)。 可以根据实际需求选择适合的持久化方式,或者同时使用RDB和AOF来提高数据的安全性和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值