This application claims priority to and the benefit of Korean Patent Application No. 10-2010-0129530 filed in the Korean Intellectual Property Office on Dec. 16, 2010, the entire contents of which are incorporated herein by reference.
The present invention relates to a workflow processing system and method for supporting the multi-tenancy. More particularly, the present invention relates to a workflow processing system and method for supporting the multi-tenancy in a software as a service (SaaS) environment.
With development of a reliable large capacity Internet access technology and a service-oriented architecture technology, and with increase in maintenance and repair cost of package software, a web based service of a new scheme called software as a service (SaaS) is rapidly growing. In a conventional art, large cost is required to provide the same service to a plurality of tenants. To reduce the cost, a single service is provided using a web based multi-tenant supporting scheme in a SaaS environment. Also, in the conventional art, to provide a service to a single tenant, exclusive resources including software, hardware, and the like, are allocated to the tenant. However, in the SaaS environment, only a single software instance is managed and can be shared by a plurality of tenants and thereby be used. Accordingly, it is possible to obtain a great economical effect such as a decrease in management cost, a decrease in resource construction cost, and the like.
Many technologies have been proposed to provide a service for enabling the multi-tenancy to share and thereby use a single software instance as if the multi-tenants use a resource dedicated for each group. As one example, To support the multi-tenancy metadata technology, a workflow authentication technology, and the like, are provided. For example, a technology for providing a service that enables each tenant to share and use a single software instance as if each tenant uses a unique service dedicated to a corresponding tenant and configured is very important. Multi-tenant metadata research has been proposed a plurality of technologies, such as schema mapping, a share schema, and the like.
However, in a technology associated with the multi-tenancy support workflow, a configuration method is provided only in a limited area such as a workflow authentication technology and the like. In an existing SaaS environment supporting a workflow, the multi-tenancy is enabled to simply use a workflow engine using an online scheme and a function capable of configuring and using a single defined workflow instance is not supported. Accordingly, a defined workflow is used as is or a new workflow needs to be defined and thereby be used. In this case, compared to providing a single workflow instance to the multi-tenancy, the above method may have high cost and low efficiency in an aspect of resource sharing or resource management.
The present invention has been made in an effort to provide a workflow processing system and method that may configure a workflow to be suitable for a tenant environment and thereby support the multi-tenancy in the multi-tenancy support environment.
An exemplary embodiment of the present invention provides a workflow processing system for supporting the multi-tenancy, including: an activity extractor to extract at least one activity associated with a workflow for providing a software service; an activity configuration unit to configure an extracted activity based on a schema customized for a selected tenant; and a storage processing unit to store a workflow that is an activity extraction target and the configured activity.
The workflow processing system may further includes a workflow editor to edit an edition requested workflow by overwriting a first activity, predetermined for each selected tenant, at a second activity location of the edition requested workflow, and a workflow executor to execute an edited workflow for each tenant.
The workflow editor may determines the first activity for each selected tenant based on metadata that is used to associate the configured activity and the workflow that is the activity extraction target. Also, the workflow editor determines the second activity associated with the first activity based on information about an identifier.
The workflow processing system may further includes a workflow processing unit to objectize the execution requested workflow. The workflow editor edits the execution requested workflow by performing activity serialization after the overwriting operation. When the metadata does not exist, the workflow executor commonly executes an unedited workflow with respect to all tenants in which the metadata does not exist.
The storage processing unit may further stores metadata that is used to associate the configured activity and the workflow that is the activity extraction target, and classifies and thereby stores each of the workflow that is the activity extraction target, the configured activity, and the metadata.
The workflow processing system may be driven when tenants desire to share a single workflow.
The activity extractor may extracts at least one activity that is selected from a control functioning activity, an allocation functioning activity, and a system interaction functioning activity.
Another exemplary embodiment of the present invention provides a workflow processing method for supporting the multi-tenancy, the method including: extracting at least one activity associated with a workflow for providing a software service; configuring an extracted activity based on a schema customized for a selected tenant; and storing a workflow that is an activity extraction target and the configured activity.
After the storage processing operation, the workflow processing method may includes editing an edition requested workflow by overwriting a first activity, predetermined for each selected tenant, at a second activity location of the edition requested workflow, and executing an edited workflow for each tenant.
The workflow edition operation may determines the first activity for each selected tenant based on metadata that is used to associate the configured activity and the workflow that is the activity extraction target. Also, the workflow edition operation determines the second activity associated with the first activity based on information about an identifier.
Before the workflow edition operation, the workflow processing method may includes objectizing the execution requested workflow. The workflow edition operation edits the execution requested workflow by performing activity serialization after the overwriting operation. When the metadata does not exist, the workflow execution operation commonly executes an unedited workflow with respect to all tenants in which the metadata does not exist.
The storage processing operation may further stores metadata that is used to associate the configured activity and the workflow that is the activity extraction target, and classifies and thereby stores each of the workflow that is the activity extraction target, the configured activity, and the metadata.
The workflow processing method may be performed when tenants desire to share a single workflow.
The activity extraction operation may extracts at least one activity that is selected from a control functioning activity, an allocation functioning activity, and a system interaction functioning activity.
According to exemplary embodiments of the present invention, the following advantages may be obtained by configuring a workflow to be suitable for a tenant environment in the multi-tenancy support environment. First, it is possible to support a single workflow instance to the multi-tenancy as if an exclusive workflow is allocated to each of the tenants. Second, a resource sharing/management is enabled at low cost and high efficiency as compared to an existing support method.
The foregoing summary is illustrative only and is not intended to be in any way limiting. In addition to the illustrative aspects, embodiments, and features described above, further aspects, embodiments, and features will become apparent by reference to the drawings and the following detailed description.
It should be understood that the appended drawings are not necessarily to scale, presenting a somewhat simplified representation of various features illustrative of the basic principles of the invention. The specific design features of the present invention as disclosed herein, including, for example, specific dimensions, orientations, locations, and shapes will be determined in part by the particular intended application and use environment.
In the figures, reference numbers refer to the same or equivalent parts of the present invention throughout the several figures of the drawing.
Hereinafter, exemplary embodiments of the present invention will be described in detail with reference to the accompanying drawings. Initially, when assigning reference numerals to constituent elements of drawings, like reference numerals refer to like elements throughout although they are illustrated in different drawings. Also, in describing the present invention, when it is determined that detailed description related to a known function or configuration they may make the purpose of the present invention unnecessarily ambiguous, the detailed description will be omitted. Also, exemplary embodiments of the present invention will be described, however, the technical spirit of the present invention is not limited thereto or restricted thereby and may be modified by those skilled in the art and thereby be variously implemented.
The workflow processing system 100 is a system for supporting the multi-tenancy and a system that configures an activity based workflow and manages metadata associated with an activity. In particular, the workflow processing system 100 is a system that configures a workflow and manages metadata in a software as a service (SaaS) environment of providing a software service to the multi-tenant online.
In the exemplary embodiment, the workflow processing system 100 is driven when tenants desire to share a single workflow.
The activity extractor 110 functions to extract at least one activity associated with a workflow for providing a software service. The activity extractor 110 extracts at least one activity that is selected from a control functioning activity, an allocation functioning activity, and a system interaction functioning activity.
The activity configuration unit 120 functions to configure an extracted activity based on a schema customized for a selected tenant.
The storage processing unit 130 functions to store a workflow that is an activity extraction target and the configured activity. The storage processing unit 130 may further store metadata that is used to associate the configured activity and the workflow that is the activity extraction target. The storage processing unit 130 may classify and thereby store each of the workflow that is the activity extraction target, the configured activity, and the metadata.
The main control unit 140 functions to control the overall operation of each of the components constituting the workflow processing system 100.
To support a single workflow instance to the multi-tenant, the workflow processing system 100 may further include a workflow editor 150 and a workflow executor 160.
When tenants request edition of the workflow, the workflow editor 150 functions to edit an edition requested workflow by overwriting a first activity, predetermined for each selected tenant, at a second activity location of the edition requested workflow. In the exemplary embodiment, the workflow editor 150 determines the first activity for each selected tenant based on metadata that is used to associate the configured activity and the workflow that is the activity extraction target. The workflow editor 150 determines the second activity associated with the first activity based on information about an identifier. The workflow editor 150 may perform activity serialization after overwriting but before completing the workflow edition.
The workflow executor 160 functions to execute an edited workflow for each tenant. Here, this function assumes that metadata exists. When the metadata does not exist, the workflow executor 160 functions to commonly execute an unedited workflow with respect to all tenants in which the metadata does not exist.
Meanwhile, the workflow processing system 100 may further include a workflow processing unit. The workflow processing unit functions to objectize the execution requested workflow.
The exemplary embodiment proposes a method of configuring a workflow to be suitable for a tenant environment in the multi-tenancy support environment, a method of managing a workflow activity as separate metadata so that activities of workflow may be configured to be suitable for a tenant when the multi-tenancy uses a single workflow instance, and the like. When different tenants using a single SaaS based service share, however, use different schemas (database tables) customized for each tenant, and desire to use a shared table, a workflow also requires a configuration to be suitable for a schema of each tenant. The exemplary embodiment proposes a method of configuring a single workflow instance when sharing the workflow instance by considering the above aspect. Hereinafter, an exemplary embodiment of the workflow processing system 100 will be described.
As described above, the workflow system 200 provides a method of configuring a workflow, defined based on an activity, for each tenant and a method of storing and managing a configured activity as metadata. When a user belonging to a tenant desires to use a workflow, it is possible to achieve the effect as if the user uses a workflow allocated to the tenant when executing the workflow by reconfiguring the workflow configured using metadata defined for the tenant, and at the same time, to achieve the effect of low cost and high efficiency since only a single workflow instance is managed.
When it is assumed that a workflow for obtaining or data-mining statistics about purchase information of the customer using a table of
Next, a workflow processing method of the workflow processing system 100 will be described.
Initially, at least one activity associated with a workflow for providing a software service is extracted (activity extraction operation S900). The activity extraction operation S900 extracts at least one activity that is selected from a control functioning activity, an allocation functioning activity, and a system interaction functioning activity.
Next, an extracted activity based on a schema customized for a selected tenant is configured (activity configuration operation S910).
Next, a workflow that is an activity extraction target and the configured activity is stored (storage processing operation S920). In the storage processing operation S920, metadata that is used to associate the configured activity and the workflow that is the activity extraction target may be further stored. Also, in the storage processing operation S920, each of the workflow that is the activity extraction target, the configured activity, and the metadata may be classified and thereby be stored.
In the exemplary embodiment, a workflow edition operation and a workflow execution operation may be performed after the storage processing operation S920.
The workflow edition operation is an operation of editing an edition requested workflow by overwriting a first activity, predetermined for each selected tenant, at a second activity location of the edition requested workflow when tenants request an edition of the workflow. In the workflow edition operation, the first activity may be determined for each selected tenant based on metadata that is used to associate the configured activity and the workflow that is the activity extraction target. Also, in the workflow edition operation, the second activity associated with the first activity based on information about an identifier may be determined. Meanwhile, in the workflow edition operation, the execution requested workflow may be edited by performing activity serialization after overwriting.
The workflow execution operation is an operation of executing an edited workflow for each tenant when metadata exists. On the contrary, when the metadata does not exist, an unedited workflow is commonly executed with respect to all tenants in which the metadata does not exist.
In the meantime, the workflow processing operation may be performed between the workflow edition operation and the workflow execution operation. The workflow processing operation is an operation of objectizing the execution requested workflow.
The present invention may be applied to a SaaS platform development for providing a software service.
As described above, the exemplary embodiments have been described and illustrated in the drawings and the specification. The exemplary embodiments were chosen and described in order to explain certain principles of the invention and their practical application, to thereby enable others skilled in the art to make and utilize various exemplary embodiments of the present invention, as well as various alternatives and modifications thereof. As is evident from the foregoing description, certain aspects of the present invention are not limited by the particular details of the examples illustrated herein, and it is therefore contemplated that other modifications and applications, or equivalents thereof, will occur to those skilled in the art. Many changes, modifications, variations and other uses and applications of the present construction will, however, become apparent to those skilled in the art after considering the specification and the accompanying drawings. All such changes, modifications, variations and other uses and applications which do not depart from the spirit and scope of the invention are deemed to be covered by the invention which is limited only by the claims which follow.
Number | Date | Country | Kind |
---|---|---|---|
10-2010-0129530 | Dec 2010 | KR | national |