当前位置: 首页 > news >正文

2024年架构设计师论文-“模型驱动架构设计方法及其应用”

论模型驱动架构设计方法及其应用
模型驱动架构设计是一种用于应用系统开发的软件设计方法,以模型构造、模型转换和精化为核心,提供了一套软件设计的指导规范。在模型驱动架构环境下,通过创建出机器可读和高度抽象的模型实现对不同问题域的描述,这些模型独立于实现技术,以标准化的方式储存,利用模型转换策略来驱动包括分析、设计和实现等在内的整个软件开发过程。
请围绕“模型驱动架构设计方法及其应用”论题,依次从以下三个方面进行论述。
1.概要叙述你参与分析、设计的软件项目以及你在其中所承担的主要工作。
2.请简要描述采用模型驱动架构思想进行软件开发的全过程及其特点。
3.具体阐述你参与的软件项目是如何基于模型驱动架构完成分析、设计和开发的。

模型驱动架构设计方法及其应用

摘要

20xx 年 1 月,我所在公司中标XX 保险公司全国再保险大集中管理系统的建设项目,该项目为期 2 年半,总投资为 1xx万人民币。通过该项目,实现 XX 保险公司整体信息化转型升级的战略中再保险板块的落地,完成全国海量再保险业务数据的集中部署运行,迁移整合历史数据,全面替代上一代系统。我担任该项目开发的系统架构设计师,主导系统的分析、规划和设计工作,确保系统能够满足高并发、高流量业务需求,同时保证数据安全和系统的稳定。该项目 20xx 年 5 月完成系统上线, 20xx 年 6 月通过最终验收,得到了用户的一致肯定,顺利达成了项目既定目标。本文作者结合实际经验,以该项目为例,讨论一下项目建设的分析、设计和开发这几个过程来进行论述。

引言

随着我国经济的持续增长和保险市场的不断扩大,各类保险业务的数量和复杂性也在不断增加。再保险作为保险行业的“稳定器”,其需求也随之增长。尤其是在巨灾保险、责任险、健康险等新兴领域,再保险的作用更加凸显。20xx 年 1 月,我作为系统架构师,担任XX 保险公司全国再保险大集中管理系统的建设项目负责人之一,负责项目整体技术方案评估、立项论证以及项目系统架构设计工作。该平台建设期为 2 年半,总投资为 1xx 万人民币。该项目时间紧任务重,具有很大的挑战性,可总结为四个方面。一是业务模式升级,需按照最新的再保险业务流程,完成系统功能的分析开发,进而具体落地公司再保险业务流程的再造;二是技术要求高,要实现全国海量再保险业务数据的集中部署运行,每日处理数据量达到 3000 万笔以上,同时要满足性能要求。三是数据整合难,需要将上一代系统的中历时十年的数据,按其有效性进行分类、转化、整合,实现历史存续业务数据在新系统环境下,按照新新模式正常运行。四是涉及人员组织多,直接研发团队成员 36 人,XX 保险公司总部再保险部、财务部、风险部、八大业务部、40 个省公司等 400 余人,同时涉及外部配合协作承保系统、核保系统、理赔系统、收付费系统、财务系统等 30 余人。项目启动后,作为主要负责人,牵头与公司内部技术专家、架构师一同建立项目技术架构组,设计项目整体技术架构。经过团队成员开会讨论,最终决定采用模型驱动架构设计方法来完成本项目的开发。

模型驱动架构设计方法

模型驱动架构设计(Model-Driven Architecture,MDA)是一种软件设计方法,旨在通过模型的创建和使用来提高软件开发的效率、可维护性和可移植性。其核心理念是将业务分析与业务实现分离,将软件开发人员的关注点转移到业务领域和业务建模。模型驱动架构设计可总结为以下六个过程:

  1. 需求分析。架构师需要与客户进行深入沟通,收集客户的详细需求,根据业务领域进行分析,生成CIM,即计算无关模型;
  2. 创建平台无关模型(Platform Independent Model,PIM)。从CIM使用统一建模语言工具生成PIM,描述系统的逻辑结构和行为,不依赖于任何特定的技术平台和实现技术细节,重点关注系统的结构、行为和交互。
  3. 生成平台相关模型(Platform Specific Model, PSM)。定义明确的转换规则,利用模型转换工具从PIM生成一个或多个PSM,针对不同平台的特定实现。此阶段考虑到特定技术栈、框架和工具,比如编程语言、数据库和中间件等。
  4. 代码生成。根据PSM模型,使用代码生成工具自动生成对应的代码框架,指导开发人员完成后续的编码工作,提高开发人员效率。
  5. 验证测试。对于开发人员修改后的代码进行测试,确保符合需求和设计思路。
  6. 迭代与改进。根据反馈和变化的需求,迭代更新模型,持续改进系统。
    MDA的特点促进了技术和业务的分析,业务人员可以专注于业务模型定义和精细化修改,技术人员负责蒋其转化为具体的实现,这使得软件开发更加规范、高效。同时,MDA强调模型的可重用性和标准化,有助于降低开发成本、提高软件质量。

模型驱动架构设计方法应用

在我参与XX 保险公司全国再保险大集中管理系统项目中,采纳了模型驱动架构(MDA)的设计理念。下面我从分析阶段、设计阶段和开发阶段阐述我们团队如何利用模型驱动架构的理念推动开发。

分析阶段:我们精研需求文档,运用先进的建模工具精心构建了再保险大集中管理的CIM(计算无关模型)框架。此模型不仅深刻剖析了系统的业务逻辑精髓,还细致描绘了业务流程的脉络与业务规则的严谨性,为项目团队绘制了一幅清晰无碍的业务蓝图,为后续的设计与开发工作奠定了坚实的基础。

设计阶段:基于CIM模型的坚实基础,我们进一步采用统一的建模语言(UML)创建PIM模型(平台无关模型)。此阶段,我们越过技术细节,聚焦于系统核心业务流程的优化与系统架构的宏观布局,明确了模块间的协作机制与接口规范。这一系列设计为后面代码编写铺平了道路,为开发团队提供了明确的指引。

开发阶段:随着设计阶段模型的精细化完成,我们设定好规则,将PIM转化为多个PSM,并借助高效的代码生成工具,实现了从模型到代码的自动化转换。这一过程不仅自动生成了数据库表结构、接口定义、类定义等关键代码元素,还极大地减轻了开发人员的负担,使他们能够将更多精力聚焦于对自动生成代码的微调与优化上。此举不仅显著提升了开发效率,更有效控制了人为错误的发生,确保了软件质量的高标准。

此外,我们在系统中预留了灵活的在线升级接口,旨在积极响应未来用户反馈,实现系统的持续迭代与优化,进行而形成一套科学规范的运维管理体系,从而不断提升用户体验。

总结

该项目于202x年3月完成系统上线,202x年4月通过最终验收,得到用户的一致好评,顺利达成了项目既定的目标。尤其在系统整体架构技术方面,效果尤为突出,其一,保持了较好的灵活性,提供较多的基础组件,使得应用便于横向扩充,满足了项目业务灵活性;其二,系统性能达到了各个层次的整合设计,数据库层中分片和读写是分离,应用开发层采用缓存技术,严格限制查询条件,服务部署层采用集群部署、F5分发技术。这使得业务日处理能力达5500万单以上,预留了40%的性能,满足了公司未来三到五年的业务增量。

相关文章:

2024年架构设计师论文-“模型驱动架构设计方法及其应用”

论模型驱动架构设计方法及其应用 模型驱动架构设计是一种用于应用系统开发的软件设计方法,以模型构造、模型转换和精化为核心,提供了一套软件设计的指导规范。在模型驱动架构环境下,通过创建出机器可读和高度抽象的模型实现对不同问题域的描述…...

Tapd敏捷开发平台的使用心得

Tapd敏捷开发平台的使用心得 一、Tapd 简介 TAPD(Tencent Agile Product Development),腾讯敏捷产品研发平台行业领先的敏捷协作方案,贯穿敏捷产品研发生命周期的一站式服务,了解敏捷如下图 二、几个核心模块概念 需求迭代缺陷故事墙前期项目需求的管理,可以按类别建…...

远程桌面 Rust Desk 自建服务器

因为某些原因(诈骗),Rush Desk 服务已暂停国内访问,今天我们介绍如何利用自己的服务器搭建 Rust Desk 远程桌面,低延迟电脑远程手机,手机远程电脑等 一、准备工作 准备一台服务器,我用的腾讯云服务器,一年…...

开源网安引领AIGC+开发安全,智能防护铸就软件安全新高度

近日,国内网络安全领域知名媒体数说安全正式发布了《2024年中国网络安全市场100强》和《2024年中国网络安全十大创新方向》。开源网安凭借在市场表现力、资源支持力以及产品在AI方向的创新力上的优秀表现成功入选百强榜单,并被评为“AIGC开发安全”典型厂…...

树和二叉树

树 节点(Node:) 树由一系列的节点组成,每个节点可以包含数据和指向其他节点的链接。 节点通常包含一个数据元素和若干指向其他节点的指针 根节点(Root): 树的顶部节点称为根节点&#xff0c…...

一篇带你速通差分算法(C/C++)

个人主页:摆烂小白敲代码 创作领域:算法、C/C 持续更新算法领域的文章,让博主在您的算法之路上祝您一臂之力 欢迎各位大佬莅临我的博客,您的关注、点赞、收藏、评论是我持续创作最大的动力 差分算法是一种在计算机科学中常用的算法…...

贷款利率高低跟什么有关?仅凭身份证就能贷到款?额度是多少?

在金融的广阔舞台上,借款人的“信用基石”——即其综合资质,是决定贷款利率高低的决定性因素。这并非偶然,而是银行基于详尽的风险评估与收益预期所做出的精准判断。 需明确的是,贷款的易得性并不意味着无门槛的放任。它更像是设置…...

苹果电脑需要安装杀毒软件吗?探索Mac的安全世界!

在聊到电脑安全时,许多Mac用户都骄傲地声称:“我的Mac是不会中病毒的!”确实,与Windows PC相比,Mac因其UNIX-based的操作系统构架,天生就更加安全。但这是否意味着Mac完全不需要杀毒软件呢?让我…...

Oracle start with connect BY 死循环

解决办法 检查start with前有没有where条件, 如果有的话,套一层select,再 Oracle start with connect BY...

力扣接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表…...

bug“医典”

温馨提示:本篇文章主要用于收藏博主所遇到的各种bug,并且不定期更新 目录 未初始化 “病状” “处方” 数组越界 “病状” “处方” 未创建对象 “病状” ​编辑 “处方” 未初始化 “病状” 这种是处在链表中的一种情况,通常是没有处理哨兵位…...

Track 06:量子计算机概述

量子计算机概述 量子计算机是基于量子力学原理的一种计算机,它与传统的经典计算机在处理信息的方式上有根本性的区别。量子计算机的设计和实现依赖于量子比特(qubits)和量子计算的核心概念,如叠加态和纠缠态,这些特性使其在解决某些复杂问题时具备传统计算机无法比拟的优…...

论文解读 | KDD2024 演化图上的森林矩阵快速计算

点击蓝字 关注我们 AI TIME欢迎每一位AI爱好者的加入! 点击 阅读原文 观看作者直播讲解回放! 作者简介 孙浩鑫,复旦大学博士生,主要研究方向为大规模图上快速算法设计。 概述 森林矩阵在网络科学、观点动力学和机器学习相关应用中…...

7.统一网关-Gateway

文章目录 1.统一网关介绍2.网关开发3.predicate4.Route Predicate Factories(路由断言工厂)4.1Path 路由断言工厂4.2.Method 路由断言工厂4.3 Header 路由断言工厂4.4 Query 路由断言工厂4.5 Host 路由断言工厂4.6 After 路由断言工厂4.7 Before 路由断言工厂4.8 Between 路由断…...

QT:QWidget 控件属性的介绍

控件属性介绍 🌴enabled 状态属性🌴geometry 几何属性示例一:改变控件尺寸示例二:更变控件位置window frame 的影响 🌴windowTitle 窗口标题🌴windowIcon 窗口图标🌴 qrc机制🌴windo…...

ctfshow-nodejs

什么是nodejs Node.js 是一个基于 Chrome V8 引擎的 Javascript 运行环境。可以说nodejs是一个运行环境,或者说是一个 JS 语言解释器 Nodejs 是基于 Chrome 的 V8 引擎开发的一个 C 程序,目的是提供一个 JS 的运行环境。最早 Nodejs 主要是安装在服务器…...

Linux 大文件和大量小文件的复制策略

在Linux上复制大文件或大量小文件时,可以根据文件的类型、数量以及硬件配置(如硬盘类型、CPU、内存)选择不同的复制策略,以提高复制效率。以下是一些常见的策略和工具,可以根据具体情况使用: 1. 大文件复制…...

0.3 学习Stm32经历过的磨难

文章目录 用库函数传参 能否按位或STM32库函数XXX_GetFlagStatus和XXX_GetITStatus的区别关于MDK导入文件后报错 Browse information of one files is not available用exti中断读取按键 忘记消抖 (更离谱的是,我忘记开启afio的时钟了 Damn!)D…...

9、Django Admin优化查询

如果你的Admin后台中有很多计算字段,那么你需要对每个对象运行多个查询,这会使你的Admin后台变得非常慢。要解决此问题,你可以重写管理模型中的get_queryset方法使用annotate聚合函数来计算相关的字段。 以下示例为Origin模型的中ModelAdmin…...

数据结构基础之《(3)—二分法》

一、认识二分法 1、经常见到的类型是在一个有序数组上,开展二分搜索 2、但有序真的是所有问题求解时使用二分的必要条件吗?不 3、只要能正确构建左右两侧的淘汰逻辑,你就可以二分 二、二分法怎么用 1、在一个有序数组中,找某个…...

【杂谈】-递归进化:人工智能的自我改进与监管挑战

递归进化:人工智能的自我改进与监管挑战 文章目录 递归进化:人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管?3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...

Java 8 Stream API 入门到实践详解

一、告别 for 循环&#xff01; 传统痛点&#xff1a; Java 8 之前&#xff0c;集合操作离不开冗长的 for 循环和匿名类。例如&#xff0c;过滤列表中的偶数&#xff1a; List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...

《Playwright:微软的自动化测试工具详解》

Playwright 简介:声明内容来自网络&#xff0c;将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具&#xff0c;支持 Chrome、Firefox、Safari 等主流浏览器&#xff0c;提供多语言 API&#xff08;Python、JavaScript、Java、.NET&#xff09;。它的特点包括&a…...

(二)TensorRT-LLM | 模型导出(v0.20.0rc3)

0. 概述 上一节 对安装和使用有个基本介绍。根据这个 issue 的描述&#xff0c;后续 TensorRT-LLM 团队可能更专注于更新和维护 pytorch backend。但 tensorrt backend 作为先前一直开发的工作&#xff0c;其中包含了大量可以学习的地方。本文主要看看它导出模型的部分&#x…...

2025 后端自学UNIAPP【项目实战:旅游项目】6、我的收藏页面

代码框架视图 1、先添加一个获取收藏景点的列表请求 【在文件my_api.js文件中添加】 // 引入公共的请求封装 import http from ./my_http.js// 登录接口&#xff08;适配服务端返回 Token&#xff09; export const login async (code, avatar) > {const res await http…...

【单片机期末】单片机系统设计

主要内容&#xff1a;系统状态机&#xff0c;系统时基&#xff0c;系统需求分析&#xff0c;系统构建&#xff0c;系统状态流图 一、题目要求 二、绘制系统状态流图 题目&#xff1a;根据上述描述绘制系统状态流图&#xff0c;注明状态转移条件及方向。 三、利用定时器产生时…...

大模型多显卡多服务器并行计算方法与实践指南

一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...

重启Eureka集群中的节点,对已经注册的服务有什么影响

先看答案&#xff0c;如果正确地操作&#xff0c;重启Eureka集群中的节点&#xff0c;对已经注册的服务影响非常小&#xff0c;甚至可以做到无感知。 但如果操作不当&#xff0c;可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码

目录 一、&#x1f468;‍&#x1f393;网站题目 二、✍️网站描述 三、&#x1f4da;网站介绍 四、&#x1f310;网站效果 五、&#x1fa93; 代码实现 &#x1f9f1;HTML 六、&#x1f947; 如何让学习不再盲目 七、&#x1f381;更多干货 一、&#x1f468;‍&#x1f…...

R 语言科研绘图第 55 期 --- 网络图-聚类

在发表科研论文的过程中&#xff0c;科研绘图是必不可少的&#xff0c;一张好看的图形会是文章很大的加分项。 为了便于使用&#xff0c;本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中&#xff0c;获取方式&#xff1a; R 语言科研绘图模板 --- sciRplothttps://mp.…...