java 微服務源碼_基于Java的微服務架構源碼案例Abixen

微服務越來越受歡迎,每個月都有更多的庫包和解決方案來支持微服務的開發測試,很多Java開發人員雖然聽說過微服務,但是真正采用還是有猶豫的:“我知道,微服務是非常棒的,微服務器更容易維護和進一步開發,但我們沒有建立一個良好的基于??微服務架構的資源。”

許多嘗試創建微服務應用程序(例如使用Netflix OSS堆棧)的開發人員都疑惑他們是否有足夠的知識來配置整個系統。因為微服務架構所需知識與與單片monolithic 應用程序非常不同,需要額外的組件功能,如請求監視,用于在服務之間共享通信的隊列,注冊表服務,配置服務等等。同時為每個微服務保留一個單獨的數據模型也是一個很好的做法。

在創建模塊化Web應用程序時,開發人員必須專注于精心設計的業務領域設計。將模塊之間的所有耦合最小化,這樣至少避免了體系架構的復雜性。

Abixen Platform是一個完整的微服務架構系統,其源碼可見Github地址:https://github.com/abixen/abixen-platform,其體系組成部分如下:

1. Eureka:作為服務的注冊器。

2. Hystrix儀表板:允許我們實時監控請求狀態(例如,多少請求超時,多少次成功,多少次失敗等)。

3. Zipkin:一種分布式跟蹤系統,可幫助您收集應用程序中發生高延遲問題(性能慢)所需的數據。

4. Redis數據庫:用于保存登錄用戶的信息。

5. RabbitMQ:用作在特定微服務器之間發送消息的隊列。例如,核心微服務刪除一個模塊實例,需要讓商業智能微服務或Web內容微服務刪除與其相關的所有配置。

6. Abixen Platform Common:包含用函數式微服務實現的通用API的JAR。

7. Abixen平臺配置:配置微服務。整個應用程序可以在YAML文件中進行逐個配置。

8. Abixen Platform Web Client:核心功能的靜態內容,如頁面和模塊管理,安全管理等。

9. Abixen平臺網關:起到安全網關的作用。每個請求都必須通過這個微服務。

10. Abixen平臺核心:擁有自己的業務核心數據庫,擁有平臺的核心功能,如頁面和模塊管理,安全管理等。

11. Abixen平臺商業智能服務:由于應用程序帶來了函數性的微服務,因此我們將在這里放置一個用于商業智能報告,圖表創建和進一步管理的模塊。它也有自己的數據庫。

12. Abixen平臺Web內容服務:這與上述服務類似,但是這個函數可以提供內容創建功能,例如用戶可以創建文章。它還有自己的數據庫。

13. 您的服務:由開發人員使用該平臺創建的定制微服務。

該架構基于Netflix OSS技術棧。函數性的微服務不需要在整個平臺上都要部署,您如果不需要圖表或文章管理器,您也可以部署這個平臺并使用獨立開發的微服務。

該架構也很好地映射到Amazon組件。使用諸如EC2,ALB,ECS,ECR,Route53,CloudWatch,Elasticache,ERD和SES之類的服務在AWS上部署應用程序。

工作原理:

1. 用戶使用Web客戶端生成請求。通過Zuul Proxy,請求被轉發到網關微服務。

2. 網關微服務執行安全操作。如果用戶未通過身份驗證,則會引發“未經授權”的異常。如果經過身份驗證,則Zuul Proxy會決定將請求發送到核心平臺或指定的微服務,如商業智能,Web內容或由第三方開發人員創建的。

在下面的列表中,我們可以看到路由的示例配置:

zuul:

host:

connect-timeout-millis: 10000

socket-timeout-millis: 60000

routes:

# Begin of custom module microservices - add mapping relevant to your microservice

# Begin of Business Intelligence microservice

businessIntelligenceApplication:

path: /service/abixen/business-intelligence/application/**

url: http://business-intelligence-service:9091/service/abixen/business-intelligence/application

sensitive-headers:

businessIntelligenceApplicationApi:

path: /api/service/abixen/business-intelligence/application/**

url: http://business-intelligence-service:9091/api/service/abixen/business-intelligence/application

sensitive-headers:

businessIntelligenceAdmin:

path: /service/abixen/business-intelligence/control-panel/**

url: http://business-intelligence-service:9091/service/abixen/business-intelligence/control-panel

sensitive-headers:

businessIntelligenceAdminApi:

path: /api/service/abixen/business-intelligence/control-panel/**

url: http://business-intelligence-service:9091/api/service/abixen/business-intelligence/control-panel

sensitive-headers:

# End of Business Intelligence microservice

# Begin of Web Content microservice

webContentApplication:

path: /service/abixen/web-content/application/**

url: http://web-content-service:9092/service/abixen/web-content/application

sensitive-headers:

webContentApplicationApi:

path: /api/service/abixen/web-content/application/**

url: http://web-content-service:9092/api/service/abixen/web-content/application

sensitive-headers:

webContentAdmin:

path: /service/abixen/web-content/control-panel/**

url: http://web-content-service:9092/service/abixen/web-content/control-panel

sensitive-headers:

webContentAdminApi:

path: /api/service/abixen/web-content/control-panel/**

url: http://web-content-service:9092/api/service/abixen/web-content/control-panel

sensitive-headers:

# End of Web Content microservice

# End of custom module microservices

resource:

path: /resource/**

url: http://core:9000

sensitive-headers:

api:

path: /api/**

url: http://core:9000/api

sensitive-headers:

如何創建自己的微服務?

想要創建自己函數式微服務的開發人員可以使用通用API,有抽象接口,還必須包含部署描述符。該部署描述符文件描述了包含哪些模塊,什么可用的靜態資源,以及控制面板中是否有某種配置面板(控制面板是可配置的)。下面的列表是一個微服務器的部署描述符示例:

abixen:

platform:

adminSidebarItems:

-

name: data-source-sidebar-item

title: Data Sources

angularJsState: application.multiVisualisation.modules.databaseDataSource.list

orderIndex: 9

iconClass: fa fa-database

modules:

-

name: multi-visualisation

angularJsNameApplication: platformChartModule

angularJsNameAdmin: platformChartModule

title: Multi Visualisation

description: This is a multi visualisation module

relativeInitUrl: /service/abixen/business-intelligence/application/multi-visualisation/html/index.html

adminSidebarItems:

-

name: data-source-sidebar-item

staticResources:

-

relativeUrl: /service/abixen/business-intelligence/application/business-intelligence.min.css

resourcePageLocation: HEADER

resourcePage: APPLICATION

resourceType: CSS

-

relativeUrl: /service/abixen/business-intelligence/application/business-intelligence.min.js

resourcePageLocation: BODY

resourcePage: APPLICATION

resourceType: JAVASCRIPT

-

relativeUrl: /service/abixen/business-intelligence/application/lib/d3.min.js

resourcePageLocation: BODY

resourcePage: APPLICATION

resourceType: JAVASCRIPT

-

relativeUrl: /service/abixen/business-intelligence/application/lib/nv.d3.min.js

resourcePageLocation: BODY

resourcePage: APPLICATION

resourceType: JAVASCRIPT

-

relativeUrl: /service/abixen/business-intelligence/application/lib/nv.d3.min.css

resourcePageLocation: HEADER

resourcePage: APPLICATION

resourceType: CSS

-

relativeUrl: /service/abixen/business-intelligence/application/lib/angular-nvd3.min.js

resourcePageLocation: BODY

resourcePage: APPLICATION

resourceType: JAVASCRIPT

-

relativeUrl: /service/abixen/business-intelligence/control-panel/business-intelligence.min.css

resourcePageLocation: HEADER

resourcePage: ADMIN

resourceType: CSS

-

relativeUrl: /service/abixen/business-intelligence/control-panel/business-intelligence.min.js

resourcePageLocation: BODY

resourcePage: ADMIN

resourceType: JAVASCRIPT

我們可以看到,Java開發人員不必從頭開始創建整個微服務架構。Abixen平臺為你準備了現成的微服務解決方案,并可以立即開始開發函數式微服務。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/534238.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/534238.shtml
英文地址,請注明出處:http://en.pswp.cn/news/534238.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

rocketmq java例子_SpringBoot和RocketMQ的簡單實例

1,引用jar包build.gradle文件添加jar包引用compile group: org.apache.rocketmq, name: rocketmq-spring-boot-starter, version: 2.1.12,配置文件application.properties 配置文件spring.application.nameapp-dempserver.port8081###rocketmq###rocketm…

mysql migrations_Code First Migrations更新數據庫結構(數據遷移)

背景 code first起初當修改model后,要持久化至數據庫中時,總要把原數據庫給刪除掉再創建(DropCreateDatabaseIfModelChanges),此時就會產生一個問題,當我們的舊數據庫中包含一些測試數據時,當持久化更新后,…

java 機器碼 虛擬機_Java虛擬機:源碼到機器碼

無論什么語言寫的代碼,其到最后都是通過機器碼運行的,無一例外。那么對于 Java 語言來說,其從源代碼到機器碼,這中間到底發生了什么呢?這就是今天我們要聊的。如下圖所示,編譯器可以分為:前端編…

docker 遠程連接 文件看不到_開發提升十倍生產力: IDEA 遠程一鍵部署 Spring Boot 到 Docker...

一、開發前準備二、新建項目《Java 2019 超神之路》《Dubbo 實現原理與源碼解析 —— 精品合集》《Spring 實現原理與源碼解析 —— 精品合集》《MyBatis 實現原理與源碼解析 —— 精品合集》《Spring MVC 實現原理與源碼解析 —— 精品合集》《Spring Boot 實現原理與源碼解析…

java多臺_Java 多態

Java中多態的特性,在學習中就是很難懂,比較抽象的概念。學的時候就犯糊涂,但日后會發現,基礎在日常工作的理解中占有重要的角色。下面,我將用一個代碼實例,回憶和鞏固多態的概念和存在的意義。理解多態&…

快準牌電腦發軟件_做自媒體必備技能,視頻剪輯軟件排名(精品篇)

作者:老馬引流定位:專業專注引流推廣0X00 前言毫不客氣的說,視頻正日益成為社交媒體和營銷的重要組成部分,有越來越多的人參與到視頻剪輯當中來,而其中最為關鍵的就是視頻剪輯軟件。而市面上的視頻剪輯軟件當然也是五花…

ad電阻原理圖_【雕爺學編程】Arduino動手做(2)---光敏電阻模塊

【Arduino】108種傳感器模塊系列實驗(02)實驗二:光敏電阻傳感器模塊我手里這塊是三針版的,挺秀氣吧光敏電阻是用硫化隔或硒化隔等半導體材料制成的特殊電阻器,其工作原理是基于內光電效應。光照愈強,阻值就…

java從url下載文件_Java從URL下載文件

在這篇文章中將學習如何從java下載URL中的文件。使用java.net.URL openStream()方法從java程序中的URL下載文件。也可以使用Java NIO Channels或Java IO InputStream從URL打開流中讀取數據,然后將它保存到文件中。下面是從指定URL下載的簡單Java程序。它演示了如何在…

怎么判斷一個字符串的最長回文子串是否在頭尾_LeetCode 第 131 號問題:分割回文串...

題目來源于 LeetCode 上第 131 號問題:分割回文串。題目難度為 Medium,目前通過率為 45.8% 。題目描述給定一個字符串 s,將 s 分割成一些子串,使每個子串都是回文串。返回 s 所有可能的分割方案。示例:輸入題目解析首先&#xff0…

java的地位_Java地位無可動搖的12個原因

如今,面對曾經在程序員中被各種新技術掩蓋直至堙滅的技術值得懷念。猶如COBOL這當年被老程序員們尊為神器的語言如今也基本沒有價值。而Java作為現代程序員的中堅力量在這點上會不會成為下一個COBOL?有關JAVA的技術賣出多少本書已經是一個很久遠的記憶了…

hystrix threadpool coresize_Hystrix斷路器 - 求知若渴的蝸牛

Hystrix介紹在微服務場景中,通常會有很多層的服務調用。如果一個底層服務出現問題,故障會被向上傳播給用戶。我們需要一種機制,當底層服務不可用時,可以阻斷故障的傳播。這就是斷路器的作用。他是系統服務穩定性的最后一重保障。在…

ionic保存到mysql_ionic sqlite 存取數據封裝(兼容真機與webkit瀏覽器)

不管是真機還是H5,都有提供sqlite數據庫進行存儲數據。那么我們只要封裝好函數就能隨意調用了。如果只是存儲簡單的鍵值對形式的話,ionic官網也提供了一個兼容網頁的storage,https://ionicframework.com/docs/storage,但只能key/v…

sql plus 表的總記錄數是多少_直播回顧 | 億級并發絲毫不虛,TDSQL-SQL引擎是如何煉成的...

騰訊云數據庫國產數據庫專題線上技術沙龍正在火熱進行中,3月19日唐顥的分享已經結束,沒來得及參與的小伙伴不用擔心,以下就是直播的視頻和文字回顧。關注“騰訊云數據庫”公眾號,回復“0319唐顥”,即可下載直播分享PPT…

java plug機制_插件機制 - OpooPress - 基于 Java 的靜態博客生成器

插件機制通過插件機制可以很容易的擴展 OpooPress 博客系統的功能。 Plugin 定義如下public interface Plugin{/**** param registry*/void initialize(Registry registry);}Registry 接口定義如下:public interface Registry {Site getSite();void registerConvert…

運放放大倍數計算公式_19.運算放大器的特性與應用,不得不掌握的知識點(一)...

運算放大器,簡稱“運放”,是電力電子中最重要的器件之一,主要作用為:信號放大、信號運算、信號處理、波形的產生和變換。一、運算放大器的內部結構集成運算放大器內部結構集成運算放大器內部一般由四個單元組成,各單元…

java選項設置_java環境配置

javac無法執行檢查:看看java 相關的java相關路徑有沒有多余的符號,比如多出分號,逗號(筆者上面是正確的路徑展示形式)Win10下 Java環境變量配置首先,你應該已經安裝了 Java 的 JDK 了(如果沒有安裝JDK,請跳轉到此網址&…

teleport 組件的作用_人臉識別綜述! 覆蓋人臉檢測,預處理和特征表示三大核心組件!...

The Elements of End-to-end Deep Face Recognition: A Survey of Recent Advances 人臉識別是計算機視覺社區中最基礎和歷史悠久的話題之一。隨著深度卷積網絡和大尺度數據集發展,深度人臉識別取得極大進步并且應用到許多領域。給定一個自然圖像或者視頻幀作為輸入…

itunes未能連接到iphone_iTunes下載_蘋果iTunes官方下載「32位|64位」

iTunes是蘋果官方推出的Apple官方數字媒體播放與管理應用程序。蘋果iTunes官方下載中文版能將您所有的媒體文件和應用收藏導入iPad和iPhone,您還可以通過它購買應用、數字音樂、視頻、電視及游戲等等。iTunes是目前最專業的iPad和iPhone管理應用工具。本站提供蘋果i…

java短視頻上傳阿里云流程_短視頻上傳

啟動上傳前需要設置上傳回調,需要實現VODSVideoUploadCallback回調:vodsVideoUploadClient.uploadWithVideoAndImg(vodSessionCreateInfo, new VODSVideoUploadCallback() {Overridepublic void onUploadSucceed(String videoId, String imageUrl) {//上…

feko軟件_計算電磁學各種方法和電磁仿真軟件簡述

計算電磁學中有眾多不同的算法,如時域有限差分法(FDTD)、時域有限積分法(FITD)、有限元法(FE)、矩量法(MoM)、邊界元法(BEM)、 譜域法(SM)、傳輸線法(TLM)、模式匹配法(MM)、橫向諧振法(TRM)、線方法(ML)和解析法等等。在頻域,數值算法有:有限…