為什么選擇事件驅(qū)動的 API?
事件驅(qū)動的 API 通過事件實現(xiàn)組件間的實時通信。以下是其核心概念的分解:
事件 :指系統(tǒng)中狀態(tài)的變化或更新,例如新用戶注冊或支付狀態(tài)更新。在事件驅(qū)動系統(tǒng)中,稱為發(fā)布者(Publisher) 的組件將事件發(fā)送到消息代理,消息代理再將事件分發(fā)給所有訂閱該事件的訂閱者(Subscriber) 。這種方式使得系統(tǒng)組件無需直接通信即可實現(xiàn)實時交互。
例如,在一個聊天應用中,當用戶發(fā)送消息時,事件驅(qū)動的 API 能立即通知其他用戶,消息會實時顯示在聊天窗口中,而無需刷新頁面。而傳統(tǒng)的同步 API 則需要客戶端 頻繁輪詢服務器以檢查新消息。
相比之下,事件驅(qū)動的 API 通過解耦組件,允許發(fā)布者和訂閱者獨立運行,從而實現(xiàn)更高的靈活性和效率。
使用 AsyncAPI 構(gòu)建 Node.js 事件驅(qū)動 API
AsyncAPI 的優(yōu)勢
AsyncAPI 提供了一種標準化的方法來定義事件驅(qū)動 API 的事件、通道和消息格式,使開發(fā)者能夠更輕松地理解和使用這些 API。
在開始實現(xiàn)基于 AsyncAPI 的 Node.js 事件驅(qū)動 API 之前,請確保安裝以下工具和依賴項:
Node.js 和 npm
AsyncAPI Generator
安裝完成后,按照以下步驟實現(xiàn)事件驅(qū)動 API。
1. 創(chuàng)建 AsyncAPI 文件
首先,創(chuàng)建一個 AsyncAPI 文件,用于定義事件驅(qū)動系統(tǒng)中的事件及其數(shù)據(jù)結(jié)構(gòu)。AsyncAPI 文件可以使用 YAML 或 JSON 格式編寫,主要包含以下組件:
asyncapi :指定 AsyncAPI 規(guī)范的版本(例如 v2.6.0)。
info :包含 API 的元數(shù)據(jù)(如標題、版本、描述等)。
servers :列出可用的服務器及其協(xié)議配置。
channels :定義 API 的通道及其操作。
components :可選部分,用于定義可重用的組件(如消息有效載荷和安全方案)。
以下是一個聊天應用的 AsyncAPI 文件示例:
asyncapi: 2.6.0
info:
title: 聊天應用程序
version: 1.0.0
servers:
test:
url: test.mosquitto.org:1883
protocol: mqtt
description: 測試代理
channels:
chat:
publish:
operationId: onMessageReceived
message:
name: text
payload:
type: string
subscribe:
operationId: sendMessage
message:
name: text
payload:
type: string
在上述文件中:
定義了一個使用 MQTT 協(xié)議的聊天應用程序。
chat 通道允許客戶端通過 publish 方法發(fā)送消息,并通過 subscribe 方法接收消息。
2. 使用 AsyncAPI 生成器生成應用代碼
安裝 AsyncAPI 生成器:
npm install -g @asyncapi/generator
使用以下命令從 AsyncAPI 文件生成 Node.js 應用代碼:
ag asyncapi.yaml @asyncapi/nodejs-template -p server=test -o example
運行命令后,生成的代碼將包含一個完整的 Node.js 應用程序。接下來,安裝依賴并運行應用程序:
cd example
npm install
npm start
3. 測試 AsyncAPI Node.js 應用程序
要測試應用程序,可以使用 MQTT.js 庫向消息代理發(fā)送消息。首先安裝該庫:
npm install mqtt
然后運行以下命令,通過 chat 通道向測試代理發(fā)送消息:
mqtt pub -t 'chat' -h 'test.mosquitto.org' -m "Hello World"
在運行應用程序的終端窗口中,您應該看到以下輸出:
← 收到聊天:"{text: Hello World}"
這表明應用程序已成功接收到消息。您可以在 examples/src/api/handlers/chat.js 中找到消息處理邏輯的代碼模板,并根據(jù)需求實現(xiàn)業(yè)務邏輯。
使用 Bump.sh 管理 AsyncAPI 文件
通過創(chuàng)建 AsyncAPI 文件,實際上您已經(jīng)生成了一個 API 合約。API 合約明確規(guī)定了組件及其行為,例如可用事件、數(shù)據(jù)結(jié)構(gòu)和使用規(guī)則。
使用 Bump.sh,您可以記錄和跟蹤事件驅(qū)動 API 的更改。以下是使用 CLI 上傳 AsyncAPI 文件的步驟:
安裝 Bump CLI:
npm install -g bump-cli
預覽生成的 API 文檔:
bump preview path/to/file.json/yml
CLI 將生成一個 URL,您可以通過該 URL 查看 API 文檔 的呈現(xiàn)效果。當 AsyncAPI 文件準備好部署時,可以按照 Bump.sh 的指南將文檔上線并共享。
結(jié)論
事件驅(qū)動 API 提供了實時、響應式和松散耦合的系統(tǒng)架構(gòu),而 AsyncAPI 是定義這些 API 的理想工具。結(jié)合使用 AsyncAPI 和 Bump.sh,您可以為事件驅(qū)動 API 創(chuàng)建高質(zhì)量的文檔,提升開發(fā)和協(xié)作效率。
如果您有任何問題或建議,歡迎隨時與我們聯(lián)系!
原文鏈接: https://bump.sh/blog/asyncapi-first-event-driven-api
熱門推薦
一個賬號試用1000+ API
助力AI無縫鏈接物理世界 · 無需多次注冊
免費開始試用 →
3000+提示詞助力AI大模型
和專業(yè)工程師共享工作效率翻倍的秘密
国内精品久久久久影院日本,日本中文字幕视频,99久久精品99999久久,又粗又大又黄又硬又爽毛片
精品久久久久99 |
97se亚洲国产综合在线 |
亚洲v中文字幕 |
一本大道av伊人久久综合 |
中文字幕av不卡 |
成人午夜av电影 |
亚洲欧洲国产日本综合 |
91玉足脚交白嫩脚丫在线播放 |
久久女同精品一区二区 |
国产成人av电影 |
亚洲精品国产精品乱码不99 |
欧美日韩综合一区 |
麻豆国产精品一区二区三区
|
国产精品麻豆视频 |
91麻豆国产精品久久 |
午夜av一区二区 |
国产亚洲精品资源在线26u |
91玉足脚交白嫩脚丫在线播放 |
亚洲.国产.中文慕字在线 |
精品国产制服丝袜高跟 |
成人av在线影院 |
日韩中文字幕亚洲一区二区va在线 |
久久久久久久久久电影 |
欧美日韩亚洲综合 |
国产成人av影院 |
日韩精品一二三四 |
亚洲青青青在线视频 |
精品国产免费久久 |
91精品国产一区二区三区蜜臀 |
国产aⅴ综合色 |
日韩高清不卡一区 |
有坂深雪av一区二区精品 |
欧美成人bangbros |
91麻豆精品久久久久蜜臀 |
91亚洲精品久久久蜜桃 |
国产美女在线精品 |
日韩国产精品久久久久久亚洲 |
中文字幕亚洲不卡 |
日本一区二区三级电影在线观看 |
欧美高清视频一二三区 |
91福利资源站 |
99久久精品国产导航 |
成人深夜福利app |
国产剧情一区二区三区 |
九九久久精品视频 |
激情综合网天天干 |
国产成人免费9x9x人网站视频 |
精品免费日韩av |
欧美日韩国产bt |
欧美在线小视频 |
日本精品一区二区三区四区的功能 |
国产一区福利在线 |
国产一区二区三区在线观看精品 |
免费成人在线网站 |
免费观看久久久4p |
老司机精品视频导航 |
日本一道高清亚洲日美韩 |
午夜激情久久久 |
激情伊人五月天久久综合 |
老司机午夜精品 |
国产麻豆欧美日韩一区 |
丁香一区二区三区 |
日本韩国精品在线 |
欧美一区午夜视频在线观看
|
亚洲黄色小视频 |
一区二区三区蜜桃 |
日韩精品一二区 |
国产在线播放一区三区四 |
高潮精品一区videoshd |
国产成人三级在线观看 |
91丨porny丨最新 |
欧美日韩免费视频 |
久久视频一区二区 |
国产精品电影一区二区 |
日韩av一区二区在线影视 |
国内精品伊人久久久久av影院
|
亚洲欧洲一区二区在线播放 |
亚洲一级二级三级 |
精品在线你懂的 |
91啪亚洲精品 |
日韩精品一区二区三区视频 |
国产精品亲子伦对白 |
日韩中文字幕一区二区三区 |
国产ts人妖一区二区 |
欧美人与z0zoxxxx视频 |
国产视频一区不卡 |
日韩电影网1区2区 |
成人福利在线看 |
91精品国产手机 |
一区二区三区日韩欧美精品 |
久久99精品久久久久久动态图
|
91精品国产综合久久香蕉麻豆 |
国产女人水真多18毛片18精品视频 |
性久久久久久久 |
色综合天天综合色综合av
|
国产成人综合在线 |
3751色影院一区二区三区 |
樱花草国产18久久久久 |
国产黄色精品网站 |
精品久久一区二区 |
蜜乳av一区二区 |
91精品麻豆日日躁夜夜躁 |
亚洲欧美一区二区三区国产精品 |
国产成人精品一区二 |
日韩一级在线观看 |
日本一道高清亚洲日美韩 |
欧美三级电影网站 |
亚洲一二三四在线观看 |
色综合 综合色 |
国产精品久久毛片a |
成人免费视频播放 |
国产精品乱码人人做人人爱
|
欧美精品自拍偷拍 |
亚洲国产精品影院 |
欧美日韩国产精品自在自线 |
亚洲一级二级在线 |
欧美精品xxxxbbbb |
精品一区二区三区不卡
|
欧美一区二区三区影视 |
三级亚洲高清视频 |
日韩一区二区三区三四区视频在线观看 |
一区二区三区视频在线观看 |
一本高清dvd不卡在线观看 |
亚洲男人电影天堂 |
欧美丝袜丝交足nylons |
五月天亚洲精品 |
欧美mv日韩mv亚洲 |
成人黄色小视频 |
亚洲国产精品久久久久婷婷884 |
欧美日韩日日骚 |
精品午夜久久福利影院 |
中文字幕一区在线观看视频 |
欧美系列日韩一区 |
久久国产尿小便嘘嘘 |
国产精品国产自产拍高清av |
91久久免费观看 |
日韩av一区二区三区四区 |
久久只精品国产 |
91福利国产成人精品照片 |
久久精品久久精品 |
伊人夜夜躁av伊人久久 |
日韩精品综合一本久道在线视频 |
成人黄色在线看 |
日本va欧美va精品发布 |
亚洲视频一二三区 |
精品国精品国产 |
欧美三级视频在线 |
av亚洲精华国产精华 |
精品一区二区影视 |
午夜精品影院在线观看 |
中文字幕不卡在线观看 |
欧美成人女星排行榜 |
欧美视频在线一区二区三区 |
国产.欧美.日韩 |
国产一区二区三区四 |
日韩电影免费在线看 |
亚洲综合色在线 |
亚洲美女淫视频 |
国产精品丝袜在线 |
久久影视一区二区 |
日韩免费在线观看 |
日韩一区二区在线看 |
欧美亚洲综合久久 |
色哟哟日韩精品 |
成人av电影在线 |
成人午夜免费电影 |
国产成人在线观看免费网站 |
精品一区二区久久 |
国内精品伊人久久久久av影院 |
日韩激情一区二区 |
美女高潮久久久 |
久久精品国产免费 |
精品一区二区三区免费观看 |
激情五月婷婷综合 |
黑人巨大精品欧美黑白配亚洲 |
国产在线一区观看 |
国产不卡免费视频 |
91捆绑美女网站 |
欧美三区在线观看 |
日韩欧美精品三级 |
国产欧美视频一区二区 |
中文字幕在线不卡 |
亚洲国产精品视频 |
美女诱惑一区二区 |
激情欧美一区二区三区在线观看 |
精品一区二区三区免费观看 |
懂色av一区二区三区免费看 |
av资源网一区 |
欧美日韩国产bt |
日本一区二区三区国色天香
|
日韩欧美激情四射 |
国产精品成人免费精品自在线观看 |
亚洲激情图片qvod |
久久福利视频一区二区 |
国产在线精品一区二区不卡了 |
国产**成人网毛片九色 |
欧美日韩卡一卡二 |
中文字幕第一区 |
麻豆精品国产91久久久久久 |
色老汉一区二区三区 |