第十二章 Productions最佳实践 - 命名约定

news2025/1/12 8:55:12

文章目录

  • 第十二章 Productions最佳实践 - 命名约定
  • 命名约定
      • 业务服务
      • 路由进程
      • 路由规则集
      • 业务操作
      • 数据转换
  • 自定义架构类别

第十二章 Productions最佳实践 - 命名约定

命名约定

本主题解释命名约定的重要性并提供示例。

通常,将逐步开发产品,一次开发一个界面。有一种“随心所欲”命名项目的诱惑,并允许命名约定随着项目的进行而逐渐增长。 建议不要采用这种渐进的命名约定方法。

请记住,一个完整的 HIS 系统可能涉及数百个接口。一旦包含所有这些接口,预计管理路由生产的任务。每个组件的名称应清楚地标识其用途。这样,开发人员和系统管理员可以轻松地根据功能预测组件的名称。

建议在项目开始时建立一套完整的命名约定,然后坚持使用。这减少了为了更正名称而回溯到您的生产配置的需要。

任何按功能明确标识组件的约定都可以。以下是几位 客户成功使用的一整套命名约定:

  • 有关配置项名称的规则,请参阅配置产品中的“配置名称”。
  • 列出将组装以创建名称的各个段。这些可能包括:
    • 关键词
      • From for incoming
      • To for outgoing
      • Router for routing
      • Rules for rule sets
      • 基本架构类别编号 — 2.1、2.2、2.3、2.3.1、2.4、2.5、2.5.1、2.6、2.7 或 2.7.1 — 用于架构
    • 每个应用程序的简称
    • 标识一般消息结构类(ADTORM 等)的关键字
    • 完整的消息结构名称(ADT_A01ADT_A04ORM_O01 等)
  • 保持名称的每个部分简短(3-6 个字符)
  • 请记住名称区分大小写

对于生产的每个元素,从定义的片段中组合一个名称:

  • 业务服务:FromSourceAppName
  • 业务操作:ToTargetAppName
  • 路由进程:SourceAppNameRouter
  • 路由规则集:SourceAppNameRules
  • 数据转换:SourceAppNameSourceMessageTypeToTargetAppNameTargetMessageType
  • 自定义架构类别:SourceAppNameBaseSchemaNumber

对于更复杂的设计:

  • 业务服务:FromSourceAppNameMessageTypes
  • 业务操作:ToTargetAppNameMessageTypes
  • 路由进程:SourceAppNameMessageTypesRouter
  • 路由规则集:SourceAppNameMessageTypesRules

以下主题提供了这些命名约定的解释和示例。

业务服务

Convention

在这里插入图片描述

Examples

FromERChart, FromFineOR, FromDeskAdm

Variation

在这里插入图片描述

如果决定组织一个接口,以便一个应用程序通过多个业务服务将消息发送到 IRIS,还包括一个关键字,用于对通过每个业务服务的消息类型进行分类。典型的 MessageTypes 关键字使用消息结构的前三个字母。在这种情况下,业务服务名称的约定是 FromSourceAppNameMessageTypes

路由进程

Convention

在这里插入图片描述

Examples

ERChartRouter, FineORRouter, DeskAdmRouter

如果决定组织一个接口,以便一个应用程序通过多个业务服务将消息发送到 IRIS,还包括一个关键字,用于对通过每个业务服务传递到其路由进程的消息类型进行分类。在这种情况下,路由进程名称的格式如下

Variation

在这里插入图片描述

Examples

ERChartADTRouter, ERChartORMRouter, ERChartOtherRouter

路由规则集

Convention

每个路由进程都有一个关联的规则集,其规则确定消息目的地。这些规则根据消息类型、消息内容、一天中的时间或其他因素将消息定向到数据转换或业务操作。命名每个规则集以匹配其路由过程。也就是说,对于每个 SourceAppNameRouter,调用规则集 SourceAppNameRules。对于每个 SourceAppNameMessageTypesRouter,调用规则集 SourceAppNameMessageTypesRules

Examples

DeskAdmRules

DeskAdmORMRules

业务操作

Convention

在这里插入图片描述

ToImagit, ToFineOR, ToPindex

Variation

在这里插入图片描述

如果决定组织一个接口,以便一个应用程序通过多个业务操作从 IRIS 接收消息,还包括一个关键字,用于对通过每个业务操作的消息类型进行分类。

数据转换

请记住,SourceMessageTypeTargetMessageType 可能具有相同的名称,但在不同的模式类别中表示相同的消息结构。

自定义架构类别

ApplicationName BaseSchemaNumber

ApplicationName 可以表示发送应用程序或接收应用程序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/558294.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CAD数据库下包含的表记录

AutoCAD数据库(AcDb)是一些存储在数据库中的对象的集合。 数据词典,符号表是存储数据库对象的容器(Container Object),用于组织和管理数据库对象。这两种容器对象都有与之相关的符号名,用字符来表示。 符号表是固定的…

chatgpt赋能Python-python_ipython

Python和IPython:SEO编程最佳实践 Python 是一种高级动态编程语言,被许多人用于开发各种应用程序和脚本。它是一个易于学习和使用的语言,提供了一些流行的框架和库来减少开发时间。另一方面,IPython 是Python的交互式命令行界面和…

面试:Babel 的编译过程

Babel 是一个 JavaScript 编译器,是一个工具链,主要用于将采用 ECMAScript 2015 语法编写的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中。 Babel 本质上就是在操作 AST 来完成代码的转译。AST是抽…

Ubuntu GitLab服务器git-data中tmp_pack_xxx文件占满磁盘

Ubuntu GitLab服务器git-data中tmp_pack_xxx文件占满磁盘 目录 Ubuntu GitLab服务器git-data中tmp_pack_xxx文件占满磁盘一、问题发现二、查找原因三、解决方法 服务器版本: cat /proc/version:Linux version 4.15.0-142-generic (builddlgw01-amd64-039…

Spring Initializr方式构建Spring Boot项目

文章目录 一,创建Spring Boot项目二,创建控制器三,运行入口类四,访问Web页面五,修改访问映射路径六,利用控制器返回页面1、添加thymeleaf依赖2、准备图片作为静态资源3、创建样式表作为静态资源4、创建首页…

最强Mock 工具,没人反对吧?

背景 在开发过程中,由于后端与前端并行开发,或者前端需要等待后台开发,难以保证对接效率,同时即使用开发好的 API 对接,也有可能一个 API 不通就阻塞了整个软件的对接工作。同时对软件的敏感度也很高,一不…

微软推出 Hierarchical Transformer 实现更高准确率的语音评测

对于语言学习者来说,练习发音并获得及时准确的反馈,是提高口语水平的重要环节。多年来,微软一直深耕基于 Azure 认知服务的语音功能,不断优化语音评测[1]功能的底层技术,从准确率、流畅度、完整性和语音语调等方面&…

Cadence+SPB16.2入门教程(下)

弹出Create Net Class对话框,如图4.21所示。输入名称DDR_DATA,点击OK关闭对话框。 建立DDR_ADDR的过程也一样,同时选中网络XM1ADDR0-XM1ADDR15,XM1CASN、XM1CKE0、XM1CSN0、XM1RASN、XM1WEN后右键Create->Net Class。其它就不重复了。 然后将上一步建立的两个电气规则D…

chatgpt赋能Python-python_ijust

简介 Python ijust,是一款非常优秀的Python代码编辑器,它支持多种语言编程、自动补全、代码高亮、代码片段库和多种主题等众多特性。Python ijust 可以在Windows、macOS、Linux上运行,而且界面简洁、易用。 主要功能 代码高亮:P…

【MySQL新手到通关】第三章 基本的SELECT语句

文章目录 1. SQL 概述1.1 SQL 背景知识 1.2 SQL 分类2. SQL语言的规则与规范2.1 基本规则2.2 注释2.3 数据导入指令 3. 基本的SELECT语句3.1 SELECT ... FROM3.2 列的别名3.3 去除重复行3.4 空值参与运算3.5 着重号 4. 显示表结构5. 基本的过滤数据 1. SQL 概述 1.1 SQL 背景知…

计讯物联打造医疗设备远程质检“新神器”TG453,引领医疗设备数字化浪潮

方案背景 基于物联网的普及与推广,物联网技术在医疗行业得到更广泛的应用。在医院的日常诊疗工作开展中,CT、呼吸机、监护仪、注射泵、核磁共振、DR系统、工频X光机等医疗设备稳定无故障地运行对于医院、患者而言具有重要影响。医疗设备在长期使用过程中…

讨论:为什么越来越多的企业开始搭建属于自己的知识库?

随着信息技术的发展,人们可以在互联网上随时随地获取各种信息。企业作为一个独立的组织体系,其运营和管理需要依赖于大量的知识和信息。因此,建立一个属于自己的知识库,可以帮助企业更好地管理和共享知识,提高员工的工…

VS Code 大量 Java 新功能来袭!

大家好,欢迎来到 Visual Studio Code Java 的 4 月更新!在此博客中,我们将带来大量基础用户体验更新,其中包括调试功能改进、Maven 插件中的配置文件支持、全新 Java Project Explorer 的用户界面和 Spring Boot 项目的可视化增强…

2.shell脚本基本操作及案例

本文介绍了shell脚本的基本建立过程,并举了4个案例。关键是例3的shell脚本检测局域网ip地址机器是否宕机,例4的shell脚本获取本机ip地址 一、第一个shell脚本 1、定义解释器 #!/bin/bash echo "hello world" #! 是一个约定的标记…

[玩游戏想道理]底层能力提升

继续金铲铲中想道理; overview 很多熟悉的情况是调用记忆即可,但是新的情况则需要使用底层能力,包括不限于做事的方式倾向,对事物的深刻理解等等; 既有事情更多在调用和打磨记忆,新的事物更多调用和打磨底…

『C++』C++的IO流详解

「前言」文章是关于C的IO流 「归属专栏」C嘎嘎 「笔者」枫叶先生(fy) 「座右铭」前行路上修真我 「枫叶先生有点文青病」 「每篇一句」 就像山看水,水流山还在, 喜欢之人,只管远去, 我只管喜欢。 ——烽火戏诸侯《剑来》 目录 一…

留学热议话题:在美国可以用ChatGPT写作业吗?

今年,学术界最热议的话题要数人工智能技术非大语言数据模型ChatGPT了。随着ChatGPT等智能写作助手在学生群体中的应用和日益普及,极大程度地影响了学生们的传统学习方法。然而,在享受技术革新带来便利的同时,不恰当的运用这些软件…

rails routes的使用

Rails routes 是用于确定应该将请求发送到哪个控制器和操作的一种机制。在 Rails 应用程序中,可以通过定义路由来映射 URL 到控制器操作。可以使用 rails routes 命令查看当前应用程序中定义的所有路由。 以下是一些常见的用法: 查看所有路由&#xff…

从三个层次来介绍用于机器人主控板的设计思想

在很多人眼里,主控板有着密密麻麻的芯片引脚与PCB走线,看起来非常难的样子。其实恰恰相反,主控板的设计有着其特有的设计规律,其实说白了就像搭积木,在满足单片机最小系统的条件下,需要哪些功能&#xff0c…

chatgpt赋能Python-python_head_first

Python Head First:学习Python编程的必备指南 如果你是一位编程新手,尤其是对Python感兴趣,那么Head First Python是你需要阅读的书籍之一。这本书通过富有趣味性的教学方法,让你轻松理解Python编程语言。 了解Python编程 Pyth…