The design and implementation of a workflow management system is typically a large and complex task. Decisions need to be made about the hardware and software platforms, the data structures, the algorithms, and network interconnection of various modules utilized by various users and administrators. These decisions are further complicated by requirements such as flexibility, robustness, modifiability, availability, performance, and usability. As the size of workflow systems increases, organizations are finding that the standard server/client architectures, and off-the-shelf solutions are not adequate. We can further see that in the future, very large-scale workflow systems (VLSW) will become more complex, and more prevalent. Thus, one further requirement is an emphasis of this document: scalability. For the purposes of our scalable workflow investigations, we describe a framework, a taxonomy, a model, and a methodology to investigate the performance of various workflow architectures as the size of the system (number of workcases) grows very large.First, this paper presents a novel workflow architectural framework and taxonomy. We survey some example current workflow products and research prototype systems, illustrating some of the taxonomical categories. In fact, most current workflow architectures fall into only one of the many categories of this taxonomy: the centralized server/client category. The paper next explains a performance analysis methodology useful for exploring this taxonomy. The methodology deploys a layered queuing model, and performs mathematical analysis on this model using a modified MOL (method of layers) combined with a linearization algorithm. Finally, the paper utilizes this methodology to compare and contrast the various architectural categories, providing interesting results about performance as the number of workcases increases. Our analytic results suggest that (a) for VLSW performance determination, software architecture is as important as hardware architecture, and (b) alternatives to the client server architecture provide significantly better scalability.
[1]
Jerome A. Rolia,et al.
The Method of Layers
,
1995,
IEEE Trans. Software Eng..
[2]
Lori A. Clarke,et al.
A Formal Model of Program Dependences and Its Implications for Software Testing, Debugging, and Maintenance
,
1990,
IEEE Trans. Software Eng..
[3]
Jerome Alexander Rolia,et al.
Predicting the performance of software systems
,
1992
.
[4]
Kwang-Hoon Kim,et al.
A Framework and Taxonomy for Workflow Architecture
,
2000,
COOP.
[5]
Carlos Maltzahn,et al.
The Chautauqua workflow system
,
1997,
Proceedings of the Thirtieth Hawaii International Conference on System Sciences.
[6]
K. Mani Chandy,et al.
Linearizer: a heuristic algorithm for queueing network models of computing systems
,
1982,
CACM.
[7]
Amit P. Sheth,et al.
CORBA-Based Run Time Architectures for Workflow Management Systems
,
1996
.
[8]
Clarence A. Ellis.
Team automata for groupware systems
,
1997,
GROUP '97.
[9]
Clarence A. Ellis,et al.
Architectures for very large scale workflow management systems
,
1998
.
[10]
Alexander L. Wolf,et al.
Acm Sigsoft Software Engineering Notes Vol 17 No 4 Foundations for the Study of Software Architecture
,
2022
.
[11]
Gustavo Alonso,et al.
Exotica/FMQM: A Persistent Message-Based Architecture for Distributed Workflow Management
,
1995
.