热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

三分钟谈谈互联网技术架构

谈谈对互联网的发展的理解,从熟悉的传统架构项目,到分布式架构项目,再到微服务架构。

1.首先传统的项目是:三层架构

三分钟谈谈互联网技术架构

 2.传统架构的问题所在: 

   随着公司发展,业务的俱增,开发人员的增加,传统的开发项目往往会面临这样的问题。开发人员对了以后,人员管理需要花费更多的时间,模块开发沟通需要更多的时间,代码冲突变得越来越多,直接影响开发速度,需要有一套更加合理的架构方案。同时,在性能上,物理机是有抗压上限的,传统的项目是整个项目在一块,然后部署在机器上,将功能模块拆分开,部署在不同的机器上,显然能够突破物理的极限,以满足新的业务需求。

  3.分布式解决传统的问题:

  先说分布式干了什么:分布式是将服务拆分开,将一个系统拆分为若干个子系统,来维护开发,从传统的直接各层调用,变成使用 RPC 技术远程接口的调用,开发团队开始拆分,变成几个人维护一个接口。

  在这里说一下分布式并不是集群,这两个是区分开的概念,不是简单的分别部署在机器上这么简单。集群是来帮助我们解决高并发,高可用的工具。

三分钟谈谈互联网技术架构

  4.分布式的优点:代码服务,解耦,适合大的团队开发,解决了传统结构的问题。  

  5. 分布式开发的问题:网络延迟,维护复杂,开发需要解决分布式的问题,比方说分布式事务。因为分布式就是将服务拆开,通过网络调用的方式,去调用接口。 

  6.面向服务架构(我觉得可以理解为分布式)关键性技术:

   走出技术误区,很多人觉得springboot就是微服务,这是不对的,springboot其实做了这样的是,整合了框架,让环境的搭建变得更加方便,比方说使用ssm框架做开发,那么很多依赖需要手动的添加,但是使用了springboot以后,一条依赖就够了,因为springboot帮我们整合好了,集成好了,我们可以借助maven的依赖继承,就可以轻松的把几十条依赖,变成一条依赖,并且不会有依赖冲突问题。springboot 解决的是简化复杂的配置文件的问题。并不能说springboot就是微服务,只是大家都用springboot的轻巧性,来配合做微服务开发。

   关键性技术:前边提到了,将系统拆分开为子系统,这似乎并不需要什么技术,关键就在与拆分开以后的调用上,调用是远程调用的,这就涉及到远程调用技术。远程调用框架有: springCloud    httpClient    hession   dubbo。

   面向服务架构都是基于SOAP通信协议来进行传输的,SOAP协议就是 http协议 + xml 序列化与反序列化操作,这个是比较笨重的,不如json格式的传输跟快。

7.微服务架构

 微服务架构技术是在SOA上的一个升级,也是分布式架构的一种。那么微服务升级到哪里了呢?它的传输使用的是 http + rest风格 + json。那么微字又体现在哪里呢?体现在拆分的更加细,并且每个服务都是独立运行。

8.面向服务架构和微服务架构的区别:

  面向服务架构主要针对银行,企业 xml格式,企业级ESB服务,就是对安全性要求比较高,这是一种比较重量级的服务,微服务采用http +rest风格 +json 传输更快,是一种轻量级的。

 

 


推荐阅读
  • 本文介绍了基于Java的在线办公工作流系统的毕业设计方案,涵盖了MyBatis框架的应用、源代码分析、调试与部署流程、数据库设计以及相关论文撰写指导。 ... [详细]
  • 微服务架构详解及其入门指南
    本文详细介绍了微服务的基本概念、发展历程、与传统架构的区别及优势,并探讨了适合采用微服务架构的场景。此外,文章还深入分析了几个主流的微服务开发框架,特别是Spring Cloud的组成和特点。 ... [详细]
  • 大数据SQL优化:全面解析数据倾斜解决方案
    本文深入探讨了大数据SQL优化中的数据倾斜问题,提供了多种解决策略和实际案例,旨在帮助读者理解和应对这一常见挑战。 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • django项目中使用手机号登录
    本文使用聚合数据的短信接口,需要先获取到申请接口的appkey和模板id项目目录下创建ubtils文件夹,定义返回随机验证码和调取短信接口的函数function.py文件se ... [详细]
  • 深入理解SAP Fiori及其核心概念
    本文详细介绍了SAP Fiori的基本概念、发展历程、核心特性、应用类型、运行环境以及开发工具等,旨在帮助读者全面了解SAP Fiori的技术框架和应用场景。 ... [详细]
  • 酷家乐 Serverless FaaS 产品实践探索
    本文探讨了酷家乐在 Serverless FaaS 领域的实践与经验,重点介绍了 FaaS 平台的构建、业务收益及未来发展方向。 ... [详细]
  • IntelliJ IDEA配置微服务启动显示
    通过编辑IntelliJ IDEA的workspace.xml文件,可以实现微服务启动对象的显示。具体步骤包括定位并修改workspace.xml中的RunDashboard部分。 ... [详细]
  • Java高级工程师学习路径及面试准备指南
    本文基于一位朋友的PDF面试经验整理,涵盖了Java高级工程师所需掌握的核心知识点,包括数据结构与算法、计算机网络、数据库、操作系统等多个方面,并提供了详细的参考资料和学习建议。 ... [详细]
  • 本文探讨了如何利用 Application 对象在 PHP 应用程序中共享数据,特别是在多用户环境中保持数据的一致性和安全性。文章还介绍了 Application 对象的基本结构、方法和事件,并提供了实际应用示例。 ... [详细]
  • 本文探讨了一种方法,通过开发C#应用程序来拦截并处理从遗留系统发出的Http请求,该系统原本依赖于已停止服务的Web服务。解决方案涉及使用代理技术或HTTP监听器来捕获和重定向这些请求。 ... [详细]
  • 实践指南:利用Jenkins与JMeter实现自动化测试报告通知
    本文详细介绍了如何结合Jenkins和JMeter工具,通过自定义脚本向用户发送测试报告的通知。这不仅提高了开发团队的工作效率,也确保了信息的及时传递。 ... [详细]
  • 2023年PHP处理请求超时的全面指南
    本文详细介绍了在PHP中处理请求超时的各种方法,包括设置脚本执行时间、处理file_get_contents函数超时以及优化AJAX请求等,适合开发者参考学习。 ... [详细]
  • 微服务自动化.dockercompose
    目录一、docker-compose二、docker-compose安装与配置1、修改docker.service2、下载文件3、将刚才下载的docker-compose文 ... [详细]
author-avatar
Xl小飞2502901391
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有