Service Oriented Architecture and WCF 【转】
http://www.codeproject.com/Articles/515253/Service-Oriented-Architecture-and-WCF
Introduction
This article will not talk about how to create and host a WCF service rather we stress on importance of SOA and WCF.
If
you are a advanced WCF developer then article is not for you, if you
are one who is trying to learn WCF then article is not for you, this is
for them who is completely new to WCF and trying to understand why WCF
is there.
Index
- Evolution of SOA
- Architecture Terminologies
- What is SOA?
- Characteristics of SOA
- WCF and Web services
- Conclusion
Evolution of SOA

Evolution is the nature’s law. Just like Human beings
who evolved from Primate to Modern age Humans just to adapt the moving
environment and competitions, Programing style or we can say technique
also evolved to overcome the challenges in the changing programming
world.
Procedural Programming
Initially programmers used this approach for developing applications where Functions were everything.
In this approach Functionalities will be
encapsulated inside one or more functions, which can call each other,
pass some parameters and get some return value. Here one of the
functions will be made as entry point (like in C programming we had main
method).
Why it need to be evolved.
The biggest challenges with this approach were,
- How to reuse the same code?
- Difficulties in code Management.
Object oriented Programming
To overcome the problems in the Procedural
programming, object oriented era comes into the picture where people
start talking in terms of objects and classes.
Everything is treated and considered as real world objects created from
the blue print that is class.
Lots of Object oriented principles like Abstraction,
Encapsulation, Inheritance, polymorphism and solid has been introduced
are introduced in this era.
Why it need to be evolved.
OOP increased the reusability and thus improved the
code management. But one thing which was not addressed here was how two
or more applications will communicate each other,
especially when they have been written using different
languages or technologies.
For instance inventory module which is written using Java
will not be able to call function inside classes of accounting module
written in .NET.
Service oriented Programming
We have progressed from functions, to objects and now to services.
In SOA functions and tasks are created as loosely connected independent services communicating via messages.
Service provider publishes the service via standard interfaces in a publicly accessible directory called
Service Repository and Service consumer make a service request and in response gets the Service Response.

Architecture Terminologies
Before we go in depth and talk about SOA (Service
oriented architecture), it’s must to understand some terminologies
related to architecture.
Patterns
In simple words Pattern is a solution to a problem in a context.
Architectural Style
When we say architectural style, it’s a very high
level thing, it’s a concept. It’s up to us how we take this and
implement. For example REST is an architectural style which tells us how
we can use standard web features in effective way. It’s not standard or
specification, in a style which we can understand and design web
services in that style. In my perspective n-Tier is also an
architectural style, it says divide your systems into different tiers
but middle tier may be anything, and developer can make it a simple
class library or a WCF service. In face the value of ‘n’ is also not
sure.
Architectural Patterns
Architectural Pattern is something which solves our
problem at sub system level or in short module level. It deals with the
problem related to architecture of a project. We make Class libraries,
Components, Web services to solve the problem. For example - In MVC we
break the application into Model, View and Controller. Here we know how
View interacts with model and so on.
Design Patterns
Design pattern talk about problems at class or function level.
What is SOA?
SOA or Service oriented architecture is an
architecture style for building business applications by means of
services. Application comprises collection of services which communicate
through messages.
Service
- Services are logical encapsulation of self-contained business functionality
- Every Service encapsulates one action such as Register User, Send Email etc.
Messages
Services communicate with each other using messages.
Messages are standard formats which everyone (every service) can read
and understand.
Characteristics of SOA
- In SOA, Services should be independent of other services.
Altering a service should not affect calling service. - Services should be self-contained.
When we talk about a RegisterCusomer service it
means, service will do all the necessary work for us, we are not
required to care about anything. - Services should be able to define themselves.
Services should be able to answer a question
what is does? It should be able to tell client what all operations it
does, what all data types it uses and what kind of responses it will
return. - Services should be published into a location (directory) where anyone can search for it.
- As I said, SOA comprises of collection services which communicate via standard Messages.
Standard messages make them platform independent.
(Here standard doesn’t mean standard across
Microsoft it means across all programming languages and technologies.) - Services should be able to communicate with each other asynchronously.
- Services should support reliable messaging.
Means there should be a guarantee that request
will be reached to correct destination and correct response will be
obtained. - Services should support secure communication.
WCF and Web services
WCF is a Microsoft framework for building Service-Oriented applications.
Comparing Web services with WCF will not be a good
idea. Can you compare yourself with yourself in past(let's say two year
before)? Obviously in two year you might have learned new things,
improved somewhat,right? WCF and Web service are related to each other
in same manner. WCF has evolved from Web services and so WCF can do all
which a web services is capable of, plus can do some more.
Features of WCF
- WCF hosting - If we are working
with web services then only option we are having is hosting it inside
web server such as IIS using http or wshttp protocols. But WCF supports
four types of hosting- IIS
- WAS (Windows process activation services)
- Self-hosting
- Windows services
Read more about WCF hosting at
http://msdn.microsoft.com/en-us/library/bb332338.aspx - Message transmission - Messages
can be transmitted between clients and service via various transport
protocols and encodings such as SOAP using http and binary data using
TCP. - Serialization - Web services uses XmlSerializer for transferring data between service calls whereas WCF supports multiple serializers
- DataContractSerializer(faster and supports versioning)
- NetDataContractSerializer(when it required to include CLR type information in the serialized XML)
- XmlSerializes(mostly to support backward compatibility).
- Multiple technologies at one place - WCF unites following four technologies
- .NET remoting
- MSMQ
- Web Services
- COM+
- Message Contract - In Web
services customizing the headers of the SOAP message was a tedious task.
For that we were supposed to derive a class from SoapHeader and then
SoapHeaderAttribute is used to indicate the presence of the header.
But with WCF we can make it easily with the help
of simple attributes like MessageContractAttribute,
MessageHeaderAttribute, and MessageBodyMemberAttribute. - Multiple Message Patterns - WCF supports three message patterns that describe how client and service pass messages
- Request-Reply Pattern – Client sends message to service and waits for reply.
- One-Way Message Pattern – Client sends message to service but service does not reply message to client.
- Duplex pattern – Both client and the
service can initiate communication. The client calls a method of the
service. The service can then use a client callback to call a method in
the client.
- Security - In WCF security can be implemented with the help of well-known standards such as SSL.
- Reliable - WCF supports reliable messages with the help of Queues and reliable sessions.
- REST - WCF can be extended to
support plain xml data that is not wrapped in a soap envelope, xml
formats such as ATOM and non xml standard such as JSON. - WCF Transaction - - WCF
supports to create distributed transactions for your service
application. Transaction is a collection of logical operations which
need to be run as a single logical unit.
(Either all operations will successfully execute
and completes or in case any of them fail others will rollback). - WCF instancing - In WCF we can
control the way WCF service objects are instantiated in the WCF server.
WCF Framework comes up with following instancing models- Per Call - A new instance will be created for every client request.
- Per session - A new instance is created for each new client session and maintained for the lifetime of that session.
- Single - A single instance handles all client requests for the lifetime of the application.
- WCF Concurrency - With WCF
Concurrency features we can control how service instances can serve
multiple requests at the same time. We have three choices- Single – Only one request will be served at a time.
- Multiple - Multiple requests can be handled by the WCF service object at any given moment of time.
- Reentrant - A single request thread has
access to the WCF service object, but the thread can exit the WCF
service to call another WCF service or can also call a WCF client through
callback and reenter without deadlock.
What is ABC in WCF
We had gone through the feature of WCF and
understood why its termed as advanced version of web services. Now it’s
time to answer a very basic question related to WCF i.e., what is ABC of
WCF?
When we say WCF, we came across end points. Service
endpoint can be a part of continuously hosted service hosted in IIS or
service hosted in an application.
ABC or Address, Binding and Contract are the three elements which constitutes and Service Endpoint.
- Address - Where Service is residing (URL of the service.)
- Binding – How to talk to the service?
- Contract – What can the service do for me?
Example – basicHttpBinding, wsHttpBinding, webHttpBinding etc.
Conclusion
We have understood
- What is Service oriented architecture?
- Why SOA required?
- What are the characteristics of SOA?
- How WCF can be differentiated from Web service?
- What are the characteristics of WCF?
- What is mean by ABC of WCF?
Service Oriented Architecture and WCF 【转】的更多相关文章
- Service Oriented Architecture
What is Service Oriented Architecture (SOA)? There have been so many interpretations of this through ...
- SOA (面向服务的架构)-Service Oriented Architecture
SOA (面向服务的架构) 编辑 面向服务的架构(SOA)是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来.接口是采用中立的方式进行定义的,它应该独立 ...
- service oriented architecture 构造分布式计算的应用程序的方法 面向服务的架构 分解技术
zh.wikipedia.org/wiki/面向服务的架构 [程序功能做为服务] 面向服务的体系结构(英语:service-oriented architecture)是构造分布式計算的应用程序的方法 ...
- The service ‘xxx’ configured for WCF is not registered with the Autofac container
最近在使用autofac.wcf时,报如下异常: Exception Details: System.InvalidOperationException: The service 'xxx' conf ...
- 重温WCF之构建一个简单的WCF(一)(2)通过Windows Service寄宿服务和WCF中实现操作重载
参考地址:http://www.cnblogs.com/zhili/p/4039111.html 一.如何在Windows Services中寄宿WCF服务 第一步:创建Windows 服务项目,具体 ...
- Web Service \restful web services\WCF Service\ServiceStack
http://www.cnblogs.com/jfzhu/p/4025448.html http://www.cnblogs.com/jfzhu/p/4022139.html#3043243
- SOA相关资料整理分享
昨@幸福框架同学问能否推荐SOA一些资,.想想之前看过不少资料文档,就整理分享下,有需要的可以参考下. 文章链接 理解面向服务的体系结构中企业服务总线场景和解决方案,第 1 部分 SOA 和 web ...
- SOA一些资料
SOA相关资料整理分享 2015-03-26 16:16 by 蘑菇先生, 693 阅读, 9 评论, 收藏, 编辑 昨@幸福框架同学问能否推荐SOA一些资料.想想之前看过不少资料文档,就整理分享下. ...
- WCF Windows Service Using TopShelf and ServiceModelEx z
http://lourenco.co.za/blog/2013/08/wcf-windows-service-using-topshelf-and-servicemodelex/ There are ...
随机推荐
- javascript格式化指定的日期对象
/* * 格式化Date对象为:“2015-04-17 10:20:00” * var dateObj = new Date(); */ function formartDate(dateObj){ ...
- 尝试设计LFSR加密器,并用CAP4验证随机性
在CPA4软件中有提供设计LFSR加密器的功能: 输入LFSR的大小,初始密钥,还有反馈密钥. 点击Set Key后点击Show LFSR 观察LFSR,发现初始密钥是1101,转成十六进制是D,反馈 ...
- windows phone 扫描二维码
在网上找了找扫描二维码的例子,利用ZXing库实现(下载),提供的Silverlight版本的下载,在网上搜了一下已经有wp的dll可用了,不过网上实现的条码扫描的例子还都是用的Silverlight ...
- MySql中常用语句
1.查询语句: SELECT 查询字段 FROM 表名 WHERE 条件 查询字段可以使用 通配符* 字段名 别名(把长的名字命名一个别名,比较短的) 通配符:SELECT * FROM ' ...
- Android自定义图片加载框架
大神原网址: http://blog.csdn.net/lmj623565791/article/details/41874561 思路: 1. 压缩图片 压缩本地图片: 获得imageview想要 ...
- Python Tips and Traps(二)
6.collections 模块还提供有OrderedDict,用于获取有序字典 import collections d = {'b':3, 'a':1,'x':4 ,'z':2} dd = col ...
- “父窗口拖动的时候Popup不随着父窗口移动”问题的解决方案
我们用WPF用的Popup时候会发现,当 StaysOpen=True 的时候,因为Popup不会消失,在父窗口移走的时候Popup仍旧在原地...作者在国外网站上无意间发现了这个解决方案,拿出来给大 ...
- C#中的委托用法
当一个函数有返回值的时候用,用Func委托方法. 例如: static int sum(int x) { return x+x; } Func<int> a = sum; 当一个函数没有返 ...
- [简历] PHP 技能关键字列表
本技能关键字列表是从最近招聘PHP的数百份JD中统计出来的,括号中是出现的词频.如果你的简历要投递给有机器(简历分选系统)和不如机器(不懂技术的HR)筛选简历环节的地方,请一定从下边高频关键词中选择5 ...
- MOS管应用之放反接电路
一.典型电路 1.电路1 说明: GND-IN 为电源接口的负极 GND 为内部电路的公共地 原理分析 正向接: VCC-IN通过R1.R2.MOS体二极管,最后回到GND-IN;然后GS电压升高,紧 ...