如何使用 JavaScript 将 KV 模块导入 Cloudflare Worker

KV

使用 JavaScript 在 Workers 中设置 Cloudflare KV

在网络边缘执行无服务器、轻量级应用程序的一个越来越常见的选择是 Cloudflare Workers。使用 Cloudflare KV(键值)存储保存和检索数据的能力是 Cloudflare Workers 的重要组成部分。然而,对于那些不熟悉这个生态系统的人来说,将 KV 模块集成到 Cloudflare Worker 中可能会显得有点困难。

使用 Wrangler CLI 管理 Cloudflare Workers 时,尤其是使用 v3.78.12 等版本时,您在尝试集成 KV 存储时可能会遇到一些挑战。您并不是唯一一个努力理解模块的正确用法或 KV 导入语法的开发人员。不同的互联网资源建议可能有多种不同的方法来导入模块,但找出正确的答案可能很困难。

在本文中,我们将介绍使用 JavaScript 在 Cloudflare Worker 中正确导入和使用 KV 模块所需的过程。我们将介绍如何正确配置它,以便您可以使用放置和接收请求。如果您想在应用程序中利用 Cloudflare KV 的最大功能,理解此过程至关重要。

无论您在后端编程或 Cloudflare Workers 方面的经验水平如何,本教程都将指导您完成该过程的每个步骤。最后,您将了解如何使用基本的 JavaScript 代码与 KV 模块进行通信并进行设置。

命令 使用示例
env.MY_KV_NAMESPACE.put() 在 Cloudflare 的 KV 存储中保存一个值。例如,await env.MY_KV_NAMESPACE.put('key1', 'value') 这就是将数据保存到 KV 存储的方式,这对于 Workers 保留持久数据是必要的。
env.MY_KV_NAMESPACE.get() 从 Cloudflare 的 KV 存储中提取值。 const value = wait env.MY_KV_NAMESPACE.get('key1');为了将数据读回到您的工作线程中,此命令通过其密钥检索存储在 KV 中的数据。
addEventListener('fetch') Sets up an event listener for the fetch event, which is triggered when a request is made to the Worker. Example: addEventListener('fetch', event =>为 fetch 事件设置一个事件监听器,当向 Worker 发出请求时会触发该事件。示例:addEventListener('fetch', event => {...});这用于定义 Worker 如何处理传入的 HTTP 请求。
event.respondWith() 返回给客户端的回复。指定 Worker 如何响应 HTTP 请求的一个重要方法是使用类似 event.respondWith(handleRequest(event.request)); 的示例。这通常会从 KV 存储返回信息。
handleRequest() 专门创建的函数,旨在处理查询和回复。以handleRequest(request)为例,async function {...} 其中包含处理KV和管理各种请求方法的逻辑,例如GET和PUT。
Response() 为 HTTP 响应创建一个对象。示例: return new Response('Hello World');该命令经常用于从 KV 检索响应,用于在处理请求后将数据返回给客户端。
putValue() 用于 KV 数据存储的模块化辅助功能。 PutValue(kv, key, value) 是异步函数 {...} 的示例。该函数包含了在 KV 中存储值的机制,提高了代码的可重用性。
getValue() 用于从 KV 获取信息的模块化辅助功能。 async function getValue(kv, key) 为例 {...} 该命令通过可重用逻辑使从 KV 收集数据变得更容易,就像 putValue() 一样。
wrangler.toml 链接 Worker 的 KV 命名空间的配置文件。 kv_namespaces = [{ binding = "MY_KV_NAMESPACE", id = "kv-id" }] 就是一个例子。要从 Worker 脚本访问 KV,您必须拥有此文件,该文件描述了您的 Worker 如何连接到 KV 存储。

了解 Cloudflare Worker KV 集成

前面示例中给出的脚本允许工作脚本使用 JavaScript 与 Cloudflare KV 存储进行通信。主要作用是使用 数据存储和检索系统。借助 Cloudflare Workers,您可以运行靠近用户的小型脚本,因为它们在无服务器环境中运行。作为一个键值数据库,KV 存储对于管理持久数据非常有用。 `put` 和 `get} 操作可以配置为第一个示例中的基本操作。更准确地说,这些命令 和 分别用于存储和检索数据,并且对于管理动态内容是必需的。

通过 `wrangler.toml} 配置文件将 KV 命名空间绑定到您的 Cloudflare Worker 是基本思想之一。通过将其指定为 ,我们附上 到此配置中的工作人员。 {env} 对象允许 Worker 脚本在绑定后访问此 KV 存储。通过为传入的 HTTP 请求配置事件侦听器,“addEventListener('fetch')”方法使 Worker 能够根据请求方法(GET 或 PUT)做出反应。当管理需要实时读写数据的 API 请求时,这种技术非常有用。

第二个示例展示了除了基本请求处理之外处理 KV 活动的更加模块化的方法。可以使用“putValue()”和“getValue()”等函数抽象出从 KV 存储中保存和检索数据的实现细节。由于这些函数可以从程序的其他部分使用,因此脚本变得更可重用且更易于维护。开发人员可以通过划分关注点来确保与 KV 交互的逻辑在整个软件中得到包含和一致。

最后一个示例演示了如何将 Fetch API 功能与 Cloudflare KV 操作相结合。员工现在可以以动态方式对 HTTP 请求做出反应。开发人员可以使用 Cloudflare Workers 创建适应性强的 API,并利用 Fetch API 保证数据存储和检索请求的异步处理。 “Response()”对象的重要性在于它能够将 KV 操作的结果压缩为可以返回给客户端的 HTTP 响应。得益于其框架和模块化帮助器方法,您的 Cloudflare Worker 将在许多情况下保持高性能且易于测试。

在 Worker 中导入和使用 Cloudflare KV 的各种方法

JavaScript:使用 Wrangler 访问 Cloudflare KV 存储

// Cloudflare Worker script using Wrangler to access the KV store
export default {
  async fetch(request, env) {
    // Put request to store a value in KV
    await env.MY_KV_NAMESPACE.put('key1', 'Hello, Cloudflare KV!');
    // Get request to retrieve a value from KV
    const value = await env.MY_KV_NAMESPACE.get('key1');
    return new Response(`Stored value: ${value}`);
  },
};
// Ensure that MY_KV_NAMESPACE is bound to the Worker in the wrangler.toml

替代方法:在 Cloudflare Worker 中使用 Fetch API

JavaScript:从 Worker 中的 Cloudflare KV 获取数据

// Cloudflare Worker script to fetch data from a KV namespace
addEventListener('fetch', event => {
  event.respondWith(handleRequest(event.request));
});
async function handleRequest(request) {
  // Fetch data from KV store using env bindings
  const value = await MY_KV_NAMESPACE.get('key2');
  return new Response(value || 'Value not found');
}
// Ensure 'MY_KV_NAMESPACE' is properly defined in wrangler.toml

模块化方法:KV 操作的独立函数

JavaScript:用于 Cloudflare KV 操作的模块化函数

export default {
  async fetch(request, env) {
    if (request.method === 'PUT') {
      const result = await putValue(env.MY_KV_NAMESPACE, 'key3', 'Modular KV Put!');
      return new Response(result);
    } else if (request.method === 'GET') {
      const value = await getValue(env.MY_KV_NAMESPACE, 'key3');
      return new Response(`Retrieved value: ${value}`);
    }
  },
};
async function putValue(kv, key, value) {
  await kv.put(key, value);
  return 'Value stored successfully!';
}
async function getValue(kv, key) {
  return await kv.get(key);
}

在 Workers 中管理 Cloudflare KV 的最佳实践

为了优化性能和安全性,在将 Cloudflare KV 集成到 Workers 时考虑一些推荐的实践至关重要。确保 KV 存储正确绑定在 配置文件是新手经常忘记做的一件事。当您的工作脚本由于绑定不正确而尝试访问 KV 存储时,可能会出现运行时问题。确保 通过正确定义命名空间,可以在工作环境中识别并使用。

有效管理数据检索是另一个关键因素。考虑到最终的一致性 ,不同区域获取的数据可能有些不同步。在设计应用程序时考虑到这种一致性模型至关重要,尤其是在处理时间敏感数据时。对于不太重要的数据来说,这种延迟是微不足道的,但在全局设置中使用 KV 时,理解这种行为至关重要。

最后,您应该考虑安全性和错误处理。与其他无服务器设置类似,Cloudflare Workers 也需要强大的错误处理能力,尤其是在使用 KV 等外部存储系统时。在将数据放入 KV 之前,请确保其经过验证,并处理任何潜在的困难,例如 或礼貌地连接问题。在 KV 操作周围包含 try-catch 块并提供有用的错误消息可以帮助使您的应用程序更加可靠和可维护。

  1. 如何将 KV 命名空间绑定到我的 Worker?
  2. 通过添加以下配置,可以在 文件: 。
  3. Cloudflare KV 中的最终一致性是什么?
  4. 由于最终一致性,在一个地方对 KV 所做的修改可能不会立即传播到世界各地。虽然它不是瞬时的,但这种延迟对于许多应用程序来说效果很好。
  5. 与KV交互时如何处理错误?
  6. 要管理超时等可能的问题,请使用 围绕你的 KV 操作的块。您可以报告错误以供以后排除故障。
  7. 我可以在 KV 中存储像 JSON 这样的复杂数据类型吗?
  8. 事实上,JSON 数据可以通过首先使用以下命令将其转换为字符串来存储: ,然后使用 获取数据。
  9. 在将数据存储到 KV 之前如何验证数据?
  10. 使用前 要存储数据,请编写验证函数以确保数据遵循您预期的格式。

Cloudflare KV 存储必须集成到 Workers 中才能有效管理持久数据。您可以通过使用基本的 get 和 put 请求并正确绑定 KV 命名空间来轻松存储和检索数据。当使用辅助函数并理解语法时,开发会更加顺利。

确保您始终遵循最佳实践,包括如何处理错误和任何一致性问题。有了这个基础,您可以在 Cloudflare Workers 上创建可扩展、可靠的应用程序,这些应用程序可以在一系列场景中有效利用 KV 存储。

  1. 有关使用 Cloudflare Workers 和 KV 集成的信息可以在 Cloudflare 的官方文档中找到。欲了解更多详情,请访问 Cloudflare Workers KV API
  2. 有关使用 Wrangler CLI 管理 Cloudflare Workers 的指南,请参阅 Cloudflare Wrangler 文档
  3. 有关处理 Cloudflare KV 和最终一致性的精彩教程,请访问: Cloudflare Workers KV 的工作原理