[原创] 如何在企业应用中使用嵌入式工作流引擎-1

原创 2004年11月02日 17:18:00

前言

        有关工作流的基本概念、标准等方面的文章和有关资源现在很容易获得,使用工作流管理系统(WFMS)或业务流程管理(BPM)对企业在商业上的意义与利益,已经无人不晓了。可是虽然很多人都说工作流技术将会成为IT架构的基础组成部分[1],当我们要在自己开发的企业级应用中使用工作流技术时,该如何设计实现呢?关于这个问题的文章很少。

        本文针对想在企业级应用中使用工作流技术的软件开发人员,基于作者工作学习的经验和心得,介绍如何在企业级应用中使用嵌入式工作流引擎。文章首先描述了需求范围,然后介绍了业务流程的分析和设计要考虑的问题,最后实现了一个完整的例子。文章的内容很有限,但我可以确定的是:在企业级应用开发一线的技术人员,需要可以帮助他们快速解决问题、有实质内容的文章,本文应该可以在一定程度上为他们提供一些有用的信息。

需求范围

        企业级应用(Enterprise Applications)也可称为信息系统(Information Systems)或者商业应用(Commercial applications)。对于企业级应用的特点,总结Martin Fowler在[2]中和Bevington在[3]中的阐述可以得到如下几点:

        大量的持久化数据:企业的业务活动状态由持久化数据保持。表现为数据量大、持续的时间长,数据之间有业务关联,一般都使用关系数据库系统作为存储管理工具;

        多用户:企业的业务活动状态由多个用户,通过大量的交互界面查询和更新。企业应用要在多用户之间保持业务活动状态的完整和一致性;

    复杂的业务逻辑:为了满足商务需要,业务逻辑复杂、多变,有时甚至“无逻辑可循”;

    企业级应用之间的集成:企业的业务可能跨越多个应用系统。

 

        在企业级系统中应用工作流技术主要解决两类问题[4 p110]:包含在一个业务或软件过程中的所有实体的协作和系统内外部的数据、资源、应用逻辑等的集成。工作流技术的应用方式也分为两种:独立(Stand-alone)的工作流管理系统和嵌入(Embedded)的工作流组件。“在上个世纪80-90年代,大部分工作流应用采用第一种应用方式(独立)。现在,对于包含复杂流程的应用系统,许多软件提供商重新定位和设计它们的工作流产品,使其成为应用系统的构建模块(即嵌入式)”。[4 p116]

    本文提供的内容适用于,以解决企业级应用中“协作”问题为主要目的的嵌入式工作流组件的使用。

(待续)

参考文章:
1、Delphi Study: The Future of Process Automation :What is the role of Process Automation Technology in future Information System Architectures? http://www.stevens.edu/workflow/projects/delphi/round_1/question8.htm

2、“Patterns of enterprise application architecture” by Martin Fowler ISBN 0-321-12742-0

3、“Business function specification of commercial applications” by Bevington IBM SYSTEMS JOURNAL, VOL 39, NO 2, 2000

4、“Workflow-based Process Controlling”http://www.workflow-research.de/Publications/Book/index.html by Michael zur Muehlen

5、“http://www.joinwork.net/document/The State of Workflow2.htm The state of Workflow”[中文] by Tom Baeyens

嵌入式 建立ssl连接过程分析一

Https协议:SSL建立过程分析 web访问的两种方式: http协议,我们一般情况下是通过它访问web,因为它不要求太多的安全机制,使用起来也简单,很多web站点也只支持这种方式下的访问. ...
  • skdkjxy
  • skdkjxy
  • 2013年12月02日 14:46
  • 1327

如何制作嵌入式Linux虚拟机

如何制作嵌入式Linux虚拟机
  • u010096900
  • u010096900
  • 2016年12月05日 17:10
  • 1121

杂谈:微信推出赞赏码功能

近日微信的新功能多了一个针对个人打赏的赞赏码功能,这个功能和其他付款码实际上差不多。但针对上次苹果对公众号抽水一事情,这次更新更让人猜想到一些奇怪的意图。昨天晚上,我尝试一下这个功能。当开启后,这个赞...
  • hero82748274
  • hero82748274
  • 2017年10月29日 07:55
  • 302

嵌入式环境下的gdb调试方法

采用GDB方法调试,由于嵌入式系统资源有限性,一般不能直接在目标系统上进行调试,通常采用gdb+gdbserver的方式进行调试。目标系统必须包括gdbserver程序,宿主机也必须安装gdb程序。在...
  • newyoung518
  • newyoung518
  • 2014年05月07日 23:40
  • 1147

使用NetBeans EJB 创建企业应用程序

使用 EJB 3.1 创建企业应用程序本教程介绍了开发 Java EE 6 企业应用程序的基础知识,并说明了作为 Java EE 6 规范一部分引入的某些 EJB 3.1 技术功能。在本教程中,将创建...
  • u011225629
  • u011225629
  • 2015年11月16日 17:58
  • 2045

嵌入式开发服务器构架

 一、需求  由于嵌入式项目日益庞大,直接导致开发团队人员的增涨,由此导致在开发过程中出现很多问题。例如团队内部交叉编译工具的不同,导致最终软件的异 常或不能运行(这种问题的出现,大多数情况是由于操作...
  • My_emdebed
  • My_emdebed
  • 2007年04月25日 17:40
  • 1057

苹果企业号-通过网页下载应用,部署应用分发服务器

#TODO创建证书打包ipa文件配置plist文件必需配置的值 节点 说明 示例 software-package 你的ipa文件url https://www.itest.co...
  • blacklife00544
  • blacklife00544
  • 2016年07月20日 11:01
  • 660

ARM嵌入式系统移植环境搭建

ARM嵌入式系统移植环境搭建 安装eldk42 QA 列表 安装eldk时报sh opteldkbinrpm not found footnote 找不到ia32-libs包E Package ia3...
  • taotaoyouarebaby
  • taotaoyouarebaby
  • 2016年09月23日 23:35
  • 916

Caffe学习笔记(1)--在spyder中 import caffe

在配置好caffe环境之后无法在anaconda的spyder中直接导入caffe的库,需现先将caffe的路径导入进去。操作如下:import sys caffe_home = '/home/kel...
  • spcq4
  • spcq4
  • 2016年09月24日 22:52
  • 636

嵌入式linux程序之调试方法

裸板调试1.点灯法(程序能运行到的地方点灯) 2.串口打印 3.调试器,JTAG,仿真器JTAG调试原理,硬件断点和软件断点http://blog.csdn.net/gowyz/article/d...
  • u013426958
  • u013426958
  • 2015年09月05日 17:25
  • 257
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[原创] 如何在企业应用中使用嵌入式工作流引擎-1
举报原因:
原因补充:

(最多只允许输入30个字)