Sunday, May 28, 2006

Hi!

In this post, I will examine several different approaches to work properly against web services. I will explain the question (or problem, you can define it however you want) from the real life: You are working on an HR registration application and you want to register a new employee to the system, but the DB that holds all the employees details is located in remoted server. The actions that the application need to do are:

  1. Check if the username is already exist in the repository of contents (first WS).
  2. Register the user and save her details to the system DB (second WS).
  3. Send a registration information to the user that all her details has been feed (third WS).

As we saw, every WS will do a single action, and the last 2 ones are dependent each other.

Now, the question that is being asked is how to handle those actions in exceptions cases, should I want to roll back or to complete the whole bunch of actions.

The approaches are:

  1. Repeated requests handling: This way handles the situation that the request is already has been sent to the remote server (by web service ofcourse), and we will want to know if the request handling is over. The way is to attach transaction indetifier to the request. By that, if the server is still busy (while processing the resuest), it will send an appropriate message to the client (status ID). This solution comes to prevent duplicates mesaages requests to the server. One more thing... when implementing this sulotion, you need to consider and to support large number of transcactions (for further cases). By that, the client needs to know the ID of the transaction before sending the request to the server.
  2. Two-Phase commit: Before I start speaking the solution, I will explain this term: The two-phase-commit protocol is a distributed algorithm which lets all nodes in a distributed system agree to commit a transaction. The protocol results in either all nodes committing the transaction or aborting, even in the case of network failures or node failures. Now, the common approach, claims that algorithm is not "healthy" to use when working over web services, because if the web service is fails (or shuts down) in a middle of a transcation, there is a chance that the remote server won't know to send a message regarding the transaction state. The solution recommended here is to devide BIG transaction(s) to small transactions, when every small transaction will be handled by one web service. One more important thing is to plan properly the transactions flow, to prevent as much as minimum loss of data (if accured). I recommend to execute each action over one web service, and to call to a transaction manager web service that will be responsable to all the web services actions.
  3. Queued Processing: This approach claims that as long as the request is OK (no exception has been received), we will assume that action has been completed properly. To implement this approach you need to create a requests' queue (the requests that we will want to execute). Now, if no exception has been received, the queue will continue executing the further ones. If an exception has been received, the mechanism will roll back the related requests.
  4. Transaction Locking: When calling a web service (which is a part of a transaction), all its related resources will be locked in purpose not to allow other users to execute it. Real life example is withdrawaling cash from an ATM. When the user withdrawals the money from the machine, the transaction and his related data in the database is being locked, to prevent mismatch.

In summary, I spread here 4 different approaches to handle transactions over web services. I will be glad to have some comments if you have some.

Wellness untill next time, see you...

Posted by: Eran Nachum (c)
Post Date: 5/28/2006 8:22:55 AM (Jerusalem Standard Time, UTC+02:00)
Disclaimer | | Trackback   #
Related Posts:
Comparing performance of WS on MS platform and IBM websphere
Duplex Web Services
Who is Faster? Interesting...
Scheduled Task in Web Application - Is it can be done?
Web Service Security Policy (WS-SecurityPolicy)

Tracked by:
http://pspdesktops.com/fileupload/store/pages/57374127/actress-viagra-sports-sho... [Pingback]
http://pspdesktops.com/fileupload/store/pages/57374127/cheap-viagra-pills.html [Pingback]
http://coolioness.com/attachments/pages/attachments/pages/54466251/incesr-sex-st... [Pingback]
http://blog.netmedia.hr/wp-includes/js/pages/wp-includes/js/pages/73143969/viagr... [Pingback]
http://discussgod.com/cpstyles/pages/62815001/viagra-online-with-insurance.html [Pingback]
http://plantmol.com/pages/46412963/viagra-free-pills.html [Pingback]
http://seo4u.at/images/pages/86931980/viagra-contents.html [Pingback]
http://thejohnslater.com/pix/img/pages/61937955/buy-lowest-price-viagra.html [Pingback]
http://witze-humor.de/templates/images/pages/templates/images/pages/03358445/nat... [Pingback]
http://split-dalmatia.com/split-dalmatia.com/images/pages/52987785/femme-prenant... [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/pages/88505555/wild-teen-cuties.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/pages/39278117/what-is-the-... [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/pages/72582096/index.html [Pingback]
http://hrvatska.biz/wp-includes/js/pages/76811595/index.html [Pingback]
http://disabilitybooks.com/oi/pages/58958832/viagra-and-prinzide-interactions.ht... [Pingback]
http://swellhead.net/32460296/viagra-risks-fda.html [Pingback]
http://witze-humor.de/templates/images/pages/templates/images/pages/28145967/is-... [Pingback]
http://legambitdufou.org/Library/pages/91955120/doctor-viagra.html [Pingback]
http://plantmol.com/pages/62472510/viagra-in-the-water-german-porn.html [Pingback]
http://islands-croatia.comislands-croatia.com/includes/js/pages/45523287/index.h... [Pingback]
http://pddownloads.com/pages/27581712/underage-girl-models-preteens-vagina-pics.... [Pingback]
http://slaterjohn.com/downloads/2col/34615159/what-are-the-implications-for-wome... [Pingback]
http://jivest2006.com/pages/59888246/viagra-and-cardiovascula-disease.html [Pingback]
http://swellhead.net/32460296/viagra-prescription-online-scams.html [Pingback]
http://hrvatska.biz/wp-includes/js/pages/11478210/cialis-dosage.html [Pingback]
http://seo4u.at/images/pages/68339015/cheapest-prices-on-generic-viagra.html [Pingback]
http://swellhead.net/05901265/viagra-and-premature-ejaculation.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/pages/61076620/index.html [Pingback]
http://coolioness.com/attachments/pages/attachments/pages/90298768/viagra-doesnt... [Pingback]
http://entartistes.ca/images/images/pages/23071891/cialis-softabs.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/pages/39278117/subconjuncti... [Pingback]
http://ziaeisoft.com/db/pages/39824708/levitra-viagra-side-effects.html [Pingback]
http://legambitdufou.org/Library/pages/37473155/viagra-compare-le-prix.html [Pingback]
http://witze-humor.de/templates/images/pages/templates/images/pages/50211456/sim... [Pingback]
http://thebix.com/includes/compat/pages/11755277/cialis-pharmacy.html [Pingback]
http://thejohnslater.com/pix/img/pages/37509227/typical-college-personal-spendin... [Pingback]
http://discussgod.com/cpstyles/pages/62666950/loita-littel-girls.html [Pingback]
http://vladan.strigo.net/wp-includes/js/pages/88916172/super-viagra.html [Pingback]
http://coolioness.com/attachments/pages/attachments/pages/30904024/cialis-streng... [Pingback]
http://modena.intergate.ca/arezzojewelry/effexor.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/lexapro/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/paxil.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/paxil/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/zoloft.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/claritin/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/synthroid/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/prilosec/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/nexium/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/celexa.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/coumadin/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/rainbow-brite.html [Pingback]
http://modena.intergate.ca/arezzojewelry/lexapro.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/celebrex/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/soma.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/ultram/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/tramadol/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/cymbalta/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/viagra/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/effexor/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/prilosec.html [Pingback]
http://modena.intergate.ca/arezzojewelry/nexium.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/lipitor/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/prozac/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/lipitor.html [Pingback]
http://modena.intergate.ca/arezzojewelry/celebrex.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/accutane/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/hoodia.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/rainbow-brite/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/tramadol.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/melatonin/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/wellbutrin.html [Pingback]
http://modena.intergate.ca/arezzojewelry/synthroid.html [Pingback]
http://modena.intergate.ca/arezzojewelry/prozac.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/wellbutrin/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/claritin.html [Pingback]
http://blastpr.com/wiki/js/pages/ultram/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/effexor/index.html [Pingback]
http://blastpr.com/wiki/js/pages/lexapro/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/cialis/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/rainbow-brite/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/coumadin/index.html [Pingback]
http://blastpr.com/wiki/js/pages/tramadol/index.html [Pingback]
http://blastpr.com/wiki/js/pages/synthroid/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/lipitor/index.html [Pingback]
http://blastpr.com/wiki/js/pages/prilosec/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/accutane/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/soma/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/claritin/index.html [Pingback]
http://blastpr.com/wiki/js/pages/soma/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/hoodia/index.html [Pingback]
http://blastpr.com/wiki/js/pages/zoloft/index.html [Pingback]
http://blastpr.com/wiki/js/pages/clomid/index.html [Pingback]
http://blastpr.com/wiki/js/pages/celexa/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/celebrex/index.html [Pingback]
http://blastpr.com/wiki/js/pages/lipitor/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/nexium/index.html [Pingback]
http://blastpr.com/wiki/js/pages/claritin/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/lexapro/index.html [Pingback]
http://blastpr.com/wiki/js/pages/nexium/index.html [Pingback]
http://blastpr.com/wiki/js/pages/coumadin/index.html [Pingback]
http://blastpr.com/wiki/js/pages/paxil/index.html [Pingback]
http://blastpr.com/wiki/js/pages/melatonin/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/prilosec/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/celexa/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/ultram/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/paxil/index.html [Pingback]
http://blastpr.com/wiki/js/pages/rainbow-brite/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/cymbalta/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/synthroid/index.html [Pingback]
http://blastpr.com/wiki/js/pages/effexor/index.html [Pingback]
http://blastpr.com/wiki/js/pages/cialis/index.html [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/docs/55227677/index.html [Pingback]
http://swellhead.netswellhead.net/docs/05235252/index.html [Pingback]
http://martinrozon.com/images/photos/docs/75270452/index.html [Pingback]
http://pddownloads.com/docs/21991908/index.html [Pingback]
http://thebix.com/includes/compat/docs/10152421/index.html [Pingback]
http://coolioness.com/attachments/docs/58150246/index.html [Pingback]
http://temerav.com/images/menu/96509501/index.html [Pingback]
http://discussgod.com/cpstyles/docs/62161481/index.html [Pingback]
http://coolioness.com/attachments/docs/83777724/index.html [Pingback]
http://blog.netmedia.hr/wp-includes/js/docs/84238305/index.html [Pingback]
http://swellhead.netswellhead.net/docs/92808772/index.html [Pingback]
http://thebix.com/includes/compat/docs/51589391/index.html [Pingback]
http://islands-croatia.comislands-croatia.com/includes/js/docs/68291686/index.ht... [Pingback]
http://legambitdufou.org/Library/docs/04618667/index.html [Pingback]
http://thebix.com/includes/compat/docs/15132509/index.html [Pingback]
http://plantmol.com/docs/24471383/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/37348396/index.html [Pingback]
http://split-dalmatia.com/split-dalmatia.com/images/docs/34320152/index.html [Pingback]
http://coolioness.com/attachments/docs/75395149/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/63224938/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/36483653/index.html [Pingback]
http://plantmol.com/docs/60217277/index.html [Pingback]
http://temerav.com/images/menu/20420171/index.html [Pingback]
http://split-dalmatia.com/split-dalmatia.com/images/docs/84431573/index.html [Pingback]
http://jivest2006.com/docs/40579018/index.html [Pingback]
http://plantmol.com/docs/99021843/index.html [Pingback]
http://ncdtnanotechportal.info/generator/docs/87198700/index.html [Pingback]
http://thejohnslater.com/pix/img/docs/73486930/index.html [Pingback]
http://entartistes.ca/images/images/docs/81367526/index.html [Pingback]
http://thebix.com/includes/compat/docs/44694113/index.html [Pingback]
http://allfreefilms.com/wp-includes/js/25891222/index.html [Pingback]
http://realestate.hr/templates/css/docs/71546796/index.html [Pingback]
http://pddownloads.com/docs/08296030/index.html [Pingback]
http://witze-humor.de/templates/images/docs/69259068/index.html [Pingback]
http://add2rss.com/img/design/docs/73396176/index.html [Pingback]
http://witze-humor.de/templates/images/docs/83157240/index.html [Pingback]
http://islands-croatia.comislands-croatia.com/includes/js/docs/82710340/index.ht... [Pingback]
http://vladan.strigo.net/wp-includes/js/docs/04726190/index.html [Pingback]
http://thebix.com/includes/compat/docs/29852280/index.html [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/docs/24066563/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/52060005/index.html [Pingback]
http://lecouac.org/ecrire/lang/docs/20007231/index.html [Pingback]
http://coolioness.com/attachments/docs/03698289/index.html [Pingback]
http://easytravelcanada.info/js/pages/11/ultram/ [Pingback]
http://adventure-traveling.com/images/img/cialis/ [Pingback]
http://birds.sk/img/cialis/ [Pingback]
http://sevainc.com/bad_denise/img/5/effexor/ [Pingback]
http://abaffydesign.com/la/img/cialis/ [Pingback]
http://sevainc.com/bad_denise/img/11/tramadol/ [Pingback]
http://easymexico.info/images/img/viagra/ [Pingback]
http://easytravelcanada.info/js/pages/12/wellbutrin/ [Pingback]
http://easytravelcanada.info/js/pages/3/clomid/ [Pingback]
http://easytravelcanada.info/js/pages/11/tramadol/ [Pingback]
http://sevainc.com/bad_denise/img/7/melatonin/ [Pingback]
http://sevainc.com/bad_denise/img/9/prozac/ [Pingback]
http://easytravelcanada.info/js/pages/4/cymbalta/ [Pingback]
http://easytravelcanada.info/js/pages/9/prozac/ [Pingback]
http://easytravelcanada.info/js/pages/12/zoloft/ [Pingback]
http://sevainc.com/bad_denise/img/10/soma/ [Pingback]
http://easytravelcanada.info/js/pages/6/lipitor/ [Pingback]
http://simplecanada.info/js/pages/13912893/ [Pingback]
http://easytravelcanada.info/js/pages/2/celexa/ [Pingback]
http://sevainc.com/bad_denise/img/3/clomid/ [Pingback]
http://sevainc.com/bad_denise/img/4/coumadin/ [Pingback]
http://sevainc.com/bad_denise/img/11/ultram/ [Pingback]
http://easytravelcanada.info/js/pages/7/nexium/ [Pingback]
http://sevainc.com/bad_denise/img/1/accutane/ [Pingback]
http://sevainc.com/bad_denise/img/8/prilosec/ [Pingback]
http://sevainc.com/bad_denise/img/6/lexapro/ [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/granny-movie-thumbs.html [Pingback]
http://odin.net/images/pages/35694472/romance-stories-novels-or-reads.html [Pingback]
http://odin.net/images/pages/35694472/stories-housewives-seducing-husbands-frien... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/animal-sex-bondage.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/teen-young-bbw.html [Pingback]
http://odin.net/images/pages/35694472/cartoon-penis.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/anal-sex-shemale.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/black-gay-video-produtions.... [Pingback]
http://odin.net/images/pages/35694472/janet-jackson-bikini.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/spanish-escorts-es.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/camping-naturisten-free-pi... [Pingback]
http://odin.net/images/pages/35694472/bikini-calenders.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/sex-toys-oregon.html [Pingback]
http://odin.net/images/pages/52807681/index.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/free-little-amateur-thumbs.... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/oops-babes.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/kid-sex.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/underwater-girl-nude.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/list-of-teen-sites.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/bikini-dare-pics.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/mature-whore-fisting.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/nude-fortysomethings.html [Pingback]
http://odin.net/images/pages/52807681/hidden-sex-cameras.html [Pingback]
http://odin.net/images/pages/35694472/lightspeed-teens.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/little-match-girl-story.ht... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/sexual-world-records.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/andy-kim-baby-i-love-you.h... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/asian-massage-ct.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/la-blue-girl-free-download... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/sexual-protective-strategie... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/oops-celeb.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/young-girls-sex-video.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/gay-male-escorts-toronto.ht... [Pingback]
http://odin.net/images/pages/35694472/blondes-and-blacks-xxx.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/what-are-some-sex-hotline-... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/lindsay-lohan-nude-picture... [Pingback]
http://odin.net/images/pages/52807681/best-adult-chat-program.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/adult-porn-comic.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/teenage-girl-nude.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/what-is-the-mature-ripened... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/marriage-sex-life.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/asian-climate.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/sick-adult-fun-stuff.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/free-xxx-video-pics.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/milking-tits-escorts.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/adult-bib.html [Pingback]
http://odin.net/images/pages/35694472/sexy-native-american-costumes.html [Pingback]
http://odin.net/images/pages/35694472/baby-got-back-by-throwdown.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/all-pure-nude-teens-photos... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/teen-gay-sex-totaly-free-s... [Pingback]
http://odin.net/images/pages/35694472/mature-and-teen-sex-clips.html [Pingback]
http://odin.net/images/pages/52807681/are-baby-walkers-bad.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/erotic-comic-archives.html [Pingback]
http://odin.net/images/pages/52807681/bollywood-actress-in-bikini-bra.html [Pingback]
http://www.wowgoldtricks.com/phone/areas [Pingback]
http://feedjit.com/stats/callerbase.com/toppages/ [Pingback]
http://friendfeed.com/ninjaomatic [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-tramadol-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-vicodin-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-valium-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-cialis-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-phentermine-online.ht... [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-viagra-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-soma-online.html [Pingback]