草庐IT

java - 微服务、服务注册中心、API 网关和数据共享

coder 2023-08-28 原文

其实我是在看一些关于微服务架构的文章的基调,但是,似乎他们正在以最简单的方式处理事情,而没有深入解释。

为了向您解释我的问题,我将向您展示我的实际小架构:

所以,这就是我想要使用的。在技​​术上做任何事情之前,我需要更多的理论信息。

我的域的描述

我有一些基于移动和浏览器的客户,他们能够在应用程序上连接自己,获取他们的用户信息,并能够查询他们所购买商品的账单信息。

在单体应用程序中,我会使用这种架构: - 移动/角-Ember 表示层 - 带有 REST API 的业务层,前面是 NGINX - 带有标准 MySQL 数据库的 DAL - 可扩展性仅适用于 X 轴

在这种情况下,我想使用微服务架构,因为它是“域可扩展的”并且非常灵活(当然还需要更多地了解它)。

在架构上,在每个服务中,相关 API 公开了唯一的 HTTP URL。

问题

a/ 在 (1) flux 中,“mobile”在 http://myDomain.or/auth 上发送了一个 http 请求.

在我看来,APIGateway 能够要求标准服务注册中心(Eureka、ZooKeeper 或其他)能够找到 AuthSrv 是否可访问并检索其网络地址。然后ApiGateway可以请求AuthSrv并响应服务器

这是让它发挥作用的好方法吗?处理X机器访问数据时是否存在延迟问题?

b/ flux (2) 查阅服务注册表。服务注册中心如何理解/auth 上的每个请求,甚至是/auth/other 之类的子 url(如果它被公开)都与此地址 ip:port 上的此服务相关?

c/ flux (3) 表明服务注册表有一个可用的 AuthSrv。 (3 之二) 显示另一个:没有可用的 AuthSrv。在一个小的应用程序中,我们可以承认我们有时会失去责任感,但在一个连接着数百个服务的大系统中,我们如何处理服务缺陷?

d/ 在另一篇文章中,我问如何存储账单信息,因为它与用户相关,来自另一个服务和另一个数据库。

在标准架构中我会:

{
   billingInformations:{...},
   billingUser:ObjectId("userId")
}

在微服务架构中,有人推荐使用:

{
    billingInformations:{...},
    billingUser:"/user/12365" // URL corresponding the the user Resource in the other service
}

这是处理“服务数据共享”而不耦合服务的最佳方式吗?

e/ 在这种特定情况下,我什么时候应该更喜欢使用 AMQP 协议(protocol)而不是 HTTP 协议(protocol)?

感谢提前

最佳答案

a/

不,像 Zookeeper 这样的服务注册中心在内存中保证高吞吐量和低延迟。

b/

在像 Zookeeper 这样的服务注册表中,您可以像注册服务一样创建文件系统路径。例如/App1/Service1 和/App1/Service2

c/

不太清楚是什么问题。

d/

有人推荐的模式是 HATEOAS推荐用于 API 响应的模式。

e/

只有在服务之间需要通信时才需要 AMQP。切勿直接从一项服务直接调用另一项服务的 API。

编辑

c/

在这种情况下,您需要实现回退逻辑。例如,如果服务不可用、超时或任何其他故障,则需要采取一些措施。 Netflix 的 Hystrix 等工具有助于实现这一目标。

e/

通信模式必须是对称的,而不是非对称的。就像下面一样,

这种模式将实现微服务之间的松散耦合,从而实现灵 active 。

关于java - 微服务、服务注册中心、API 网关和数据共享,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29669180/

有关java - 微服务、服务注册中心、API 网关和数据共享的更多相关文章

  1. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  4. ruby - 通过 ruby​​ 进程共享变量 - 2

    我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是

  5. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  6. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  7. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  8. ruby-on-rails - ActionController::RoutingError: 未初始化常量 Api::V1::ApiController - 2

    我有用于控制用户任务的Rails5API项目,我有以下错误,但并非总是针对相同的Controller和路由。ActionController::RoutingError:uninitializedconstantApi::V1::ApiController我向您描述了一些我的项目,以更详细地解释错误。应用结构路线scopemodule:'api'donamespace:v1do#=>Loginroutesscopemodule:'login'domatch'login',to:'sessions#login',as:'login',via::postend#=>Teamroutessc

  9. ruby - Ruby 有 `Pair` 数据类型吗? - 2

    有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳

  10. ruby - 用 Ruby 编写一个简单的网络服务器 - 2

    我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b

随机推荐