返回顶部
首页 > 资讯 > 精选 >Java架构怎么应用于不同的产品
  • 679
分享到

Java架构怎么应用于不同的产品

2023-06-17 05:06:35 679人浏览 八月长安
摘要

本篇内容介绍了“Java架构怎么应用于不同的产品”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!当我们架设一个系统的时候通常需要考虑到如何与其

本篇内容介绍了“Java架构怎么应用于不同的产品”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

当我们架设一个系统的时候通常需要考虑到如何与其他系统交互,所以我们首先需要知道各种系统之间是如何交互的,使用何种技术实现。

1. 不同系统不同语言之间的交互

现在我们常见的不同系统不同语言之间的交互使用WEBService,Http请求。WebService,即“Web 服务”,简写为  WS。从字面上理解,它其实就是“基于 Web  的服务”。而服务却是双方的,有服务需求方,就有服务提供方。服务提供方对外发布服务,服务需求方调用服务提供方所发布的服务。如果说得再专业一点,WS  其实就是建立在 HTTP 协议上实现异构系统通讯的工具。没错!WS 说白了还是基于 HTTP 协议的,也就是说,数据是通过 HTTP  进行传输的。最早我们是用CXF开发SOAP服务实现WS,后面我们是用REST服务实现WS(这个目前使用比较多,也最我用得最多的这一种)。基于 CXF也可以开发REST服务,不过我们一般直接使用springMVC或者其他mvc框架实现REST服务。

但是在很多人的印象中Web service的话一般指十来年前IBM主导的基于XML的各种交互技术,现在除了一些公司在用之外用得人也很少了。广义的话Webservice就是Web 服务了,一切皆服务。

2. 不同系统相同语言之间的交互

常见的不同系统相同语言之间的交互用rpc(远程过程调用),或者RMI(远程方法调用)实现,不用对外部提供服务,当然上面说的也可以使用在相同语言之间的交互,只是我常用的是RPC。

不同产品的架构

单个产品的架构演进

一般我们只是一个产品的情况下的架构演进历程,如果需要对外提供webService,通常使用REST服务实现。

以下一段内容来源于知乎

1)分布式架构的演进系统架构演化历程-初始阶段架构

Java架构怎么应用于不同的产品

初始阶段 的小型系统 应用程序、数据库、文件等所有的资源都在一台服务器上通俗称为LAMP

特征:应用程序、数据库、文件等所有的资源都在一台服务器上。

描述:通常服务器操作系统使用linux,应用程序使用PHP开发,然后部署在Apache上,数据库使用Mysql,汇集各种免费开源软件以及一台廉价服务器就可以开始系统的发展之路了。

2)系统架构演化历程-应用服务和数据服务分离

Java架构怎么应用于不同的产品

好景不长,发现随着系统访问量的再度增加,webserver机器的压力在高峰期会上升到比较高,这个时候开始考虑增加一台webserver

特征:应用程序、数据库、文件分别部署在独立的资源上。

描述:数据量增加,单台服务器性能及存储空间不足,需要将应用和数据分离,并发处理能力和数据存储空间得到了很大改善。

3)系统架构演化历程-使用缓存改善性能

Java架构怎么应用于不同的产品

特征:数据库中访问较集中的一小部分数据存储在缓存服务器中,减少数据库的访问次数,降低数据库的访问压力。

描述:系统访问特点遵循二八定律,即80%的业务访问集中在20%的数据上。缓存分为本地缓存和远程分布式缓存,本地缓存访问速度更快但缓存数据量有限,同时存在与应用程序争用内存的情况。

4)系统架构演化历程-使用应用服务器集群

Java架构怎么应用于不同的产品

在做完分库分表这些工作后,数据库上的压力已经降到比较低了,又开始过着每天看着访问量暴增的幸福生活了,突然有一天,发现系统的访问又开始有变 慢的趋势了,这个时候首先查看数据库,压力一切正常,之后查看webserver,发现apache阻塞了很多的请求,而应用服务器对每个请求也是比较快 的,看来 是请求数太高导致需要排队等待,响应速度变慢

特征:多台服务器通过负载均衡同时向外部提供服务,解决单台服务器处理能力和存储空间上限的问题。

描述:使用集群是系统解决高并发、海量数据问题的常用手段。通过向集群中追加资源,提升系统的并发处理能力,使得服务器的负载压力不再成为整个系统的瓶颈。

5)系统架构演化历程-数据库读写分离

Java架构怎么应用于不同的产品

享受了一段时间的系统访问量高速增长的幸福后,发现系统又开始变慢了,这次又是什么状况呢,经过查找,发现数据库写入、更新的这些操作的部分数据库连接的资源竞争非常激烈,导致了系统变慢

特征:多台服务器通过负载均衡同时向外部提供服务,解决单台服务器处理能力和存储空间上限的问题。

描述:使用集群是系统解决高并发、海量数据问题的常用手段。通过向集群中追加资源,使得服务器的负载压力不在成为整个系统的瓶颈。

6)系统架构演化历程-反向代理和CDN加速

Java架构怎么应用于不同的产品

特征:采用CDN和反向代理加快系统的 访问速度。

描述:为了应付复杂的网络环境和不同地区用户的访问,通过CDN和反向代理加快用户访问的速度,同时减轻后端服务器的负载压力。CDN与反向代理的基本原理都是缓存。

7)系统架构演化历程-分布式文件系统和分布式数据库

Java架构怎么应用于不同的产品

随着系统的不断运行,数据量开始大幅度增长,这个时候发现分库后查询仍然会有些慢,于是按照分库的思想开始做分表的工作

特征:数据库采用分布式数据库,文件系统采用分布式文件系统。

描述:任何强大的单一服务器都满足不了大型系统持续增长的业务需求,数据库读写分离随着业务的发展最终也将无法满足需求,需要使用分布式数据库及 分布式文件系统来支撑。分布式数据库是系统数据库拆分的***方法,只有在单表数据规模非常庞大的时候才使用,更常用的数据库拆分手段是业务分库,将不同的 业务数据库部署在不同的物理服务器上。

8)系统架构演化历程-使用NoSQL和搜索引擎

Java架构怎么应用于不同的产品

特征:系统引入NoSQL数据库及搜索引擎。

描述:随着业务越来越复杂,对数据存储和检索的需求也越来越复杂,系统需要采用一些非关系型数据库NoSQL和分数据库查询技术如搜索引擎。应用服务器通过统一数据访问模块访问各种数据,减轻应用程序管理诸多数据源的麻烦。

9)系统架构演化历程-业务拆分

Java架构怎么应用于不同的产品

特征:系统上按照业务进行拆分改造,应用服务器按照业务区分进行分别部署。

描述:为了应对日益复杂的业务场景,通常使用分而治之的手段将整个系统业务分成不同的产品线,应用之间通过超链接建立关系,也可以通过消息队列进 行数据分发,当然更多的还是通过访问同一个数据存储系统来构成一个关联的完整系统。纵向拆分:将一个大应用拆分为多个小应用,如果新业务较为独立,那么就 直接将其设计部署为一个独立的Web应用系统纵向拆分相对较为简单,通过梳理业务,将较少相关的业务剥离即可。横向拆分:将复用的业务拆分出来,独立部署 为分布式服务,新增业务只需要调用这些分布式服务横向拆分需要识别可复用的业务,设计服务接口,规范服务依赖关系。

10)系统架构演化历程-分布式服务

Java架构怎么应用于不同的产品

Q:分布式服务应用会面临哪些问题?

(1) 当服务越来越多时,服务URL配置管理变得非常困难,F5硬件负载均衡器的单点压力也越来越大。

(2) 当进一步发展,服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动,架构师都不能完整的描述应用的架构关系。

(3) 接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务需要多少机器支撑?什么时候该加机器?

(4) 服务多了,沟通成本也开始上升,调某个服务失败该找谁?服务的参数都有什么约定?

(5) 一个服务有多个业务消费者,如何确保服务质量?

(6) 随着服务的不停升级,总有些意想不到的事发生,比如cache写错了导致内存溢出,故障不可避免,每次核心服务一挂,影响一大片,人心慌慌,如何控制故障的影响面?服务是否可以功能降级?或者资源劣化?

这个好像是大型网站技术架构核心原理与案例分析开篇的内容,不过作者总结得不错,我就转载一下吧。

4. 产品线的架构

还有一种就是上面也有提到的业务拆分。现在我们需要做一个产品线,我们只需要一个数据层,一个通用业务逻辑层,前面还有各种应用和界面层,不需要 对外部系统(外部公司的系统)提供服务的情况以前我们一般会选择用EJB等来构建分布式应用,但是现在我们可以使用dobbo、thrift、avro、 hessian这类RPC框架来构建分布式应用实现不同应用和数据来源的交互。这种结构模式下我们需要对其他公司提供服务,可以专门写一个应用对外部系统 提供rest服务。一般大多数互联网服务背后都要访问十几个甚至几百个内部服务,它们之间的通信方式一般都是RPC:就像访问一个远程方法那样,输入参数 后等待返回结果。这对于构建复杂系统是最容易理解的方式。

如下图的模型,文件系统,缓存那些没有画出来,大家理解就行。

Java架构怎么应用于不同的产品

“Java架构怎么应用于不同的产品”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Java架构怎么应用于不同的产品

本文链接: https://lsjlt.com/news/287285.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java架构怎么应用于不同的产品
    本篇内容介绍了“Java架构怎么应用于不同的产品”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!当我们架设一个系统的时候通常需要考虑到如何与其...
    99+
    2023-06-17
  • Brainstorm框架如何应用于新产品设计
    定义目标用户群体:通过Brainstorm框架可以帮助团队明确新产品的目标用户群体,包括他们的需求、偏好和行为特点。 确定产...
    99+
    2024-03-08
    Brainstorm
  • 亚马逊arm架构服务器是什么类型的产品
    AWS arm架构服务器通常包括以下组件: Amazon CPU:AWS CPU 提供高性能计算、GPU加速和对象存储等功能,使 Amazon AI 平台更加强大。 Amazon GPU:AWS GPU 为 Amazon AI 平台提供...
    99+
    2023-10-27
    亚马逊 架构 类型
  • C++ 内存管理如何适应不同的硬件架构?
    c++++ 内存管理通过采用不同的寻址方案(直接、间接、段寻址)、利用内存管理单元(mmu)以及提供指针、引用、智能指针和自动内存管理等技术来适应不同的硬件架构。这些技术使 c++ 能够...
    99+
    2024-05-24
    内存管理 硬件架构 c++
  • SAP不同的产品是怎样支持用户创建自定义字段的
    这篇文章将为大家详细讲解有关SAP不同的产品是怎样支持用户创建自定义字段的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。我们从SAP CRM,Cloud for Customer(简称C4C...
    99+
    2023-06-04
  • Java分布式架构如何应用于Laravel路径管理?
    Java分布式架构和Laravel路径管理是两个不同的领域,但是它们可以结合起来实现更加高效的开发和管理。在本文中,我们将介绍如何将Java分布式架构应用于Laravel路径管理。 首先,让我们来看一下Java分布式架构是什么。Java分布...
    99+
    2023-08-25
    分布式 laravel path
  • Java RESTful API 设计模式:探索不同的架构风格
    RESTful API 的设计模式提供了一种结构化的方法,使开发人员能够创建符合 REST 原则的高质量 API。这些模式对于提高 API 的可预测性、可扩展性和可维护性至关重要。 1. RESTful 资源 RESTful 资源是 A...
    99+
    2024-03-07
    RESTful API、RESTful 架构、设计模式、资源导向、超媒体、HATEOAS、微服务
  • 响应式框架开发:Java和Django的不同之处
    响应式网页设计是一种能够在不同设备上自适应的设计方式。它可以让网页在不同大小的屏幕和不同的设备上呈现出最佳效果。为了实现响应式设计,我们通常会使用响应式框架。Java和Django是两种流行的Web开发框架,它们都有自己的响应式框架。在本...
    99+
    2023-09-07
    django 响应 框架
  • java的Structs框架怎么应用
    要使用Struts框架,首先需要进行以下步骤:1. 下载Struts框架:你可以从官方网站下载最新的Struts框架。解压下载的文件...
    99+
    2023-09-14
    java Structs
  • SAP的产品主数据怎么通过PI同步到CRM
    本篇内容介绍了“SAP的产品主数据怎么通过PI同步到CRM”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!SAP Cloud for Cust...
    99+
    2023-06-04
  • 构建现代应用:Java中的热门架构概览
    文章目录 1. 三层架构2. Spring框架3. 微服务架构4. Java EE(Enterprise Edition)5. 响应式架构6. 大数据架构7. 领域驱动设计(Domain-Dr...
    99+
    2023-09-04
    java 架构 开发语言
  • Java SSM框架怎么应用
    这篇文章主要介绍了Java SSM框架怎么应用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java SSM框架怎么应用文章都会有所收获,下面我们一起来看看吧。一、什么是SSM框架?SSM框...
    99+
    2023-07-05
  • 不是云服务器ecs的产品组件怎么办
    如果您是云服务器ECS的产品组件,并且您认为它们可能存在问题,您可以尝试以下几点来解决问题:检查您的ECS配置文件以获取更多信息。在检查ECS配置文件时,请仔细检查每一个步骤,以确保它们是正确的。如果您已经尝试了许多步骤仍然无法解决问题,请...
    99+
    2023-10-25
    组件 服务器 产品
  • 怎么用云服务器做亚马逊商品架构
    选择云服务器提供商:首先,你需要选择一个可靠的云服务器提供商,可以选择AWS、阿里云等。选择云服务器提供商时需要考虑一些因素,比如价格、稳定性、安全性等。可以参考官方文档或者咨询一些技术人员。 搭建基础环境:在选择云服务器提供商后,你需要...
    99+
    2023-10-27
    亚马逊 架构 服务器
  • java数据结构关于栈的实例应用
    此文章介绍关于顺序栈,链式栈的实例操作,括号匹配,表达式求值(后缀表达式) 1.声明一个栈接口SStack package ch05; public interface SS...
    99+
    2024-04-02
  • Java企业级应用架构设计中的分布式结构是怎样的
    本篇文章为大家展示了Java企业级应用架构设计中的分布式结构是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java企业级应用架构设计中的分布式结构大致可以分为单级结构、2级结构、3级结构和N...
    99+
    2023-06-17
  • java构造方法怎么应用
    构造方法在Java中是用于创建对象并初始化对象的特殊方法。构造方法的特点是:1. 构造方法的名称必须与类名一致。2. 构造方法没有返...
    99+
    2023-10-08
    java
  • 怎么理解.NET三层架构应用中的十层框架
    这篇文章给大家介绍怎么理解.NET三层架构应用中的十层框架,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。凡是接触.net开发的,***要理解的就是三层架构的重要思想。关于三层架构的概述 我就不多说了,相信大家都早已明白...
    99+
    2023-06-17
  • react同构应用的概念是什么
    今天小编给大家分享一下react同构应用的概念是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2024-04-02
  • PHP在微服务架构中怎么应用
    今天小编给大家分享一下PHP在微服务架构中怎么应用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、基于PHP的微服务架构构...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作