百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

node中Session持久化与Redis缓存(nodejs操作redis)

mhr18 2024-11-01 12:19 20 浏览 0 评论

HTTP协议和TCP/IP协议组中其它协议相同,用于客户端和服务器端之间的通信,HTTP是一种无状态协议,及协议本身不保存客户端和服务端的通信状态,也就是说在HTTP这个级别,协议不会对请求或响应做持久化处理,当然这也是为了更快的处理大量事务,确保协议的可伸缩性。

cookie

为了解决HTTP的无状态,引入了Cookie技术,Cookie技术通过在请求和响应报文中写入cookie信息来控制客户端的状态

session

为了跟踪客户端的状态,服务器端借助于客户端的cookie和后端存储实现的会话状态。所以说,Session机制决定了当前客户只会获取到自己的Session,而不会获取到别人的Session。

1 cookie

1.1 概述

在HTTP协议中,制定了Cookie机制,用于实现客户端和服务器之间的状态共享

  • Cookie是解决HTTP无状态性的有效手段,服务器可以设置(set-cookie)或读取cookie中所包含的信息。

  • Cookie是解决HTTP无状态性的有效手段,服务器可以设置(set-cookie)或读取cookie中所包含的信息。

  • Cookie是解决HTTP无状态性的有效手段,服务器可以设置(set-cookie)或读取cookie中所包含的信息。

1.2实现原理

Cookie定义了HTTP请求头和HTTP响应头,客户端和服务器端通过这些头信息进行状态交互。

  • 客户端第一次请求:服务器端如果需要记录用户信息,才会在响应信息中返回 Set-cookie 响应头

  • 客户端会根据响应头存储Cookie信息

  • 客户端再次请求:会在请求头上带上存储的cookie信息,服务端通过cookie信息识别用户

1.3cookie 类别

cookie 总是存储在客户端(通常指浏览器),根据其存储位置可以分为:内存式cookie、硬盘式cookie。

内存式:存储在内存中,浏览器关闭后清除,也非持久存储(会话cookie)

  • cookie 不包含到期日期,则可视为会话 cookie。 会话 cookie 存储在内存中,决不会写入磁盘。 当浏览器关闭时,cookie 将从此永久丢失

硬盘式:保存在硬盘中,浏览器关闭后不会清除,除非手动清除或到了过期时间,也叫持久存储(持久cookie)。

  • cookie 包含到期日期,则可视为持久性 cookie。 在指定的到期日期,cookie 将从磁盘中删除

注:通常我们可以通过 expires 到期时间来做区分

1.4HTTP 协议中为 cookie 服务的首部字段

Set-cookie: 响应首部字段,开始状态管理所使用的Cookie信息

Cookie: 请求首部字段,服务端接收到的cookie信息

1.5 cookie-parser

cookie-parser是 node 中用于操作 cookie 的中间件,用法也比较简单。

安装

参数说明

response 设置的 cookie 信息会随HTTP响应头中的set-cookie,返回给客户端。

  • name:cookie 名

  • value:cookie 值(可以是 json 对象或字符串)

  • options:set-cookie选项,[同上图]

使用

02 session

概述

Session需要借助Cookie实现,Session数据存储在服务端,而只在Cookie中存储一个SessionId,可以保证安全性和降低服务器负载。

express-session

express-session真正在服务端保存数据的中间件,它需要独立安装

安装

引入

几个常用的 options

因为创建 session 的同时会创建 cookie 来保存 sessionId,所以 options 中的 cookie.maxAge 可看作是 session 的有效时长。

使用

3 redis

session存在的问题:Session用于在服务端保存用户会话状态(如:用户登录信息等),Session在程序重启、多进程运行、负载均衡、跨域等情况时,会出现Session丢失或多进程、多个负载站点间状态不能共享的情况

要解决这些问题:我们需要将Session持久化存储,Redis存储是一个非常不错的Session持久化解决方案

Redis是一个高性能的key-value数据库

3.1 概述

特点

  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。

  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储

  • Redis支持数据的备份,即master-slave模式的数据备份

优势

  • 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s

  • 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作

  • 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行

  • 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性

3.2 connect-redis

connect-redis是一个 Redis 版的 session 存储器,使用node_redis作为驱动。借助它即可在Express中启用Redis来持久化你的Session。

使用之前先搭建好redis环境和express应用,Mac下面非常简单,参考:redis搭建Hello world 示例

安装

参数说明

client: 你可以复用现有的redis客户端对象, 由redis.createClient() 创建

host: Redis服务器名

port: Redis服务器端口

socket: Redis服务器的unix_socket

ttl: Redis session TTL 过期时间 (秒)

disableTTL: 禁用设置的 TTL

db: 使用第几个数据库

pass: Redis数据库的密码

prefix: 数据表前辍即schema, 默认为 "sess:"

使用

此时:你的session信息就转移到redis数据库了,当应用重启后数据仍然可以通过cookie中的sessionid获取到,做到数据持久化,提高应用的健壮性。当然你可以尝试存到其它数据库里面,选择redis在于它极高的性能。

结语

不管是express-cookie、express-session、connect-redis 都只是node的中间件,使用都非常简单,关键点在于理解其中的原理,在不同场景都能很好的应用。

相关推荐

Java培训机构,你选对了吗?(java培训机构官网)

如今IT行业发展迅速,不仅是大学生,甚至有些在职的员工都想学习java开发,需求量的扩大,薪资必定增长,这也是更多人选择java开发的主要原因。不过对于没有基础的学员来说,java技术不是一两天就能...

产品经理MacBook软件清单-20个实用软件

三年前开始使用MacBookPro,从此再也不想用Windows电脑了,作为生产工具,MacBook可以说是非常胜任。作为产品经理,值得拥有一台MacBook。MacBook是工作平台,要发挥更大作...

RAD Studio(Delphi) 本月隆重推出新的版本12.3

#在头条记录我的2025#自2024年9月,推出Delphi12.2版本后,本月隆重推出新的版本12.3,RADStudio12.3,包含了Delphi12.3和C++builder12.3最...

图解Java垃圾回收机制,写得非常好

什么是自动垃圾回收?自动垃圾回收是一种在堆内存中找出哪些对象在被使用,还有哪些对象没被使用,并且将后者删掉的机制。所谓使用中的对象(已引用对象),指的是程序中有指针指向的对象;而未使用中的对象(未引用...

Centos7 初始化硬盘分区、挂载(针对2T以上)添加磁盘到卷

1、通过命令fdisk-l查看硬盘信息:#fdisk-l,发现硬盘为/dev/sdb大小4T。2、如果此硬盘以前有过分区,则先对磁盘格式化。命令:mkfs.文件系统格式-f/dev/sdb...

半虚拟化如何提高服务器性能(虚拟化 半虚拟化)

半虚拟化是一种重新编译客户机操作系统(OS)将其安装在虚拟机(VM)上的一种虚拟化类型,并在主机操作系统(OS)运行的管理程序上运行。与传统的完全虚拟化相比,半虚拟化可以减少开销,并提高系统性能。虚...

HashMap底层实现原理以及线程安全实现

HashMap底层实现原理数据结构:HashMap的底层实现原理主要依赖于数组+链表+红黑树的结构。1、数组:HashMap最底层是一个数组,称为table,它存放着键值对。2、链...

long和double类型操作的非原子性探究

前言“深入java虚拟机”中提到,int等不大于32位的基本类型的操作都是原子操作,但是某些jvm对long和double类型的操作并不是原子操作,这样就会造成错误数据的出现。其实这里的某些jvm是指...

数据库DELETE 语句,还保存原有的磁盘空间

MySQL和Oracle的DELETE语句与数据存储MySQL的DELETE操作当你在MySQL中执行DELETE语句时:逻辑删除:数据从表中标记为删除,不再可见于查询结果物理...

线程池—ThreadPoolExecutor详解(线程池实战)

一、ThreadPoolExecutor简介在juc-executors框架概述的章节中,我们已经简要介绍过ThreadPoolExecutor了,通过Executors工厂,用户可以创建自己需要的执...

navicat如何使用orcale(详细步骤)

前言:看过我昨天文章的同鞋都知道最近接手另一个国企项目,数据库用的是orcale。实话实说,也有快三年没用过orcale数据库了。这期间问题不断,因为orcale日渐消沉,网上资料也是真真假假,难辨虚...

你的程序是不是慢吞吞?GraalVM来帮你飞起来性能提升秘籍大公开

各位IT圈内外的朋友们,大家好!我是你们的老朋友,头条上的IT技术博主。不知道你们有没有这样的经历:打开一个软件,半天没反应;点开一个网站,图片刷不出来;或者玩个游戏,卡顿得想砸电脑?是不是特别上火?...

大数据正当时,理解这几个术语很重要

目前,大数据的流行程度远超于我们的想象,无论是在云计算、物联网还是在人工智能领域都离不开大数据的支撑。那么大数据领域里有哪些基本概念或技术术语呢?今天我们就来聊聊那些避不开的大数据技术术语,梳理并...

秒懂列式数据库和行式数据库(列式数据库的特点)

行式数据库(Row-Based)数据按行存储,常见的行式数据库有Mysql,DB2,Oracle,Sql-server等;列数据库(Column-Based)数据存储方式按列存储,常见的列数据库有Hb...

AMD发布ROCm 6.4更新:带来了多项底层改进,但仍不支持RDNA 4

AMD宣布,对ROCm软件栈进行了更新,推出了新的迭代版本ROCm6.4。这一新版本里,AMD带来了多项底层改进,包括更新改进了ROCm的用户空间库和AMDKFD内核驱动程序之间的兼容性,使其更容易...

取消回复欢迎 发表评论: