首页 文章 精选 留言 我的
优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/613815

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

如何让笨重的架构变灵巧?

随着业务的复杂性增大、系统吞吐量增长,所有功能统一部署难度加大,各个功能模块相互影响使系统变的笨重且脆弱,因此需要对业务进行拆分、对系统进行解耦、对系统内部架构升级,以此来提升系统容量及健壮性。 接下来主要分两部分介绍:系统拆分结构演变 一、系统拆分 系统拆分从资源角度分为应用拆分和数据库拆分,而从采用的先后顺序则可分为: 水平扩展;垂直拆分;业务拆分;水平拆分。 图1 系统分解原则 1水平扩展 水平扩展是最初始的解决的手段,也是系统遇到瓶颈的首选方案,主要从以下两个方面扩展: 应用加实例,搞集群,把系统吞吐量扩上去;数据库利用主从进行读写分离,数据库其实是系统最应该保护的资源。 2垂直拆分 垂直拆分才是真正开始拆分系统,主要是从业务功能角度拆分。如拆出用户系统、商品系统、交易系统等。 为了解决拆分后各个子系统之间相互依赖调用的问题,这时会引入服务调用治理。虽然系统复杂度有所加大,但系统基本解耦,稳定性相对提高,做好降级就能避免因其它系统功能异常导致系统崩溃问题。 业务对应的库也会按照对应的业务拆分出用户库、商品库、交易库等。 3业务拆分 业务拆分主要是针对应用层面按功能特点拆分,如交...

从零学习Spring MVC框架「环境搭建和MVC架构」

这是Spring MVC框架教程的第一篇,首先为大家讲解MVC架构思想,MVC模式并不是Javaweb项目中独有的,MVC是一种软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型「Model」、视图「View」和控制器「Controller」,即为MVC。 图源见文末我们直接拿例子来解释,最典型的MVC就是Jsp+servlet+Javabean模式。比如登陆的案例,在视图层即Jsp中有一个表单,用户填写用户名和密码,点击提交。这时候会跳转到控制层,控制层Servlet会接受到表单提交的用户名和密码。 注意:我们并不会在Servlet里面进行业务逻辑和数据库SQL编写,这样会显得杂乱不堪。MVC架构的思想是,控制层接到用户名和密码送给Service层,在Service层中进行业务逻辑的编写,比如判断当前有没有此用户、密码是否正确。 判断密码的正确性需要和数据库进行交互,此时就需要另一个Dao层,Dao是专门和数据库打交道,在Dao层中可以利用JDBCUtil进行SQL的编写,并把查询的结果返回给Service层。Service层有了Dao层的返回结果便可以进一步判断密码是否...

相关文章

发表评论

资源下载

更多资源
优质分享App

优质分享App

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。