关于soa:SOA-和微服务有何区别

玩过 Dubbo 的小伙伴应该都有据说过一个概念叫做 SOA,每当咱们说起微服务的时候,很多人就会去纠结这和 SOA 有啥关系呀?感觉换汤不换药呀。 明天松哥来略微和小伙伴们探讨下这个话题,咱们一起来看看 SOA 和微服务到底有何异同。 1. SOASOA,英文全称是 Service-Oriented Architecture (SOA) governance,单纯从字面来看,是面向服务的架构治理。然而小伙伴们在网上应该很难看到比拟权威的对于 SOA 通俗易懂的解释。我这里还是以 TienChin 我的项目为例,来和大家捋一捋 SOA。 假如 TienChin 中有一个用户注册的性能,当初前端的注册有三个端: 网页手机 App小程序 如果采纳传统的 JavaWeb 开发方式,那么我可能得写三遍注册性能,为三个 Client 各自提供一个接口,然而小伙伴们略微思考一下就会发现,注册逻辑其实都差不多,区别可能仅仅是接口返回的数据格式有差别而已。因而,咱们能够将注册性能抽取进去,写成一个独自的服务,而后通过近程服务调用如 HTTP 或者 Socket 等,去调用这个注册的功能模块。这就是一个简略的 SOA 架构设计。 然而看了这个很多小伙伴都懵了,这不就是微服务吗? 接下来咱们就来说说 SOA 和微服务到底哪里不一样。 2. SOA PK 微服务2.1 服务间通信首先第一点,就是服务之间的通信形式不同。 玩过 Dubbo 的小伙伴都晓得,Dubbo 中罕用的通信协议就是 Dubbo 协定,Dubbo 协定实质上其实就是 socket 通信。在 SOA 中,服务之间的通信往往都是采纳的重量级协定如 SOAP 等。 而咱们罕用的微服务框架 Spring Cloud,小伙伴们晓得,这里的通信基本上都是 REST 这种轻量级协定,有时候咱们甚至是基于音讯来驱动微服务,无论哪一种,微服务中服务之间的通信协议都更加轻量级。 2.2 数据库设计在 SOA 中,一般来说不太会进行分库设计,也就是说整个零碎还是应用的一个库,零碎可能会分为不同的服务,然而不同的服务操作的都是同一个库。 微服务则不同,昨天的文章中,松哥画的上面这张图,基本上是每一个服务都有一个本人的库,每个服务都是操作本人的库,合同治理中须要调用用户治理的数据,不能间接调用库,得通过用户治理提供的 REST 接口去调用。 ...

January 9, 2023 · 1 min · jiezi

关于soa:面向资源的架构ROA概述

【注】本文译自: Overview of Resource-Oriented Architectures (ROA) | Developer.com 理解面向资源的架构 (ROA)、其价值以及最佳实际。 面向服务的架构 (Service-Oriented Architecture,SOA) 和面向资源的架构 (Resource-Oriented Architecture,ROA) 是用于实现强壮、可扩大的分布式应用程序架构的架构设计模式。分布式架构由通过定义良好的接口在网络上应用的组件组成。在 ROA 中,这些组件被称为资源,而在 SOA 中,它们被称为服务。本文概述了面向资源的体系结构。 什么是面向资源的架构 (ROA)? 面向资源的架构 (ROA) 是一种架构格调,它扩大了 REST 架构格调,并提供了更宽泛、可扩大、灵便且与传输无关的架构。面向资源的架构 (ROA) 范式建设在资源的概念之上。资源是一个独立的、可辨认的实体,其状态能够被调配一个对立的资源定位符 (URI)。服务代表所申请操作的执行,而资源代表可通过统一的标准化接口进行治理的分布式组件。 面向资源架构的特色之一是与传输无关。因而,必须有特定的机制将面向资源的服务裸露给内部世界。当消费者申请对立资源定位器(Uniform Resource Locator,URL)并指定拜访办法(例如,GET、PUT、POST 和 DELETE)时,该 URL 将转换为绝对的外部 URI。拜访办法被转化为动作。 面向资源的架构仅围绕四个概念建模: 资源URI表述链接和连通性 以下是面向资源架构的四个属性: 可寻址性无状态性连通性对立的接口面向资源的架构:资源 资源是 ROA 的基石;资源是信息的逻辑示意。例如,学生是数据点的形象汇合,能够用多种形式示意,包含 XHTML、JSON 和 XML。 资源名称包含以下内容: 资源的类型资源标识符父元素的资源名API 服务的名称 资源是 REST 或 RESTful 架构中最重要的信息形象。术语“资源”是指任何可辨认的信息。这些信息能够是文档、计算机、汽车、长期服务(例如“俄亥俄州明天的天气”)、其余资源的汇合、集体、学生等。 每个不可变资源示意都能够通过绝对的对立资源批示符 (URI) 来标识,它可能包含到其余资源以及其余不可变资源的连贯。请留神,一个资源也能够有多个 URI。 每种资源应具备以下特色: 是惟一的必须至多有一个表述具备属性,模式能够被拜访并提供上下文对立资源标识符(URI) 对立资源标识符 (Uniform Resource Identifier,URI) 是蕴含资源名称和地址的字符序列,用于标识逻辑或物理资源。请留神,资源必须具备一个或多个 URI。 没有 URI,一条信息不被视为资源,因为它不能被援用或拜访。 您能够应用 URI 来标识任何事物,例如事实世界的对象、网页、书籍等。 上面是一个 URI 的例子:语法::示例:http://payroll/employee/1234 下表阐明了如何指定资源的绝对 URI: ...

July 21, 2021 · 1 min · jiezi