用 Upstash 作为你的 Redis 服务器

用 Upstash 作为你的 Redis 服务器

本文继续我们的实战教程(源码:github.com/weijunext/n...%25EF%25BC%258C "https://github.com/weijunext/nextjs-learn-demos)%EF%BC%8C") 今天给大家推荐一个免费的 Redis 服务器,它叫 Upstash。

如果你正在开发个人产品,那么请忘掉 Redis 的配置和各种安全措施,用 Upstash,什么 RDB 和 AOF、雪崩和击穿、密码和权限,这些 Upstash 会帮你搞定,你只需要关注你要实现的功能。

本文假定你已了解 Redis 的基本概念,阅读完本文,你将学习到:

  • 创建一个 Upstash 的 Redis 数据库
  • NextJS 服务端组件和 Redis 交互

创建 Redis 数据库

万事开头需注册,请到 upstash.com/ 注册登录,开始咱们的教程。

首次进入后台,看到的是这样的界面

创建 Redis 数据库

稍等片刻就创建完成了,Redis 信息一览无余。

这种方式创建Redis,相信要比我们手动在本地安装Redis、分配db要流畅的多吧。下面进入正题,NextJS中 怎么使用 Upstash 的 Redis。

服务端组件调用

先安装依赖

bash 复制代码
    yarn add @upstash/redis

实际项目中,我们会在多个地方使用redis,所以应该把redis配置写到lib里,方便调用

ts 复制代码
    // @/lib/redis.ts

    import { Redis } from '@upstash/redis'

    const redis = new Redis({
      url: `${process.env.UPSTASH_REDIS_REST_URL}`,
      token: `${process.env.UPSTASH_REDIS_REST_TOKEN}`,
    })

    export default redis

在服务端组件中直接和 redis 交互

tsx 复制代码
    // @/app/pages.tsx

    ......
    import redis from "@/lib/redis";

    export default async function Home() {
    ......
    	await redis.incr("view");
    	const view = await redis.get("view")

    	return (
    		<>
    			......
    				<span className="flex max-w-fit items-center justify-center space-x-2 rounded-full border border-gray-300 bg-white px-5 py-2 text-sm text-gray-600 shadow-md transition-colors hover:border-gray-800">
              <TablerEyeFilled />
              <p>
                <span className="hidden sm:inline-block">Page Views</span>{" "}
                <span className="font-semibold">{nFormatter(view)}</span>
              </p>
            </span>
    			......
    		</>
    	) 

    ......
    }

如果你疑惑为什么组件内可以直接调用redis,那么请看我的过往文章:

从 demo 中可以知道,Upstash 的 redis 命令和 Node开发者熟悉的 ioredis 几乎一样,所以 Upstash 使用起来不会有任何心理门槛。

我们看看控制台,确认 redis 是否被正确操作了:

当我们刷新几次页面后,在 Usage 页卡下可以看到命令调用次数;

在 Data Browser 可以看到 Redis 里的所有数据。

再看页面,数据和控制台相符,说明以上代码没有问题。

结语

Upstash 这样的第三方托管平台,比较适合个人开发者的个人项目使用,它能够让你最轻量又安全地用上 Redis,你要做的只是学习常用的 Redis 的命令。

源码

github.com/weijunext/n...

相关推荐
别问,问就是菜鸡5 小时前
阿里云效前端流水线自动化部署
前端·阿里云·自动化·持续部署
燐妤5 小时前
前端HTML编程4:深入学习CSS
前端·学习·html
2301_816374335 小时前
服务访问的用户认证
前端·网络
XS0301065 小时前
从浏览器到互联网的完整数据流
前端·数据库·servlet·交互
程序员三明治5 小时前
【AI】一文讲清 RAG:从大模型局限到企业级知识库落地流程
java·人工智能·后端·ai·大模型·llm·rag
Devin~Y5 小时前
大厂 Java 面试实录:Spring Boot/Cloud、Kafka、Redis、JVM、K8s、RAG 一条龙(小Y翻车版)
java·jvm·spring boot·redis·spring cloud·kafka·kubernetes
hhb_6185 小时前
MATLAB数值计算与数据可视化核心技术梳理及实战应用案例解析
前端
lichenyang4535 小时前
从零理解微前端:基于 React + Vite + qiankun 的子应用切换 Demo
前端·react.js·状态模式
l软件定制开发工作室5 小时前
Spring开发系列教程(37)——使用Conditional
java·后端·spring
yangminlei5 小时前
Spring Boot Starter自定义开发 构建企业级组件库
java·spring boot·后端