can be executed several times. Each execution is
known as process instance. Events collected during
system execution must be correlated into the correct
instance.
This paper presents a technique to obtain event
logs from traditional systems, paying special
attention to the event correlation improvement
regarding previous work. The technique consists of
three stages. Firstly, the technique records events
from the execution of traditional systems. During
this stage the technique allows experts to identify
candidate correlation attributes, whose runtime
values will then be collected together with each
event. As a result, events and their respective
attributes are then stored in a database in an
intermediate format (cf. Section 3.1). Secondly, the
algorithm proposed by (Motahari-Nezhad et al.,
2011) is adapted and applied with the event datasets
so to discover the most appropriate set of attributes
and conditions for the events correlation (cf. Section
3.2). Finally, the third stage applies an algorithm
based on the correlation set in order to correlate each
event with its corresponding process instance (cf.
Section 3.3). As a result, a standard-format event log
is obtained from the source traditional system.
Figure 1: Event correlation overview.
3.1 Event Collection
The event collection stage is in charge of the suitable
generation and storage of events throughout system
execution. Since traditional information systems do
not have any in-built mechanism to record events
about executed business processes, this stage
instruments information systems to record events.
The instrumentation is semi-automated by a parser
that syntactically analyzes the source code and
injects statements in particular places of the code to
record events during system execution.
This work follows the ‘a callable unit / a
business activity’ approach proposed by Zou et al.
(Zou and Hung, 2006). Callable units are the generic
elements (e.g., Java methods, C or COBOL
procedures, etc.) in which the parser injects
statements to record an event corresponding to the
execution of a business activity. Despite this fact,
not all the executions of callable units have to be
recorded as events. Some callable units such as fine-
grained or technical callable units do not correspond
to events and must be discarded. The injection in the
exact place is consequently supported by some
information provided by experts. Such experts (i)
delimit business processes with the start and end
callable units of each process; (ii) establish the
boundaries of non-technical source code to be
instrumented; and finally, (iii) they identify those
code elements that can be treated as candidate
correlation attributes.
This stage is supported by an improved version
of the tool presented in (Pérez-Castillo et al., 2011),
which supports the identification and addition of
candidate correlation attributes. Selection of
candidate correlation attributes is a key task, since
an incomplete list of candidate attributes may lead to
a non-suitable correlation. This stage provides
experts with all the possible selectable attributes.
These attributes are every parameter appearing in
callable units as well as the output and fine-grained
callable units that are invoked within those callable
units, which are considered to be collected as events.
The information about candidate correlation
attributes is injected together with a statement
enabling event collection.
Figure 2: Example of code instrumentation.
Figure 2 provides an example of the results
obtained after instrumenting a Java method of the
system under study (cf. Section 4). The two tracing
statements (see highlighted statements) are injected
at the beginning and at the end of the body of the
method. Those candidate correlation attributes that
are present in a method (e.g., a parameter or
variable) are automatically injected in the tracing
statements, i.e., the respective variables are in the set
of parameters of the invocation to the method
‘writeDBEvent’ (see Figure 2). However, not all
correlation attributes defined by experts are present
in all methods (e.g., due to the absence of a
particular variable). In this case, the respective
EVENTS
PROCESS
INSTANCE
PROCESS
A D
B
C
A D C
A DB
A
D
A
C
D
D
A
B
C
B
A
B
D
B
C
B
C
public class SocioFacadeDelegate
[...]
public static void saveAuthor(AuthorVO author) throws InternalErrorException {
writeDBEvent("SocioFacadeDelegate.saveAuthor", "Author Management", "", "start",
false, false, -1, false, 2, 8, "", "" + author.getId(), "" + author.isHistorico(),
"" + author.getNumeroSocio(), "", "" + author.getCotas());
try {
SaveAuthorAction action = new SaveAuthorAction(author);
PlainActionProcessor.process(getPrivateDataSource(), action);
} catch (InternalErrorException e) {
throw e;
} catch (Exception e) {
throw new InternalErrorException(e);
}
writeDBEvent("SocioFacadeDelegate.saveAuthor", "Author Management", "", "complete",
false, true, -1, false, 2, 8, "", "" + author.getId(), "" + author.isHistorico(),
"" + author.getNumeroSocio(), "", "" + author.getCotas());
}
[...]
ImprovingEventCorrelationforNon-processAwareInformationSystems
35