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 ...
随机推荐
- redis 在windows上运行
参考自:https://github.com/ServiceStack/redis-windows 1.用vagrant 运行redis的最后版本 1.1在windows上安装vagrant http ...
- struts1、 struts2所有版本jar包下载地址大全
jakarta-struts-1.2.2.tar.gz 30-Aug-2004 18:21 12M jakarta-struts-1.2.2.tar.gz.asc 30-Aug-2 ...
- Demo_张仕传_结构体考试-modify
/* 题目: //声明一个结构体类型 struct _AdvTeacher { char *name; char *tile; int age; char *addr; char *p1; //系统预 ...
- 将数据库二进制图片导出显示到EPPlus Excel2007中
1.EPPlus Excel 控件可以参考我的另一篇博客:http://blog.163.com/pei_huiping/blog/static/206573067201281810549984/ 这 ...
- php 验证码生成方法 及使用
基本思路是: 在生成图片的页面中(as: yzm.php)1.设置生成的图片的宽度和高度:2.设置图片要写入的字符:3.截取显示在图片上的字符;4.开启session,把上面截取的字符存放在sessi ...
- datareader 和dataset 区别
ADO.NET2.0提供了两个用于检索关系数据的对象:DataSet和DataReader.并且这两个对象都可以将检索的关系数据存储在内存中.在软件开发过程中经常用到这两个控件,由于这两个控件在使用和 ...
- Python使用re实现计算器
re 正则表达式 计算器 海瑞博客-学习python之路•2016-12-01•Python• 59•0•A+ A- re是一门小型语言 元字符 . 通配符除了\n ^ 以什么开始的 ...
- 使用ajax传递及接收数据
前端代码: <input id="txtNum1" name="txtNum1" type="text" width="13 ...
- KVO - 键值观察
[基本概念] 键值观察是一种使对象获取其他对象的特定属性变化的通知机制.控制器层的绑定技术就是严重依赖键值观察获得模型层和控制器层的变化通知的.对于不依赖控制器层类的应用程序,键值观察提供了一种简化的 ...
- bzoj 1761: [Baltic2009]beetle 区间dp
1761: [Baltic2009]beetle Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 255 Solved: 92[Submit][Statu ...