探索 Cloudflare Workers:高效边缘计算的新选择

随着现代应用对低延迟、高可扩展性的需求日益增长,边缘计算成为了热门话题。而在边缘计算中,Cloudflare Workers 作为一种轻量级、功能强大的计算平台,脱颖而出。本文将深入探讨 Cloudflare Workers 的技术特性、核心优势,以及如何通过实例实现具体的应用场景。

什么是 Cloudflare Workers?

Cloudflare Workers 是一种基于 Cloudflare 全球边缘网络的无服务器计算平台。它允许开发者通过 JavaScript、TypeScript 或 WebAssembly 在边缘位置直接运行代码,缩短响应时间并减少服务器负载。

其主要特性包括:

  1. 全球分布:Cloudflare 在全球 300 多个数据中心部署边缘节点,代码运行在距离用户最近的位置。

  2. 无冷启动:基于 V8 引擎实现,无需担心传统无服务器架构中的冷启动问题。

  3. 支持标准 API:兼容 Fetch API、Streams 和其他现代 Web 标准。

  4. 小型化:Worker 脚本最大大小为 1 MB,但执行性能优秀,适合处理轻量级逻辑。

接下来,我们将展示如何设置和使用 Cloudflare Workers。


开始使用 Cloudflare Workers

1. 创建第一个 Worker

首先,确保已安装 wrangler CLI 工具,这是管理 Cloudflare Workers 的核心工具。

npm install -g wrangler
初始化项目

通过 wrangler 初始化一个新的 Worker 项目:

wrangler init my-first-worker
cd my-first-worker

此命令会生成一个基础的项目结构,包括 wrangler.toml 配置文件和入口脚本 index.js

编写代码

编辑 index.js,实现一个简单的 HTTP 响应:

export default {
  fetch(request) {
    return new Response("Hello, Cloudflare Workers!", {
      headers: { "Content-Type": "text/plain" },
    });
  },
};
部署 Worker

使用以下命令将 Worker 部署到 Cloudflare:

wrangler publish

完成后,你会得到一个 Worker 的 URL,访问即可看到运行结果。


深入探索 Cloudflare Workers 的功能

2. 处理自定义路由

Cloudflare Workers 可以轻松处理自定义路由和不同的请求路径。以下代码实现了简单的路由逻辑:

export default {
  async fetch(request) {
    const url = new URL(request.url);
    switch (url.pathname) {
      case "/api":
        return new Response(JSON.stringify({ message: "API endpoint" }), {
          headers: { "Content-Type": "application/json" },
        });
      case "/hello":
        return new Response("Hello, user!", {
          headers: { "Content-Type": "text/plain" },
        });
      default:
        return new Response("Not found", { status: 404 });
    }
  },
};

3. 与 KV 存储集成

Cloudflare Workers 支持与 Workers KV(键值存储)集成,用于快速存储和检索数据。

配置 KV 存储

wrangler.toml 文件中添加 KV 命名空间:

[[kv_namespaces]]
binding = "MY_KV" # 绑定到 Worker 的名称
id = "<namespace-id>" # 从 Cloudflare Dashboard 获取
使用 KV 存储

在 Worker 中读取和写入 KV 数据:

export default {
  async fetch(request, env) {
    if (request.method === "GET") {
      const value = await env.MY_KV.get("key1");
      return new Response(value || "No data found");
    } else if (request.method === "POST") {
      await env.MY_KV.put("key1", "Hello, KV!");
      return new Response("Data saved to KV.");
    }
  },
};

4. 执行复杂任务:图像优化

Cloudflare Workers 还能处理复杂的任务,比如图像优化。以下是基于 Workers 和 Cloudflare Images API 的简单示例:

export default {
  async fetch(request) {
    const url = new URL(request.url);
    if (url.pathname.startsWith("/images")) {
      const imageUrl = url.searchParams.get("url");
      const optimized = `https://imagedelivery.net/<your-account-id>/<image-id>/public`;
      return fetch(optimized);
    }
    return new Response("Invalid request", { status: 400 });
  },
};

应用场景与实践

边缘身份验证

使用 Cloudflare Workers 验证用户请求是否携带有效的 JWT(JSON Web Token):

import jwt from "jsonwebtoken";

export default {
  async fetch(request) {
    const token = request.headers.get("Authorization")?.split(" ")[1];
    try {
      const decoded = jwt.verify(token, "your-secret-key");
      return new Response(`Hello, ${decoded.user}`);
    } catch (err) {
      return new Response("Unauthorized", { status: 401 });
    }
  },
};

全球缓存

通过 Workers 缓存 API 提升静态资源的全球可用性:

export default {
  async fetch(request) {
    const cache = caches.default;
    let response = await cache.match(request);
    if (!response) {
      response = await fetch(request);
      response = new Response(response.body, response);
      response.headers.append("Cache-Control", "max-age=3600");
      await cache.put(request, response.clone());
    }
    return response;
  },
};

总结

Cloudflare Workers 是一项强大的边缘计算服务,其简洁、高效的特性让开发者能够轻松应对低延迟、高并发的应用需求。无论是 API 服务、身份验证还是缓存优化,Cloudflare Workers 都提供了灵活的解决方案。希望本文的内容能够帮助你快速上手并充分发挥 Cloudflare Workers 的潜力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/952179.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络相关习题整理

第一讲 传输媒介 【知识点回顾】 两种导线可以减小电磁干扰&#xff1a; 双绞线&#xff08;分为非屏蔽双绞线、屏蔽双绞线&#xff09;&#xff08;RJ-45用&#xff09;同轴电缆&#xff08;短距离使用&#xff09;网络通信的基本单位&#xff1a;位&#xff08;bit&#xff…

应急响应之入侵排查(下)

一.进程排查 1.Windows 任务管理器查看 在 Windows 系统中&#xff0c;可通过任务管理器查看进程信息。操作步骤为&#xff1a;在任务管理器界面&#xff0c;于 “查看” 选项中选择 “选择列”&#xff0c;随后添加 “映像路径名称” 和 “命令行”&#xff0c;以此查看更多进…

极狐GitLab 正式发布安全版本17.7.1、17.6.3、17.5.5

本分分享极狐GitLab 补丁版本 17.7.1, 17.6.3, 17.5.5 的详细内容。这几个版本包含重要的缺陷和安全修复代码&#xff0c;我们强烈建议所有私有化部署用户应该立即升级到上述的某一个版本。对于极狐GitLab SaaS&#xff0c;技术团队已经进行了升级&#xff0c;无需用户采取任何…

力扣经典二分题:4. 寻找两个正序数组的中位数

题目链接&#xff1a;4. 寻找两个正序数组的中位数 - 力扣&#xff08;LeetCode&#xff09; 一、题目分析 这道题目是让我们在 两个正序的数组中寻找中位数已知两个数组的大小分别是&#xff1a;int m nums1.size(),n nums2.size();中位数性质1&#xff1a;中位数左侧元素 …

安装yarn时显示npm使用淘宝镜像安装报错

问题描述&#xff1a; npm使用淘宝镜像安装报错 错误原因&#xff1a; 淘宝原镜像域名&#xff08;registry.npm.taobao.org&#xff09;的 HTTPS 证书正式到期&#xff0c;npm 淘宝镜像已经从 registry.npm.taobao.org 切换到了 registry.npmmirror.com。解决方案&#xff1a;…

【Python】Python之Selenium基础教程+实战demo:提升你的测试+测试数据构造的效率!

这里写目录标题 什么是Selenium&#xff1f;Selenium基础用法详解环境搭建编写第一个Selenium脚本解析脚本脚本执行结果常用的元素定位方法常用的WebDriver方法等待机制 Selenium高级技巧详解页面元素操作处理弹窗和警告框截图和日志记录多窗口和多标签页操作 一个实战的小demo…

Seata搭建

1.初识Seata Quick Start | Apache Seata 官网 2.准备nacos和 seata 启动nacos startup.cmd -m standalone账号nacos 密码nacos 搭建seata TC 这里下载的 1.4.2 seata-server-1.4.2 1.修改seata配置文件 registry.conf 这里我们使用nacos作为注册中心 和 配置中心 r…

selenium+pyqt5自动化工具总结

说明&#xff1a;本工具是&#xff0c;操作外部google浏览器、selenium是无法操作qt界面中嵌套的浏览器的&#xff0c; 工具在后面 1. 代码结构 pycharm打开的文件下&#xff0c;再写一个子文件&#xff0c;文件导入的时候把子文件名带上 这样就可以在 外层使用命令 pyinst…

.NET 终止或结束进程

如何使用 C# 终止进程。 使用简单的方法终止.NET中的现有进程Process.Kill()。有一个可选参数 true 或 false&#xff0c;用于结束与要结束的进程相关的所有子进程。 了解如何创建流程。 结束当前进程&#xff1a; System.Diagnostics.Process.GetCurrentProcess().Kill(tru…

怎么实现Redis的高可用?

大家好&#xff0c;我是锋哥。今天分享关于【怎么实现Redis的高可用&#xff1f;】面试题。希望对大家有帮助&#xff1b; 怎么实现Redis的高可用&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 为了实现 Redis 的高可用性&#xff0c;我们需要保证在发…

大数据技术实训:Hadoop完全分布式运行模式配置

准备&#xff1a; 1&#xff09;准备3台客户机&#xff08;关闭防火墙、静态ip、主机名称&#xff09; 2&#xff09;安装JDK 3&#xff09;配置环境变量 4&#xff09;安装Hadoop 5&#xff09;配置环境变量 6&#xff09;配置集群 7&#xff09;单点启动 8&#xff09;配置ss…

【Uniapp-Vue3】Prop校验与prop默认值用法及循环遍历数组对象

一、prop校验 如果我们在想要限制prop的类型&#xff0c;就可以在接收prop的时候对接收类型进行限制&#xff1a; defineProps({ 属性名:{ type:类型 } }) 需要注意类型的首字母大写 但是设置了传入参数类型限制并不能严格限制&#xff0c;只会在后台进行提示&#xff1a; 二、…

开启Excel导航仪,跨表跳转不迷路-Excel易用宝

都2025年了&#xff0c;汽车都有导航了&#xff0c;你的表格还没有导航仪吗&#xff1f;那也太OUT了。 面对着一个工作簿中有N多个工作表&#xff0c;工作表中又有超级表&#xff0c;数据透视表&#xff0c;图表等元素&#xff0c;如何快速的切换跳转到需要查看的数据呢&#…

【Unity3D日常开发】Unity3D中适用WEBGL打开Window文件对话框打开/上传文件

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享QQ群&#xff1a;398291828小红书小破站 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 Unity3D发布的WEBGL程序是不支持直接的I/O操…

《安富莱嵌入式周报》第348期:开源低功耗测试仪,开源创意万用表,续航100-300小时,开源PCB电机,自制shell和网络协议栈,开源水培自动化系统

周报汇总地址&#xff1a;嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 视频版&#xff1a; https://www.bilibili.com/video/BV1Tzr9Y3EQ7/ 《安富莱嵌入式周报》第348期&#xff1a;开源低功…

音频合成的常见问题

使用了1年多的音频合成&#xff0c;有些常见的问题分享给大家 。 一、音质问题 噪声 背景噪声&#xff1a;在音频合成过程中&#xff0c;可能会引入背景噪声。这可能是由于原始音频素材本身质量不佳&#xff0c;比如录制环境嘈杂&#xff0c;包含电脑风扇声、外界交通声等。当…

用AI技术提升Flutter开发效率:ScriptEcho的力量

引言 在当今快速发展的技术时代&#xff0c;Flutter作为一种跨平台开发框架&#xff0c;正在越来越多的开发者中崭露头角。它不仅能够为开发者提供一套代码同时部署到iOS和Android平台的解决方案&#xff0c;还能帮助企业节省人力成本和开发时间。然而&#xff0c;对于新手开发…

SmartAIChain荣获重要认可

2024年12月21日,洛杉矶尔湾市——在今年尔湾举办的交流会上,黄荣先生的SmartAIChain项目获得了重要认可。此次活动汇聚了来自各地的杰出人才以及社区代表,共同庆祝这一创新性艺术的时刻。 在活动中,核桃市议员伍立伦(Allen Wu)的代表黄冬平女士发言,并为黄荣先生颁发了荣誉证书…

EFT信号测试和电源测试经验笔记

1. 什么是EFT 标准&#xff1a;perlEC 61000-4-4 eft设备将群脉冲干扰加到信号或者电源上&#xff0c;常见的频率是 5K 100K 两个频率 电压 电源3k&#xff0c;信号2k -----电网设备 电源4K -------------------空调设备 大概就是下图这样的周期性脉冲 1.1 电源eft 通过信…

web前端学习总结(一)

web前端使用三项技术:html、css、javascript. 一、html:超文本标记语言&#xff0c;用于展示网页的框架。 <html> <head><title> </title></head><body><div> </div> <!--用于布局&#xff0c;占1行 --><span&g…