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.mzph.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)和解析法等等。在频域,数值算法有:有限…