架构图如下图所示。这张图基本涵盖了互联网技术公司的大部分技术点,不同公司只是在具体的技术实现上稍有差异,但不会跳出这个框架的范畴。
成都创新互联公司专注于玄武企业网站建设,响应式网站,商城网站制作。玄武网站建设公司,为玄武等地区提供建站服务。全流程按需定制制作,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务
SQL: 常用的有mysql,用于存储业务数据。互联网发展初期,各个业务一般都会独立运营mysql集群,但随着业务越来越多,mysql集群规模越来越大,那就有必要做成SQL平台。
NoSQL: 翻译为Not Only SQL,作为mysql的一种补充。Nosql一般本身就提供集群,且使用起来很方便,公司业务发展初期没有必要。一般Nosql集群的数量越来越多,那就有必要做成Nosql平台。
小文件: 互联网中有很多小文件,比如商品图片,Facebook的图片。这类小文件具有数据小、数量巨大、访问大的特点。如果每个业务都去考虑小文件存储的话,就会出现重复造轮子现象,那就有必要做成小文件平台了。
大文件: 互联网的大文件主要分为两类:一类是业务上的大数据,例如Youtube的视频、电影网站的电影;另一类是海量的日志数据,例如各种访问日志。实力雄厚的一些大公司会基于开源方案做成大数据平台。
开发框架: 比如常见的Spring框架。
Web服务器: 常见的有tomcat、jetty等。
容器: Docker可以极大降低运维成本,以及在实现动态扩容上非常方便。
配置中心: 故名思义,配置中心就是集中管理各个系统的配置。
服务中心: 解决跨系统依赖的配置和调度问题。比如有10个系统依赖A系统的x接口,此时A系统实现了一个y接口可以更好地支持x接口,那么如果直接更新10个系统依赖的配置将会很麻烦。
消息队列: 支持系统解耦。
负载均衡: 充当任务分配器的职责。
CDN: 可以对一些常用文件进行就近缓存,来提高访问速度。
多机房: 多机房的主要目的是备灾,当机房故障时可以快速地将业务切换到另外一个机房,这种切换操作允许一定时间的中断,比如10分钟,1个小时。
多中心: 多中心的要求就更高了,要求同时对外提供服务,且业务能够自动在多中心之间切换,故障后不需人工干预或者很少的人工干预就能自动恢复。
用户管理: 对各个系统的用户进行统一管理。
消息推送: 根据不同途径分为短信、邮件、站内信、App推送。
存储云: 实现是CDN+小文件存储。
图片云: 实现也是CDN+小文件存储。为何不与存储云统一一套系统呢?这是因为图片业务的复杂性导致的。图片涉及的业务会更多,包括裁剪、压缩、美化、审核、水印等。
业务千差万别,各个互联网业务面对的主要问题是复杂度越来越高。此时就要用到拆和合的技术。拆即将一个大系统拆分为多个子系统,降低复杂度。当子系统越来越多,有可能就需要采用合的技术。
测试平台的核心目的是提升测试效率。
运维平台的核心职责分为四大块:配置、部署、监控、应急。
数据平台的核心职责主要包含三部分:数据管理、数据分析和数据应用。
管理平台的核心职责就是权限管理。
框架 #1:Spring
该框架排名第一,因为它具有开发复杂 Web 应用程序的出色能力,而且,这些应用程序因性能突出而广受赞誉。它使 Java 开发人员能够轻松地创建企业级应用程序。
Web 应用程序开发人员可以证明 Spring 框架的能力。这就是 Spring 成为 Java 开发人员最爱的原因。下面的数据可以证明这一点。以下是开发者(选择 Java 作为首选的三种编程语言之一)对 Java 框架的看法:
在开发人员的选择中,Spring MVC 和 Spring Boot 远远领先于其他 Java 技术。对于开发人员来说,这里的一大优势是他们可以不受其他模块约束而专注于一个模块,因为 Spring 利用了控制反转(IoC)。
这个框架的其他一些优点是一个全面的配置模型,支持传统数据库和现代数据库(如 NoSQL),并通过支持面向方面编程来支持内聚开发。它提供了一些模块,如 Spring MVC、Spring Core、Spring Boot、SpringTransaction 等。
框架 #2:Hibernate
作为一个对象关系映射(ORM)数据库,它改变了我们以前查看数据库的方式。尽管它不是一个全栈框架,但它可以极其轻松地为多个数据库转换数据。
它支持多个数据库的能力使它很容易扩展,无论应用程序的大小或用户的数量如何。它速度快、功能强大、易于扩展、修改和配置。
框架 #3:Struts
该框架帮助自定义软件开发人员创建易于维护的企业级应用程序。这个框架的 USP 是它的插件。它们是 JAR 包,这意味着它们是可移植的。
Hibernate 插件和 Spring 插件分别可以用于对象关系映射和依赖注入。使用此 Java 框架开发应用程序可以减少处理时间,因为它提供了组织良好的 Java、JSP 和 Action 类。
框架 #4:Play
使用该框架的顶尖公司包括 LinkedIn、三星、卫报、Verizon 等。这只能说明它的可信度。该框架提供了速度、可伸缩性和性能。
它的用户界面非常简单,使移动应用程序开发人员可以快速理解它。它主要用于开发需要统一内容创建的应用程序。
框架 #5:Google Web Toolkit
这个框架用于客户端开发,类似 JavaScript。它是一个开源的 Java 框架,这意味着它是免费的。谷歌广泛使用了这个框架,谷歌产品如 AdSense、谷歌钱包、AdWords 都是使用它编写的。
借助 GWT 代码,可以轻松地开发和调试 Ajax 应用程序。Java 开发人员更喜欢使用这个框架来编写复杂的应用程序。书签、跨浏览器可移植性、历史记录和管理是它的一些特性。
框架 #6:Grails
这个开源框架在企业级 Java Bean 中非常流行。它可用于为内容管理系统、Restful Web 服务和电子商务网站创建健壮的、可伸缩的应用程序。
它可以与 Java Spring、Hibernate、quartz、EE 容器和 SiteMesh 等其他 Java 技术搭配使用。它的部分优点包括简单的 GORM、灵活的配置文件、带有多个插件的高级插件系统、简单的对象映射库以及一个支持和响应社区。
框架 #7:Blade
任何自定义应用程序开发人员都可以在一天内快速理解这个框架。Java Blade 于 2015 年推出,以简单和轻量级著称。这个框架最大的亮点是它快速创建 Web 应用程序的能力。
它是一个全栈 Web 开发框架,提供一个简单而简洁的编码结构。Blade 基于 Java 8,它提供了 RESTful 风格的路由接口。它支持 webjar 资源和插件扩展。
框架 #8:JavaServer Faces
这个 Java 框架是由 Oracle 开发的。它可用于创建企业应用程序、本机应用程序和 Web 应用程序开发。它的一大优势是可以将表示层与应用程序代码轻松地连接。
它提供了一个用于表示和管理 UI 组件的 API 集。它具有清晰的体系结构,可以区分应用程序逻辑和表示。JSF 使用 XML 进行视图处理,而不是 Java。
框架 #9:Vaadin
用于精简 Java 开发的优秀平台。您可以使用它来获得自定义的 Web 开发服务。该框架的一大优点是服务器和浏览器之间的通信顺畅。
Vaadin 提供了从 Java 虚拟机直接访问 DOM 的功能。在最新发布的版本中,它被分成了两部分。Vaadin Flow 是一个轻量级框架,可以实现服务器端通信和路由。
程序开发中的框架(例如1000万+行的Qt)往往是对常见功能的封装(类似于成语对常用含义的代指,不同点在于应用框架最终对CPU表达含义时候会把成语替换为原本含义-通过函数调用),抛开框架,程序会变得因缺少一些'固定成语'(函数)的'释义'(函数实现)而变得无法执行。
所以,程序框架理解为基础或者机械标准件(例如螺丝螺母这些有明确标准的机械部件)更为贴切。
这样理解,假如你要造一辆马车,在没有框架的情况下,你需要自己去伐木,去把木头做成木板,木棍,然后组成轮子,门,等部件,然后组装起来,但如果你用了框架,就相当于你有现成的轮子,门等部件,你只需要组装一下就可以了。
可以说,一个框架是一个可复用的设计构件,它规定了应用的体系结构,阐明了整个设计、协作构件之间的依赖关系、责任分配和控制流程,表现为一组抽象类以及其实例之间协作的方法,它为构件复用提供了上下文(Context)关系。因此构件库的大规模重用也需要框架。
拓展资料:
框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。