To add some mud into the water…
Many Bus architectures do “enrichment” of messages
between consumer and producer, including the invocation of other services to
perform that enrichment (e.g stock quote returns current price, enrichment
provides the last ten days closing price). They may also do calculations
that result in the non-connection or “empty” return from the service
(e.g. if you call for “last five minutes trades” after the market
has closed… its an empty set). So while I agree that the service
consumer is key it’s sometimes hard to identify the true consumer and the
true producer of a service within a virtualised bus.
From: McGregor.Wesley@tbs-sct.gc.ca
[mailto:McGregor.Wesley@tbs-sct.gc.ca]
Sent: 06 December 2005 19:09
To: klaskey@mitre.org; marchadr@wellsfargo.com; dnickull@adobe.com;
goran.zugic@semantion.com; mattm@adobe.com; tmathews@lmi.org;
sallystamand@yahoo.com; frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
The service consumer is the key concept that indicates the entity
that invoked the service in the first place.
A brokering service or service actor is merely a middle-man.
-----Original Message-----
From: Ken Laskey [mailto:klaskey@mitre.org]
Sent: December 6, 2005 2:02 PM
To: marchadr@wellsfargo.com; dnickull@adobe.com;
goran.zugic@semantion.com; mattm@adobe.com; tmathews@lmi.org;
sallystamand@yahoo.com; frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
I could argue that a broker consumes the service on someone else's
behalf. In reality, service actor seems too nondescriptive because either
the consumer or the provider can be thought of as an actor.
At 01:45 PM 12/6/2005, marchadr@wellsfargo.com wrote:
I hate to stir things up a bit, but can you change the service
consumer term to service actor?
Since in the case of brokering the service actor is not consuming
but brokering a request to another service.
The broker service can be a service actor upon the service but
might not really consume any part of the service since it is a pass through.
But I guess this is a matter of opinion.
-----Original Message-----
From: Ken Laskey [ mailto:klaskey@mitre.org]
Sent: Tuesday, December 06, 2005 10:39 AM
To: Duane Nickull; Goran Zugic; Matt MacKenzie; MATHEWS, Tim; Sally
St. Amand; frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
I think we need to add some words to the RM to capture this
discussion. We cover part of this in the beginning of Section 3.2.1 but
need to be more specific that:
- a service consumer can be a human or a software agent;
- a service consumer can invoke any number of services (including a
single service in isolation) and can chain the output of some services to act
as the input of others;
- from the perspective of a given service, the occurrence of such
chaining would not be visible;
- the service consumer can be implementing a business process;
- the specific of a business process do not change the basic SOA
concepts as described in the RM; however, the specific architecture that one
designs and implements will reflect the business process and make use of
specific service instances that corresponds to the real world effects that the
business process hopes to realize.
Now that said, and in full appreciation that we agreed earlier that
mechanisms which combine services (e.g. choreography, orchestration) are out of
scope, is it sufficient for words, such as those suggested above, to be
included somewhere within the current discussion or do we need to pull it out
into a subsection on its own? As an example of the former, we tried to
deal with loose-coupling and coarse-grained with words at the end of Section
2.1.
At 12:23 PM 12/6/2005, Duane Nickull wrote:
I slightly disagree with your assertions, probably based on
semantics. For a service to "participate" in a process, it
would have to be aware of the process (which many will not be). A better
way to depict this may be to state "services may be aggregated and used by
processes" and "processes may be represented/exposed as
services". There are really no limits to the number of layers that
can be present. Attached is a UML CVD depicting such.
A key rationale of why process is not part of SOA is that services
cannot see process. They are not aware of whether they are being called
as part of a process vs. as an individual service. If the "s"
part of SOA cannot see or touch that, it cannot be part of the RM.
The chicken and egg discussion you bring forward is a requirement
for those building services to strongly consider the business process when
designing their service infrastructure. Accordingly, it is not really
part of the RM for SOA yet I agree that it is a very important consideration.
For your messages to get to the list, you must join as a
"applicant" rather than an "observer" as per OASIS process.
*******************************
Adobe Systems, Inc. - http://www.adobe.com
Vice Chair -
UN/CEFACT http://www.uncefact.org/
Chair - OASIS SOA Reference Model Technical Committee
Personal Blog - http://technoracle.blogspot.com/
*******************************
From: Goran Zugic [ mailto:goran.zugic@semantion.com]
Sent: Monday, December 05, 2005 8:47 PM
To: Duane Nickull; Matt MacKenzie; MATHEWS, Tim; Sally St. Amand;
frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: Re: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
Thanks for the response. Yes I would like to see the PPT. I hope
you do not mind if I add few more thoughts related to services and business
processes:
Services participate in a business process to add some value to it.
They can be governed and evaluated using business process metrics. One service
can participate in many business processes and provide value to each of them
according to the context within that process. As far as SOA is concerned it is
as important to know what the service does, how it can be discovered,
contacted, invoked, executed, etc. as it is to be able to use it within the
process context, measure it and assess its value from the business process
requirements point of view. SOA needs to avoid typical new technology chicken
and egg syndrome, e.g. companies not producing services because there are no
service friendly process definitions to use them and not having SOA friendly
process definitions because there are no services to use. Services do not have
to know if they will be involved in the process upfront, they will be contacted
on demand according to the process script that is in effect, and they will be
contacted, checked if available, passed the arguments, collected the response
and according to their procedure left alone to wait for another call. The
process execution engine however needs to invoke the service according to both
service specific information and the process specific information.
Having just the service specific information in a model covers only
one part of the picture and I think it is fine as long as that model is a pure
service model. However I find it difficult to understand that the SOA RM TC
model is a SOA reference model when it does not include other concepts of SOA.
Unfortunately it seems that we cannot get to the point where we could agree on
a minimal set of supported SOA concepts by a model to be the SOA RM. We do not have to and I do not want to argue with you or anybody else in SOA RM
TC. I am just trying to see how our works can fit together in a most efficient
way. We obviously need more time to better understand each others thoughts and
ideas and I strongly believe that a constructive respectable discussion is
helpful for everybody.
By the way, do you know what I am supposed to do to get my messages
to the SOA RM list. In spite of that I am the SOA RM TC observer I get a
faliure notice whenever I send a note to the SOA RM.
----- Original Message -----
To: Matt MacKenzie ; goran.zugic@semantion.com ; MATHEWS, Tim ;
Sally St. Amand ; frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Sent: Monday, December 05, 2005 5:02 PM
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
The service layer enables the process layer over top of it, however
during runtime, services do not know if they are part of a process or being
called individually (it would generally be a bad idea to try to maintain the
overall state of a process within each service, although it could be
done). For maximum repurposing of services, it would be better to have
the service as a simple slave to the processes that may use it.
Accordingly, we made a decision that BPM, Orchestration,
choreography is not a core part of the RM for SOA. We generally seem to
agree that many SOA implementations will include a layer of BPM over top.
We are only addressing the SOA model, not the model for the underlying or
overarching layers.
I have a PPT that explains this in more detail if you are
interested.
*******************************
Adobe Systems, Inc. - http://www.adobe.com
Vice Chair -
UN/CEFACT http://www.uncefact.org/
Chair - OASIS SOA Reference Model Technical Committee
Personal Blog - http://technoracle.blogspot.com/
*******************************
From: Matt MacKenzie [ mailto:mattm@adobe.com]
Sent: Monday, December 05, 2005 12:51 PM
To: goran.zugic@semantion.com; MATHEWS, Tim; Sally St. Amand;
frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
Process orientation is only one of multiple potential integration
with service oriented architecture. SOA-RM is laying the foundation for
durable architecture based on the core concept of service orientation. We
recognize that process oriented architecture is a natural fit with service
orientation...but so are things like event orientation.
From: goran.zugic@semantion.com [ mailto:goran.zugic@semantion.com]
Sent: Monday, December 05, 2005 3:36 PM
To: MATHEWS, Tim; Matt MacKenzie; Sally St. Amand;
frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: Re: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better
I think that SOA RM has done good job documenting well-known
service related concepts and defining some new ones.
I do not see other details besides service and service-related
concept definitions in the current SOA RM committee draft right now. I look
forward to seeing the completion of the model you are working on with the
bottom-up approach.
Business, business processes and collaboration aspects of business
are important to address in the model what is not the case with the current
content of the SOA RM committee draft. By a business process I mean a generic
business process entity which has common components (activities, decisions,
etc) and relationships between them that can be used to model a business
process in any environment regardless of what business we support and
technology we use. I agree with Sally that a link between business processes
and services should be one of key requirements any SOA reference model should
try to meet.
I am not sure what SOA with services brings to business when the
link between the business processes and services and overall business process
semantics in the SOA context are not considered to be important aspects in a
SOA-based reference model.
-----Original Message-----
From: MATHEWS, Tim [ mailto:tmathews@lmi.org]
Sent: Monday, December 5, 2005 12:34 PM
To: 'Matt MacKenzie', 'Sally St. Amand',
frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better "Componentization"
Matt - I am not sure what point you are trying to make by
this? I agree with your premise of a bottom up effort, as this was one of
the operating assumptions that was made from the beginning.
But, I am confident it is the business environment that is
independent from the reference model.
From: Matt MacKenzie [ mailto:mattm@adobe.com]
Sent: Monday, December 05, 2005 11:58 AM
To: Sally St. Amand; frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: RE: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better "Componentization"
A reference model actually needs to be a bottom up effort. We
leave the ever so popular ?top-down? approach to folks like ebSOA J
We?re creating a vocabulary and general understanding of what I
hope we can call a discipline of computer science in the future. This
means, we need a durable reference model that is not dependent on the current
business environment.
From: Sally St. Amand [ mailto:sallystamand@yahoo.com]
Sent: Monday, December 05, 2005 10:19 AM
To: frank.mccabe@us.fujitsu.com
Cc: soa-rm@lists.oasis-open.org
Subject: Re: [soa-rm] Proposal: Reorganization of SOA-RM Draft for
Better "Componentization"
This is in response to your request on last week?s conference call,
if anyone has comments speak now. I also think that the recent comments on
clarifying sections are a reflection of my issues with the specification.
I agree with the majority of points made/described in ver 10. My
issues are with what is not in this draft. Based on Fig 1 the Refe! rence Model
is guided by Reference Architectures, Concrete Architectures, Profile &
Related Models. They in turn account for requirements, motivation & goals.
This is creating a Reference Model from the bottom up. I believe a Reference
Model should reflect a top down approach.
The Reference Model needs to reflect the environment, the strategy
and the priorities of the business/mission/collaboration. This will
impact the construction of services. A service is a business task or activity
that is realized through technology. The draft does a good job of describing
how that realization happens. But it doesn?t provide a sufficient link between
processes and services. The draft makes the point that the central focus of!
SOA is the task of business function?getting something done. A business process
is made up of tasks and activities to achieve a goal (getting something done).
The concept of creating the service from the tasks and activities in a process
is important. For example, where on the continuum of fine grained to coarse
grained should a particular service be; this will affect interaction,
reusability. The relationship between processes and services needs to be in the
Reference Model.
While I saw that there is a note saying the glossary is still in
flux, since one of the objective of the Reference Model is a vocabulary, having
less in the glossary might be a better option. Is semantic integration a
guiding principle of SOA?
With respect to conformance there needs to be business results.
That is an SOA should provide demonstrable mission accomplishments, e.g. ROI,
match a competitors distribution channel. SOA is not a technology. Conformance
should provide operational accomplishments, these should be measurable.