微服務(wù)Api網(wǎng)關(guān)框架-龍果學(xué)院 價(jià)值399
游客,如果您要查看本帖隱藏內(nèi)容請(qǐng) 回復(fù)
最近 微服務(wù)架構(gòu)在項(xiàng)目中的應(yīng)用越來越多,我們知道在微服務(wù)架構(gòu)風(fēng)格中,一個(gè)大應(yīng)用被拆分成為了多個(gè)小的服務(wù)系統(tǒng)提供出來,這些小的系統(tǒng)他們可以自成體系,也就是說這些小系統(tǒng)可以擁有自己的數(shù)據(jù)庫,框架甚至語言等,這些小系統(tǒng)通常以提供 Rest Api 風(fēng)格的接口來被 H5, Android, IOS 以及第三方應(yīng)用程序調(diào)用。
但是在UI上進(jìn)行展示的時(shí)候,我們通常需要在一個(gè)界面上展示很多數(shù)據(jù),這些數(shù)據(jù)可能來自于不同的微服務(wù)中,舉個(gè)例子。
在一個(gè)電商系統(tǒng)中,查看一個(gè)商品詳情頁,這個(gè)商品詳情頁包含商品的標(biāo)題,價(jià)格,庫存,評(píng)論等,這些數(shù)據(jù)對(duì)于后端來說可能是位于不同的微服務(wù)系統(tǒng)之中,可能我后臺(tái)的系統(tǒng)是這樣來拆分我的服務(wù)的:
產(chǎn)品服務(wù) - 負(fù)責(zé)提供商品的標(biāo)題,描述,規(guī)格等。
價(jià)格服務(wù) - 負(fù)責(zé)對(duì)產(chǎn)品進(jìn)行定價(jià),價(jià)格策略計(jì)算,促銷價(jià)等。
庫存服務(wù) - 負(fù)責(zé)產(chǎn)品庫存。
評(píng)價(jià)服務(wù) - 負(fù)責(zé)用戶對(duì)商品的評(píng)論,回復(fù)等。
現(xiàn)在,商品詳情頁需要從這些微服務(wù)中拉取相應(yīng)的信息,問題來了?
問題
由于我們使用的服務(wù)系統(tǒng)架構(gòu),所以沒辦法像傳統(tǒng)單體應(yīng)用一樣依靠數(shù)據(jù)庫的 join 查詢來得到最終結(jié)果,那么如何才能訪問各個(gè)服務(wù)呢?
按照微服務(wù)設(shè)計(jì)的指導(dǎo)原則,我們的微服務(wù)可能存在下面的問題:
服務(wù)使用了多種協(xié)議,因?yàn)椴煌膮f(xié)議有不同的應(yīng)場景用,比如可能同時(shí)使用 HTTP, AMQP, gRPC 等。
服務(wù)的劃分可能隨著時(shí)間而變化。
服務(wù)的實(shí)例或者Host+端口可能會(huì)動(dòng)態(tài)的變化。
那么,對(duì)于前端的UI需求也可能會(huì)有以下幾種:
粗粒度的API,而微服務(wù)通常提供的細(xì)粒度的API,對(duì)于UI來說如果要調(diào)用細(xì)粒度的api可能需要調(diào)用很多次,這是個(gè)不小的問題。
不同的客戶端設(shè)備可能需要不同的數(shù)據(jù)。Web,H5,APP
不同設(shè)備的網(wǎng)絡(luò)性能,對(duì)于多個(gè)api來說,這個(gè)訪問需要轉(zhuǎn)移的服務(wù)端會(huì)快得多
以上,就是我們構(gòu)建微服務(wù)的過程中可能會(huì)遇到的問題。那么如何解決呢?
這種情況下, API 網(wǎng)關(guān)(API Gataway)誕生了。
API 網(wǎng)關(guān)
API網(wǎng)關(guān)是一個(gè)服務(wù)器,是系統(tǒng)的唯一入口。從面向?qū)ο笤O(shè)計(jì)的角度看,它與外觀模式類似。API網(wǎng)關(guān)封裝了系統(tǒng)內(nèi)部架構(gòu),為每個(gè)客戶端提供一個(gè)定制的API。它可能還具有其它職責(zé),如身份驗(yàn)證、監(jiān)控、負(fù)載均衡、緩存、請(qǐng)求分片與管理、靜態(tài)響應(yīng)處理。
API網(wǎng)關(guān)方式的核心要點(diǎn)是,所有的客戶端和消費(fèi)端都通過統(tǒng)一的網(wǎng)關(guān)接入微服務(wù),在網(wǎng)關(guān)層處理所有的非業(yè)務(wù)功能。通常,網(wǎng)關(guān)也是提供REST/HTTP的訪問API。服務(wù)端通過API-GW注冊(cè)和管理服務(wù)。
API網(wǎng)關(guān)網(wǎng)關(guān)的價(jià)值:
網(wǎng)關(guān)層對(duì)外部和內(nèi)部進(jìn)行了隔離,保障了后臺(tái)服務(wù)的安全性。
對(duì)外訪問控制由網(wǎng)絡(luò)層面轉(zhuǎn)換成了運(yùn)維層面,減少變更的流程和錯(cuò)誤成本
減少客戶端與服務(wù)的耦合,服務(wù)可以獨(dú)立發(fā)展。通過網(wǎng)關(guān)層來做映射。
通過網(wǎng)關(guān)層聚合,減少外部訪問的頻次,提升訪問效率。
節(jié)約后端服務(wù)開發(fā)成本,減少上線風(fēng)險(xiǎn)。
為服務(wù)熔斷,灰度發(fā)布,線上測(cè)試提供簡單方案。
當(dāng)然現(xiàn)在市面上的Api網(wǎng)關(guān)開源項(xiàng)目,有以下項(xiàng)目
Tyk:Tyk是一個(gè)開放源碼的API網(wǎng)關(guān),它是快速、可擴(kuò)展和現(xiàn)代的。Tyk提供了一個(gè)API管理平臺(tái),其中包括API網(wǎng)關(guān)、API分析、開發(fā)人員門戶和API管理面板。Try 是一個(gè)基于Go實(shí)現(xiàn)的網(wǎng)關(guān)服務(wù)。
Kong:Kong是一個(gè)可擴(kuò)展的開放源碼API Layer(也稱為API網(wǎng)關(guān)或API中間件)。Kong 在任何RESTful API的前面運(yùn)行,通過插件擴(kuò)展,它提供了超越核心平臺(tái)的額外功能和服務(wù)。
Orange:和Kong類似也是基于OpenResty的一個(gè)API網(wǎng)關(guān)程序,是由國人開發(fā)的。
Netflix zuul:Zuul是一種提供動(dòng)態(tài)路由、監(jiān)視、彈性、安全性等功能的邊緣服務(wù)。Zuul是Netflix出品的一個(gè)基于JVM路由和服務(wù)端的負(fù)載均衡器。
apiaxle: Nodejs 實(shí)現(xiàn)的一個(gè) API 網(wǎng)關(guān)。
api-umbrella: Ruby 實(shí)現(xiàn)的一個(gè) API 網(wǎng)關(guān)。
老顧這系列課程就給大家介紹一下nignx + lua方式的網(wǎng)關(guān)框架,也是很多公司常用的網(wǎng)關(guān)框架
課程大綱
第1章 第一章
第1講 漫談網(wǎng)關(guān)架構(gòu)
第2講 網(wǎng)關(guān)技術(shù)選型
第3講 nginx下載安裝
第4講 正向代理、反向代理
第5講 nginx命令、信號(hào)控制
第6講 nginx平滑升級(jí)
第7講 nginx配置文件說明
第8講 nginx配置連接數(shù)
第9講 nginx虛擬主機(jī)
第10講 nginx日志以及切割
第11講 nginx的location詳解
第12講 nginx的負(fù)載均衡
第13講 nginx的echo模塊安裝
第14講 openresty背景介紹
第15講 openresty安裝
第16講 openresty的helloworld
第17講 lua介紹以及helloworld
第18講 lua基本語法一
第19講 lua基本語法二
第20講 lua基本語法三
第21講 lua基本語法四
第22講 lua運(yùn)算符
第23講 lua控制結(jié)構(gòu)一
第24講 lua控制結(jié)構(gòu)二
第25講 lua的正則表達(dá)式
第26講 lua的string操作
第27講 lua的table操作
第28講 lua變量
第29講 lua時(shí)間操作
第30講 lua模塊
第31講 lua元表
第32講 lua面向?qū)ο?br />
第33講 openresty中使用lua
第34講 openresty中使用json模塊
第35講 openresty中使用redis模塊
第36講 openresty中封裝redis操作
第37講 openresty中使用mysql
第38講 lua發(fā)起http請(qǐng)求
第39講 openresty中使用http模塊
第40講 openresty中使用全局緩存
第41講 openresty執(zhí)行流程
第42講 openresty執(zhí)行詳解之初始化階段
第43講 openresty執(zhí)行詳解之重寫賦值階段
第44講 openresty執(zhí)行詳解之重寫url階段
第45講 openresty執(zhí)行詳解之訪問階段
第46講 openresty執(zhí)行詳解之內(nèi)容階段
第47講 openresty執(zhí)行詳解之響應(yīng)階段
第48講 openresty實(shí)現(xiàn)訪問頻率控制
第49講 openresty實(shí)現(xiàn)黑名單控制
第50講 openresty實(shí)現(xiàn)接口簽名驗(yàn)證
第51講 openresty實(shí)現(xiàn)網(wǎng)關(guān)框架
第52講 openresty實(shí)現(xiàn)網(wǎng)關(guān)主入口
第53講 openresty實(shí)現(xiàn)網(wǎng)關(guān)插件可配置
第54講 openresty實(shí)現(xiàn)網(wǎng)關(guān)插件加載
第55講 openresy實(shí)現(xiàn)網(wǎng)關(guān)之簽名驗(yàn)證插件
第56講 openresy實(shí)現(xiàn)網(wǎng)關(guān)之黑名單插件
第57講 openresty實(shí)現(xiàn)網(wǎng)關(guān)之頻率插件
第58講 網(wǎng)關(guān)框架總結(jié)
|