软件的系统架构和开发平台有哪些?具体都有哪几种呢?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软件的系统架构和开发平台有哪些?具体都有哪几种呢?相关的知识,希望对你有一定的参考价值。

一、软件的系统架构

(一)、分层架构

分层架构(layered architecture)是最常见的软件架构,也是事实上的标准架构。如果你不知道要用什么架构,那就用它。

这种架构将软件分成若干个水平层,每一层都有清晰的角色和分工,不需要知道其他层的细节。层与层之间通过接口通信。

虽然没有明确约定,软件一定要分成多少层,但是四层的结构最常见。

    表现层(presentation):用户界面,负责视觉和用户互动

    业务层(business):实现业务逻辑

    持久层(persistence):提供数据,SQL 语句就放在这一层

    数据库(database) :保存数据

    有的软件在逻辑层和持久层之间,加了一个服务层(service),提供不同业务逻辑需要的一些通用接口。

    用户的请求将依次通过这四层的处理,不能跳过其中任何一层。

(二)事件驱动架构

事件(event)是状态发生变化时,软件发出的通知。

事件驱动架构(event-driven architecture)就是通过事件进行通信的软件架构。它分成四个部分。

    事件队列(event queue):接收事件的入口

    分发器(event mediator):将不同的事件分发到不同的业务逻辑单元

    事件通道(event channel):分发器与处理器之间的联系渠道

    事件处理器(event processor):实现业务逻辑,处理完成后会发出事件,触发下一步操作

    对于简单的项目,事件队列、分发器和事件通道,可以合为一体,整个软件就分成事件代理和事件处理器两部分。

(三)微核架构

微核架构(microkernel architecture)又称为"插件架构"(plug-in architecture),指的是软件的内核相对较小,主要功能和业务逻辑都通过插件实现。

内核(core)通常只包含系统运行的最小功能。插件则是互相独立的,插件之间的通信,应该减少到最低,避免出现互相依赖的问题。

(四)、微服务架构

微服务架构(microservices architecture)是服务导向架构(service-oriented architecture,缩写 SOA)的升级。

每一个服务就是一个独立的部署单元(separately deployed unit)。这些单元都是分布式的,互相解耦,通过远程通信协议(比如REST、SOAP)联系。

(五)、云架构

云结构(cloud architecture)主要解决扩展性和并发的问题,是最容易扩展的架构。

它的高扩展性,主要原因是没使用中央数据库,而是把数据都复制到内存中,变成可复制的内存数据单元。然后,业务处理能力封装成一个个处理单元(prcessing unit)。访问量增加,就新建处理单元;访问量减少,就关闭处理单元。由于没有中央数据库,所以扩展性的最大瓶颈消失了。由于每个处理单元的数据都在内存里,最好要进行数据持久化。

这个模式主要分成两部分:处理单元(processing unit)和虚拟中间件(virtualized middleware)。

    处理单元:实现业务逻辑

    虚拟中间件:负责通信、保持sessions、数据复制、分布式处理、处理单元的部署。

二、开发平台

ERP平台、金融电商平台、小程序平台、网站平台、bpm平台、低代码开发平台等等;
厂家有天翎、顶点、天纵、清流、K2等

开发语言有区分:dephp、java。net等;

三、如何选择合适的开发平台?
平台的选型,无非是从客户业务需求的角度,以及对应的品牌形象和案例沉淀几个角度去选择;
建议可以开箱即用,多试用几次,就找到适合的产品,通俗的说,就是货比三家。
管理顾问,每天成长一点点,努力成就自己的优秀。

参考技术A 软件系统架构分了有非常多的种类,有soa,有ssh,ssm,微服务架构等,但目前业界最流行的是微服务架构。平台目前主要分两类,一种是生成代码型,主要代表为炎黄盈动,普元,另一种是引擎式,像teemlink。我们公司现在用的是teemlink 的平台,它所有的表单流程都是可视化配置,通过鼠标拖拉的方式就可以实现百分之80的开发工作,基本实现了低代码开发模式。 参考技术B 软件开发是一项包括计划、分析、设计、编码和测试、维护系统工程,软件开发平台有两种实现方式,分别是正生成和逆生成之分。以宏天天翎的MyApps快速开发平台为例,采用的是逆生成,具体操作是:把E-R图画好,配置生成代码的参数,执行 Ant脚本,生成DAO层、业务层、控制层到展示层的配置文件和相应的页面。页面包括CRUD,分页,组合,查询等功能,MyApps开发平台采用了最流行的SOA/MVC架构设计模式,具体的你可以自己去了解。 参考技术C 软件开发平台建议还是多比较一下比较好。SDP软件开发平台通过简单拖拉设置操作即可设计出表单、流程、报表、H5、Web APP等页面,自动生成源代码,极大地节约了开发/维护的成本和周期。可以根据客户需求、快速开发出DEMO版,尤其是在大型项目调研对接过程,针对文档性资料不够直观,通过快速生成的DEMO版(其实就是后续正式的程序)让用户非常直观的看到软件项目的效果,对项目的调研起到事半功倍的效果,后续只要再次针对业务进行复杂业务逻辑的处理就可以完成项目的开发,基本上项目调研完成,软件项目基本上定型开发就已经完成,效率和效果得到空前提高。 参考技术D ES2007业务平台基于SOA架构体系,结合数据建模、业务建模、可视化流程引擎、动态表单设计等多种实现工具,是企业应用开发的一个高效、强大、开放的开发工具。其柔性的特点,保障了基于平台开发的系统可在.Net平台与J2EE平台上无缝的切换运行。
ES2007业务平台实现业务导向和驱动的软件开发,从根本上解决管理软件开发中的诸多难题,使企业信息系统真正实现“用户主控、随需而变、全局规划、整体集成”的信息化战略。渗透管理软件的设计、开发、调试、部署,到运行、维护、管控、治理的全生命周期。本回答被提问者采纳

数据库系统都有哪些,数据库软件都有哪些

目前流行的数据库系统有两类:
一类是关系型的数据库,有Oracle、MySQL、DB2、MS SQL Server,等
一类是所谓的NoSQL,有mongoDB、HBase 等等等

数据库软件,看你怎么定义了,是数据库应用软件,数据库开发软件,数据库管理软件?

基本上所有的ERP等企业管理软件都是基于数据库的,应该属于数据库应用软件的一类
比如Oracle、SAP等等都是知名的ERP软件
还有CRM软件也是基于数据库的。

数据库开发和管理软件就很多了,我个人将其分为两类,
一类是基于java的,一般是通用的,即支持多个数据库;比如AquaDataStudio、DbVisualizer等等等
一类是非java的,大多数都是专门用于某一类数据库的,比如plsqldeveloper、toad等等等;不过其中也有一些软件可以支持多种数据库。比如navicat、RapidSQL等等等
参考技术A

企业里常用的数据库软件有Mysql、PostgreSQL、MicrosoftSQLServer、Oracle数据库、MongoDB。

1、Mysql。

MySQL原本是一个开放源码的关系数据库管理系统,原开发者为瑞典的MySQLAB公司,该公司于2008年被升阳微系统(SunMicrosystems)收购。2009年,甲骨文公司(Oracle)收购升阳微系统公司,MySQL成为Oracle旗下产品。

MySQL由于性能高、成本低、可靠性好,已经成为最流行的开源数据库,因此被广泛地应用在Internet上的中小型网站中。随着MySQL的不断成熟,它也逐渐用于更多大规模网站和应用。

2、PostgreSQL。

PostgreSQL可以说是目前功能最强大、特性最丰富和结构最复杂的开源数据库管理系统,其中有些特性甚至连商业数据库都不具备。这个起源于加州大学伯克利分校的数据库,现已成为一项国际开发项目,并且拥有广泛的用户群,尤其是在海外,目前国内使用者也越来越多。

PostgreSQL基本上算是见证了整个数据库理论和技术的发展历程,由UCB计算机教授MichaelStonebraker于1986年创建。在此之前,Stonebraker教授主导了关系数据库Ingres研究项目,88年,提出了Postgres的第一个原型设计。

MySQL号称是使用最广泛的开源数据库,而PG则被称为功能最强大的开源数据库。

3、MicrosoftSQLServer。

SQLServer是Microsoft开发的一个关系数据库管理系统(RDBMS),现在是世界上最为常用的数据库。SQLServer 现在是包括内置的商务智能工具,以及一系列的分析和报告工具,可以创建数据库、备份、复制、安全性更好以及更多。

SQLServer是一个高度可扩展的产品,可以从一个单一的笔记本电脑上运行的任何东西或以高倍云服务器网络,或在两者之间任何东西。虽然说是“任何东西”,但是仍然要满足相关的软件和硬件的要求。

/iknow-pic.cdn.bcebos.com/4afbfbedab64034f8da90540a1c379310a551d14"target="_blank"title="点击查看大图"class="ikqb_img_alink">/iknow-pic.cdn.bcebos.com/4afbfbedab64034f8da90540a1c379310a551d14?x-bce-process=image%2Fresize%2Cm_lfit%2Cw_600%2Ch_800%2Climit_1%2Fquality%2Cq_85%2Fformat%2Cf_auto"/>

4、Oracle数据库。

Oracle数据库系统是美国Oracle(甲骨文)公司提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(Client/Server,C/S)或浏览器/服务器(Browser/Server,B/S)体系结构的数据库之一。

Oracle数据库是目前世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。

5、MongoDB

mongoDB是一个介于关系数据库和非关系数据库之间的开源产品,是最接近于关系型数据库的NoSQL数据库。它在轻量级JSON交换基础之上进行了扩展,即称为BSON的方式来描述其无结构化的数据类型。尽管如此它同样可以存储较为复杂的数据类型。

参考资料来源:/baike.baidu.com/item/mySQL/471251?fr=aladdin"target="_blank"title="只支持选中一个链接时生效">百度百科——Mysql

参考资料来源:/baike.baidu.com/item/PostgreSQL"target="_blank"title="只支持选中一个链接时生效">百度百科——PostgreSQL

参考资料来源:/baike.baidu.com/item/Microsoft%20SQL%20Server"target="_blank"title="只支持选中一个链接时生效">百度百科——MicrosoftSQLServer

参考资料来源:/baike.baidu.com/item/Oracle%E6%95%B0%E6%8D%AE%E5%BA%93"target="_blank"title="只支持选中一个链接时生效">百度百科——Oracle数据库

参考资料来源:/baike.baidu.com/item/MongoDB"target="_blank"title="只支持选中一个链接时生效">百度百科——MongoDB

    官方服务
      官方网站官方网站

以上是关于软件的系统架构和开发平台有哪些?具体都有哪几种呢?的主要内容,如果未能解决你的问题,请参考以下文章

常用的浏览器软件有哪几种?

自动化测试工具都有哪些

Nginx实现负载均衡的方式有哪几种呢?

虚拟化有哪几种架构

数据库系统都有哪些,数据库软件都有哪些

intel i处理器有哪几种架构,三个等级有啥区别?