npm 上的 Fastly CLI:现在 JavaScript 触手可及

npm 上的 fastly cli:现在 javascript 触手可及

Fastly CLI 是 Fastly 官方推荐的命令行工具,用于与 Fastly API 交互。它是一个开源工具,开发者常在持续集成环境中使用,执行各种操作,例如创建服务、管理后端和域名,以及部署 Compute@Edge 包。对于使用 JavaScript 开发 Fastly Compute 的开发者来说,好消息来了!Fastly CLI 现已作为 npm 包发布。

自 Fastly Compute@Edge 平台支持 JavaScript 以来,已过去三年多,距离 JavaScript SDK v1.0 发布也近两年了。JavaScript 是该平台上非常流行的语言,也是许多开发者的首选。使用 JavaScript 开发 Fastly Compute 应用,能以高效有趣的方式创建边缘应用。我们希望让更多用户都能轻松使用它。

作为一家开发者优先的公司,我们一直致力于简化开发流程。我们思考:如何才能让开发者少点击几次、减少依赖、少安装一个工具就能完成工作?如何让 JavaScript Compute 开发更便捷?这就是我们推出此项改进的原因。

Fastly CLI 是一个开源工具,用于执行 Fastly 帐户操作。由于它用于运行和发布 Compute 应用,因此它是 JavaScript Fastly Compute 开发的必要工具,即使只是本地测试。以往,需要从 GitHub 获取预构建包,或通过 Homebrew(macOS)安装。虽然这些步骤对开发者来说并不陌生,但我们希望降低 Compute 应用开发的门槛。

立即学习“Java免费学习笔记(深入)”;

因此,从 10.14.0 版本开始,我们决定在 npmjs.org 上发布 Fastly CLI,作为额外的分发渠道。对于 2024 年的 JavaScript 开发者来说,npm 作为事实上的包仓库,大家都很熟悉。这意味着几乎所有开发者都能使用 npmjs.org,这使得它成为分发此重要工具的理想方式。

无需安装即可运行 Fastly CLI

npm 的一个便捷功能是 npx,它允许运行 npm 包中的命令,无需将其安装到项目中。只要系统已安装 Node.js 和 npm,即可直接调用 Fastly CLI:

npx @fastly/cli

第一次执行此命令时,npm 会提示你获取包;这会将其添加到你的环境 npm 缓存中,之后即可立即使用。

由于 Fastly CLI 总是使用附加参数调用,你只需在命令后指定参数即可。例如,列出 Fastly 帐户中的服务:

npx @fastly/cli service list

将 Fastly CLI 作为依赖项

npmjs.org 上的可用性意味着你可以将 Fastly CLI 作为标准依赖项添加到你的 JavaScript Compute 应用中:

npm install @fastly/cli

或者,添加到项目的 package.json 文件中:

{  "dependencies": {    "@fastly/cli": "^10.14.0"  }}

然后安装项目的依赖项:

npm install

这会将 @fastly/cli 作为依赖项安装到项目的 node_modules 目录中。它可以在 node_modules/.bin 子目录下调用,例如:

npx fastly

例如,在本地开发环境中启动应用:

npx fastly compute serve

此外,package.json 文件的 scripts 部分中对 Fastly 的任何引用现在都将找到本地安装的 @fastly/cli 版本,无需全局安装。

{  "scripts": {    "build": "js-compute-runtime src/index.js bin/main.wasm",    "start": "fastly compute serve",    "deploy": "fastly compute publish"  }}

无需全局安装

以往,每个使用 Fastly Compute 的开发者都需要全局安装 Fastly CLI,即使只是尝试使用该平台。通过将 Fastly CLI 作为 JavaScript 应用的标准依赖项,首次使用 Compute 的用户只需克隆其应用仓库、安装依赖项并输入 npm start 即可体验 Compute 应用。事实上,我们已更新所有 JavaScript 和 TypeScript 入门套件以采用此方法。

团队协作也更加便捷。你和其他开发者可以获取应用代码,使用标准流程安装依赖项,然后开始工作。

这种便利性也扩展到持续集成 (CI) 管道,使应用能够在其构建或测试过程中可靠地访问 Fastly CLI。

自信地使用 CLI 的新功能

Fastly CLI 持续更新,不断添加新功能和改进。

将 Fastly CLI 指定为包的标准依赖项,可以使用语义版本控制指定其版本。这使你的包能够安全地依赖最近添加的 CLI 功能,而无需担心其他开发者是否安装了兼容版本的 CLI。

从 Node.js 代码调用 Fastly CLI

如果你正在编写要在 Node.js 下运行并调用 Fastly CLI 的代码(例如在工具或实用程序中),此包提供了一种简单可靠的方法。

@fastly/cli 的默认导出解析为一个字符串值,表示 Fastly CLI 可执行文件的完整路径。它可以直接与 Node.js 中的 spawnsync 等函数一起使用。你无需让软件包的用户在运行程序之前全局安装 Fastly CLI。

以下示例 Node.js 程序执行 fastly version 命令:

import { spawnsync } from 'node:child_process';import fastly from '@fastly/cli';const result = spawnsync(fastly, [ 'version' ]);console.log(result.stdout);

甚至全局安装 Fastly CLI

如果你确实需要全局安装 Fastly CLI,此包也可以作为一种方法:

npm install -g @fastly/cli

安装后,像传统方式一样调用它:

fastly

底层机制与使用 npx @fastly/cli 调用环境中缓存的 CLI 副本没有什么不同。但是,此过程使命令在系统路径上尽快可用。最终结果与使用任何传统的全局安装方法相同,但此安装过程更方便,因为 npm 在许多机器上广泛可用。

将边缘计算带给更多开发者

在 Fastly,我们努力提供工具,让开发者能够在边缘运行更多代码,并使用熟悉的工具进行开发。我们不希望任何事情妨碍这一点。由于 JavaScript 是最流行的语言之一,npm 上 Fastly CLI 的发布进一步推动了这一使命。

我们期待听到用户的使用反馈。获取免费的 Fastly 开发者帐户,加入我们的 Fastly 社区论坛,并分享你的成果!

以上就是npm 上的 Fastly CLI:现在 JavaScript 触手可及的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1499809.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 22:04:31
下一篇 2025年12月19日 22:04:42

相关推荐

  • js怎样实现主题切换

    确保用户主题偏好在页面刷新后依然有效的方法是使用localstorage持久化存储;2. 页面加载时从localstorage读取主题设置并应用到html元素;3. 结合系统偏好(prefers-color-scheme)提供默认主题;4. 在大型项目中可采用组件级状态管理(如context api…

    2025年12月20日 好文分享
    000
  • JS如何实现策略模式

    策略模式通过封装算法使其可互换,JavaScript中利用函数作为一等公民实现,适用于表单验证等场景,结合工厂模式提升灵活性,但应避免过度设计。 策略模式的核心在于定义一系列算法,并将每一个算法封装起来,使它们可以相互替换。这使得算法可以在不影响客户端的情况下发生变化。在JS中,这可以通过函数作为一…

    2025年12月20日
    000
  • js如何实现分页功能

    js实现分页的核心是计算总页数并截取对应数据展示,1. 首先准备数据数组alldata,设定每页数量pagesize和当前页currentpage;2. 通过math.ceil(alldata.length / pagesize)计算总页数totalpages;3. 利用slice()方法截取(st…

    2025年12月20日
    000
  • JS如何实现发布订阅模式

    发布订阅模式通过中间调度中心解耦发布者与订阅者,1. 需实现eventemitter类包含subscribe、publish和unsubscribe方法;2. 在react中可通过context api共享事件总线实例;3. 组件使用useeffect订阅并在卸载时取消以避免内存泄漏;4. 与观察者…

    2025年12月20日
    000
  • 什么是主席树?主席树的可持久化

    主席树通过共享节点实现可持久化,支持查询历史版本,空间复杂度O(N log N),常用于静态区间第K大问题,其核心是在修改时仅新建必要节点,其余指向旧版本,从而高效保存多版本线段树。 主席树,又称可持久化线段树,本质上是一种可以查询历史版本线段树的数据结构。它通过共享线段树的节点,大幅降低了空间复杂…

    2025年12月20日
    000
  • js 如何格式化日期字符串

    javascript格式化日期字符串的核心是将date对象按需转换为指定格式,如”yyyy-mm-dd”或”mm/dd/yyyy hh:mm:ss”。最直接的方法是使用tolocaledatestring()和tolocaletimestring(),…

    2025年12月20日
    000
  • JS如何实现依赖注入?DI容器的实现

    答案:JavaScript实现依赖注入的核心是通过DI容器解耦组件与其依赖,提升可测试性、可维护性和模块独立性。容器通过register注册依赖,resolve递归解析并注入依赖,支持构造函数注入等模式,适用于中大型项目以集中管理复杂依赖,但需权衡学习成本与实际需求,避免过度设计。 JavaScri…

    2025年12月20日
    000
  • js 如何实现无限滚动

    传统的“加载更多”按钮会打断用户浏览的流畅性,迫使用户从内容消费中抽离进行操作,破坏沉浸感,尤其在移动端体验较差;2. 优化无限滚动性能需采用节流控制滚动事件频率、使用documentfragment减少dom操作、实施图片懒加载、优化后端响应,并在数据量大时引入列表虚拟化技术;3. 无限滚动不适用…

    2025年12月20日
    000
  • js怎样实现倒计时功能

    倒计时功能的核心是计算目标时间与当前时间的差值并实时更新显示,1. 获取目标时间需使用new date()创建日期对象,可基于utc避免时区偏差;2. 计算时间差通过gettime()获取毫秒数并转换为天、时、分、秒;3. 格式化显示使用padstart确保两位数展示;4. 使用setinterva…

    2025年12月20日 好文分享
    000
  • js怎样实现分页功能

    客户端分页适用于数据量较小(如几百到几千条)的场景,所有数据预先加载到浏览器,通过javascript切分显示,切换页面无网络延迟,适合数据变动少、追求流畅体验的内部系统或小型页面;2. 服务器端分页适用于大数据量(如成千上万条)的场景,每次请求只获取当前页数据,减轻浏览器负担,确保性能和可扩展性,…

    2025年12月20日 好文分享
    000
  • 哈希算法是什么?常见哈希函数介绍

    哈希算法是数据安全的基石,因其单向性、抗碰撞性和雪崩效应,广泛用于数据完整性校验、密码存储、数字签名和区块链。它通过固定长度哈希值确保信息不可篡改,即使输入微小变化也会导致输出巨大差异。MD5和SHA-1因碰撞漏洞已不安全,SHA-2(如SHA-256)成为主流,广泛用于区块链和SSL/TLS;SH…

    2025年12月20日
    000
  • javascript如何实现数组并发处理

    javascript中实现数组并发处理的核心是通过异步编程与任务调度提升数据处理效率。1. 使用promise.all()可并发执行所有任务,但任一失败则整体失败;2. promise.allsettled()确保所有任务完成,无论成功或失败,适合需收集全部结果的场景;3. 通过任务队列手动控制并发…

    2025年12月20日 好文分享
    000
  • javascript闭包怎样实现策略模式

    闭包实现策略模式的核心在于其能封装私有状态并返回可复用的函数,使策略具有独立上下文;2. 其优势包括极致的封装性、灵活的参数化、避免this指向问题及便于测试;3. 实际挑战包括调试困难、潜在内存泄漏和团队理解成本,可通过保持策略简洁、管理引用和加强文档来规避;4. 闭包还可应用于模块模式、单例模式…

    2025年12月20日 好文分享
    000
  • JS数字如何格式化

    js数字格式化的最直接方法是使用 tolocalestring(),它能根据地区或指定语言环境将数字转为更易读的字符串,如1234567变为1,234,567或1.234.567,89,并支持货币格式、小数位数控制等;对于非常大的数字,可通过 tolocalestring 配合 maximumsig…

    2025年12月20日
    000
  • js中如何实现路由跳转

    在javascript中实现路由跳转的核心是通过hash模式或history模式在不刷新页面的前提下改变url并动态渲染内容。1. hash模式利用url中#后的哈希值变化触发hashchange事件,兼容性好且无需服务器配置,但url不美观且不利于seo;2. history模式使用html5的p…

    2025年12月20日 好文分享
    000
  • JS如何实现内存管理?垃圾回收机制

    JavaScript通过自动内存管理和垃圾回收机制避免内存泄漏,核心是标记-清除算法与分代回收策略,结合Chrome DevTools的堆快照和时间线分析可有效诊断内存问题。 JavaScript的内存管理和垃圾回收机制,说白了,就是浏览器引擎(比如V8)在幕后默默地帮我们处理内存的分配与释放,这样…

    2025年12月20日
    000
  • 什么是Source Map?源码映射的应用

    Source Map是前端调试的基石,它将压缩混淆后的代码映射回原始源码,使开发者能在浏览器中直接调试TypeScript或ES6+代码;通过构建工具生成,支持错误堆栈还原,提升生产环境bug定位效率;需注意生产环境安全,避免源码泄露,常用hidden-source-map并配合Sentry等平台使…

    2025年12月20日
    000
  • js 怎样实现打印功能

    最直接的打印方式是调用 window.print() 方法,它会触发浏览器打印对话框并打印当前页面全部内容;2. 若需打印特定区域,推荐使用隐藏的 iframe 方式:创建一个隐藏 iframe,将目标内容及样式复制进去,调用其 contentwindow.print(),避免影响主页面;3. 精确…

    2025年12月20日
    000
  • 解决Angular中ngOnInit无法响应动态输入更新API链接的问题

    本文探讨了Angular应用中,当组件的@Input属性动态更新时,ngOnInit为何无法重新触发API调用以更新链接的问题。我们将深入分析Angular的生命周期钩子,并提供两种解决方案:一是采用服务层分离API逻辑的最佳实践,通过父组件管理数据流并使用async管道,使子组件成为“哑组件”;二…

    好文分享 2025年12月20日
    000
  • Angular中动态输入绑定与API请求更新策略指南

    本文旨在深入探讨Angular应用中,当组件的@Input属性发生变化时,如何正确地触发API请求并更新数据。我们将分析ngOnInit生命周期钩子在处理动态输入时的局限性,并提供两种核心解决方案:一是推荐的服务化数据获取与响应式编程模式,通过父组件协调数据流;二是利用ngOnChanges生命周期…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信