- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果您在组织中寻求微服务架构,他们可以通过 zookeeper 共享配置或其等价物。但是,各种服务应该如何共享通用的数据库模式?共同常数?和常用实用程序?
一种方法是将所有微服务放在同一个代码存储库中,但这与微服务带来的解耦相矛盾......
另一种方法是让每个微服务完全独立,但这会导致每个微服务必须保存的单独数据库中出现代码重复和数据重复。
另一种方法是实现没有上下文\状态的功能微服务,但这通常是不现实的,并且会插入架构拥有一个中央集线器来维护上下文\状态以及来自\到它的大量流量。
在微服务之间共享代码和架构的可扩展、高效、实用且美观的方式是什么?
最佳答案
关于通用代码,最佳实践是使用打包系统。因此,如果您使用 Java,则使用 maven,如果您使用 Ruby,则使用 Gems,如果使用 python,则使用 pypi 等。理想情况下,打包系统几乎不会增加摩擦,因此您可能有一个(例如,git)公共(public)库存储库(或多个不同主题的公共(public)库),并通过工件存储库(例如私有(private) maven/gems/pypi)发布其工件。然后在微服务中添加对所需库的依赖关系。因此代码重用很容易。在某些情况下,打包系统确实会增加一些摩擦(maven 就是其中之一),因此人们可能更喜欢对所有内容使用单个 git 存储库以及多模块项目设置。这不像第一种方法那么干净,但效果也不错,而且还不错。其他选项是使用 git submodule(不太理想)或 git subtree(更好),以便将源代码包含在单个“父”存储库中。
关于架构 - 如果您想按书本操作,那么每个微服务都有自己的数据库。他们不接触彼此的数据。这是一种非常模块化的方法,乍一看似乎给您的流程增加了一些摩擦,但最终我认为您会感谢我。它将允许对微服务进行快速迭代,例如,您可能希望将一项特定服务的一种数据库实现替换为另一种数据库实现。想象一下当您的所有服务都使用相同的数据库时执行此操作!祝你好运...但是,如果每个服务都使用自己的数据库,则该服务会正确抽象数据库(例如,它不接受 SQL 查询作为 API 调用;-)),那么将 mysql 更改为 Cassandra 突然变得可行。拥有完全隔离的数据库还有其他好处,例如负载和扩展、找出瓶颈、管理等。
简而言之 - 通用代码(实用程序、常量等) - 使用打包系统或某些源代码链接,例如 git-tree
数据库 - 你不碰我的,我也不碰你的。这是解决这个问题的更好方法。
HTH,兰。
关于architecture - 在微服务之间共享代码和架构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25600580/
如果您设计分布式应用程序以实现轻松扩展,或者您只想使用 Amazon、Google 或 Microsoft 提供的任何新的“云计算”产品,那么您通常最终会使用一些典型的概念或组件: 分布式 blob
根据uncle Bob's Clean Architecture 、企业和应用程序业务规则(概念上由命令组成)位于外部接口(interface)层之下的层中。因此,无论何时调用接口(interface
我在网上找不到它的任何实现实际上为您提供了一种与框架无关且实用的实现方式。 我已经看到了几个解决它的低于标准的建议: 使存储库方法成为原子 使用例原子化 它们都不是理想的。 案例#1 :大多数用例依赖
我正在查看 Sparkle 项目的配置并注意到它们设置: 架构 = ppc i386 x86_64 有效架构 = i386 x86_64 来自苹果的有效架构描述: Space-separated li
只听本周的podcast并认为将您的一些经验组合在一起会很好,在这些经验中,您已经看到设计的“架构”方面比应有的支配更多东西。 Java 在这方面经常受到负面报道,而且随着 Java EE 的复杂性增
我正在阅读 Bob Martin (https://blog.8thlight.com/uncle-bob/2012/08/13/the-clean-architecture.html) 的清洁架构
OSGi是模块化架构,JavaBeans是组件架构。有什么区别? 最佳答案 OSGi 和 Java Beans 之间的主要区别在于类加载器的工作方式。在标准 .jar 文件或 EJB 中,rt.jar
我对 Clean Architecture 中的 Gateway to Entity 依赖有疑问。我认为以下同心圆图形经常被介绍为整洁的架构。 在上图中,Gateway并没有直视Entity。但是,还
我试图理解 TOGAF 9 的核心概念。 无论我多长时间阅读 TOGAF 手册中的解释,我都无法理解 Enterprise Continuum 和 Architecture Repository 之间
如果 Kappa 架构直接对流进行分析,而不是将数据拆分为两个流,那么在像 Kafka 这样的消息系统中,数据存储在哪里?或者它可以在数据库中进行重新计算? 单独的批处理层是否比使用流处理引擎重新计算
它们的含义是什么,我可以将它们设置为不同的值吗? 最佳答案 架构是您想要构建的架构,有效的架构是您可以设想使用您的代码库构建的架构。 所以也许您只想为 armv7 构建二进制文件,但相同的源代码可以为
我现在正在尝试在 Xcode 4.0 中构建的项目遇到问题,希望有人可以为我解释一下。 我正在尝试使用 ZBar SDK 并遵循此处概述的指南中概述的说明: http://zbar.sourcefor
在基于 Apple Silicon 的机器上使用 Interface builder 时,我当前的项目会引发 IBDesignable 错误。 我尝试排除用于调试的 arm64 架构,以及我在互联网上
Xcode 项目中出现警告: crypto was rejected as an implicit dependency for 'libcrypto.a' because its architect
我正在 Xcode 5 中开始新项目。我想使用 iOS SDK 7 开发应用程序,但部署目标为 iOS 5.0。当我在 Xcode 中创建新项目并尝试将部署目标更改为 5.0 时,我收到了这条消息:
编辑 :这个问题可能是旧的,它与 xcode 3 有关。 我正在开发一个需要 voip 支持的 iPhone 应用程序,所以我添加了 pjsip 的 ARM 版本图书馆。但如果我使用 iPhone 模
我们最近将最低 iOS 支持设置为 4.0,并开始使用 LLVM 编译器对当前可用的应用程序进行新更新。 将“架构”和“有效架构”设置为仅 armv7 是否会排除 iPhone 3G 等 armv6
我想在我的 64 位机器上启用额外的架构(32 位)。我做了 dpkg --print-architecture 来了解已知的架构,即 amd64 。之后我做了 dpkg --print--forei
操作系统:OS X Yosemite 版本 10.10.1 XCode:未安装 应用程序加载器3.0 (620) PhoneGap:3.7.0 PhoneGap 构建:在线 (build.phoneg
我们已经构建了一个具有多个 native 绑定(bind)的 Xamarin 应用程序(iOS、Android)。该应用程序在设备和模拟器上运行良好,我们能够毫无问题地构建存档(显然)。 问题是当我们
我是一名优秀的程序员,十分优秀!