ebook img

DTIC ADA453253: Efficiently Distributing Component-Based Applications Across Wide-Area Environments PDF

17 Pages·0.22 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview DTIC ADA453253: Efficiently Distributing Component-Based Applications Across Wide-Area Environments

Efficiently Distributing Component-based Applications Across Wide-Area Environments Technical Report: TR2002-832 DeniLlambiri,AlexanderTotok,andVijayKaramcheti DepartmentofComputerScience CourantInstituteofMathematicalSciences NewYorkUniversity,NewYork,NY,USA {llambiri,totok,vijayk}@cs.nyu.edu Abstract varietyofsophisticatednetwork-accessibleservicessuchas Distribution and replication of network-accessible ap- e-mail,banking,on-lineshopping,entertainment,andserv- plications has been shown to be an effective approach for ing as a data exchange transport for applications utilizing deliveringimprovedQualityofService(QoS)toendusers. theemergingWebServicesplatform.Withtherapidgrowth Anorthogonaltrendseenincurrent-daynetworkservicesis of functional and implementation complexity of such ser- theuseofcomponent-basedframeworks. Eventhoughsuch vices,anddrivenbytheirincreasingnecessitytoaccessdis- component-based applications are natural candidates for tributedsourcesofdata,network-accessibleservicesareof- distributed deployment, it is unclear if the design patterns tenrealizedasdistributedapplications. underlyingcomponentframeworksalsoenableefficientser- Two major trends can be observed in common ways of vicedistributioninwide-areaenvironments. designinganddeployingnetwork-accessibleservices. Inthispaper,weinvestigateapplicationdesignrulesand The first trend is the increasing popularity of theiraccompanyingsystem-levelsupportessentialtoaben- commercial-off-the-shelf (COTS) component middleware eficialandefficientservicedistributionprocess. Ourstudy as a platform for building distributed network-accessible targets the widely used Java 2 Enterprise Edition (J2EE) applications. Current-day industry standard component componentplatformandtwosamplecomponent-basedap- frameworks, exemplified by OMG’s CORBA Component plications: JavaPetStoreandRUBiS. Model [6], Sun Microsystems’ Java 2 Platform Enterprise Our results present strong experimental evidence that Edition(J2EE)[38]andMicrosoft’s.NET[28]frameworks, component-basedapplicationscanbeefficientlydistributed permit assembly of services from reusable components, inwide-areaenvironments,significantlyimprovingQoSde- relyinguponcontainerenvironmentstoprovidecommonly livered to end users as compared to a centralized solu- required support for naming, communication, security, tion. Although current design patterns underlying compo- clustering, persistence, and distributed transactions. The nentframeworksarenotalwayssuitable,weidentifyasmall advantage of using component architectures is two-fold. set of design rules for orchestrating interactions and man- First, component frameworks provide an integrated envi- agingcomponentstatethattogetherenableefficientdistri- ronment for component execution, as a result significantly bution. Futhermore,weshowhowenforcementoftheiden- reducing the time it takes to design, implement, and tified design rules and automation of pattern implementa- deploy systems. Second, a component model incorporates tioncanbesupportedbycontainerframeworks. “best practices” designs, providing developers with design patterns, suggesting a standardized structure upon which distributedcomponent-basedsystemsshouldbebased. Keywords The second trend in the design and utilization of Middleware, Component Frameworks, Internet Tech- network-accessibleservicesis,generallyspeaking,bringing nologies,WideAreaDeployment,ApplicationDesignPat- application data and data processing closer to the clients. terns,StateReplicationandCaching,E-commerceApplica- This is being done in order to cope, on the network level, tions withinherentlybursty,unpredictablenatureofInternettraf- fic,especiallyinwide-areaenvironments,and,ontheappli- 1 Introduction cation level, with high-volume, widely varying, disparate TheroleoftheInternethasundergoneatransitionfrom client workloads. Examples of this approach vary from simplybeingadatarepositorytooneprovidingaccesstoa 1 Report Documentation Page Form Approved OMB No. 0704-0188 Public reporting burden for the collection of information is estimated to average 1 hour per response, including the time for reviewing instructions, searching existing data sources, gathering and maintaining the data needed, and completing and reviewing the collection of information. Send comments regarding this burden estimate or any other aspect of this collection of information, including suggestions for reducing this burden, to Washington Headquarters Services, Directorate for Information Operations and Reports, 1215 Jefferson Davis Highway, Suite 1204, Arlington VA 22202-4302. Respondents should be aware that notwithstanding any other provision of law, no person shall be subject to a penalty for failing to comply with a collection of information if it does not display a currently valid OMB control number. 1. REPORT DATE 3. DATES COVERED 2002 2. REPORT TYPE 00-00-2002 to 00-00-2002 4. TITLE AND SUBTITLE 5a. CONTRACT NUMBER Efficiently Distributing Component-based Applications Across 5b. GRANT NUMBER Wide-Area Environments 5c. PROGRAM ELEMENT NUMBER 6. AUTHOR(S) 5d. PROJECT NUMBER 5e. TASK NUMBER 5f. WORK UNIT NUMBER 7. PERFORMING ORGANIZATION NAME(S) AND ADDRESS(ES) 8. PERFORMING ORGANIZATION New York University,Department of Computer Science,Courant Institute REPORT NUMBER of Mathematical Sciences,New York,NY,10003 9. SPONSORING/MONITORING AGENCY NAME(S) AND ADDRESS(ES) 10. SPONSOR/MONITOR’S ACRONYM(S) 11. SPONSOR/MONITOR’S REPORT NUMBER(S) 12. DISTRIBUTION/AVAILABILITY STATEMENT Approved for public release; distribution unlimited 13. SUPPLEMENTARY NOTES 14. ABSTRACT see report 15. SUBJECT TERMS 16. SECURITY CLASSIFICATION OF: 17. LIMITATION OF 18. NUMBER 19a. NAME OF ABSTRACT OF PAGES RESPONSIBLE PERSON a. REPORT b. ABSTRACT c. THIS PAGE 16 unclassified unclassified unclassified Standard Form 298 (Rev. 8-98) Prescribed by ANSI Std Z39-18 old-fashioned edge caching of static content, to web con- ducethenotionofaserviceusagepattern,afrequentlyex- tentdeliveryusingcontent-distributionnetworks[1],tosys- ecutedscenarioofserviceinvocation,whichreflectstypical tems such as Akamai’s EdgeSuite [13] and IBM’s Web- client behaviour. Considering different service usage pat- Sphere[39],whichoffloadpartofthedataprocessingfrom terns,first,helpstoidentify,whichgroupsofclientsbenefit webserverstoedgeservers. most from certain service distribution and replication, and Inthiswork,wetrytocombinethesetwonaturaltrends second, provides an application deployer with the knowl- and explore the question of whether component-based ap- edgeofhowapplicationsshouldbedistributedand/orrepli- plications can benefit from a distributed, edge deployment cated, in order to be adapted to the needs of certain client inwide-areaenvironments. Thoughnominallysuitablefor groups. deployment in distributed environments, component-based Our results present strong experimental evidence that applications are typically deployed only in a centralized component-basedapplicationscanbeefficientlydistributed fashioninhigh-performancelocalareanetworks.Intherare in wide-area environments using a small set of generally- cases when these applications are distributed in wide-area applicable design rules for orchestrating interactions and environments,thesystemstendtobehighlycustomizedand managing component state. Moreover, we argue that the handcrafted. burdenofimplementingsomeofthesuggestedfunctional- The advantages of distributing and replicating compo- ity could be shifted from application programmers to con- nentsacrosswideareaenvironmentsareseveral. Cacheable tainer providers. Application deployers would need only components can be positioned in edge nodes, effectively declaratively express the desired component behavior via bringing the service closer to clients, and thus improving (extended)deploymentdescriptors; andtheneededsystem not only client perceived latency, but also overall service and application level components could be automatically availability since client requests can utilize several entry configured, instantiatedandlinkedbycontainerinfrastruc- points into the service. Furthermore, specific “hot” com- tures. ponents can be replicated and/or redeployed on-demand ProjectContext Theworkpresentedinthispaperispart in new physical nodes in response to higher client loads of a bigger research effort, the Mutable Services project, or congested network links. Although component frame- that focuses on the construction of a flexible service dis- works offer mechanisms to enable distributed deployment tribution infrastructure for component-based applications, ofcomponents,significantchallengesneedtobeaddressed whichpermitsdifferentgroupsofclientstoaccesstheser- before wide-area deployments of general applications be- vice via different access paths. Each of the access paths comes commonplace. The most basic challenge is: how represents a different deployment of the service’s compo- shouldcomponent-basedapplicationsbeengineeredtoen- nentstounderlyingphysicalnodes,enablingtheassociated ableefficientservicedistributioninheterogonousandhigh- clientgrouptoreceivedifferentiatedservice. Thus,themu- latencynetworksettings? table services infrastructure permits a service to adapt to In this paper, we answer this question by investigating a broad range of “unfriendly” system conditions, includ- theapplicationdesignrulesandaccompanyingsystem-level ing network congestion, bandwidth mismatches and high supportrequiredforabeneficialandefficientservicedistri- latencybetweenclientandserverlocations,aswellasnode bution process. This study targets the Java 2 Platform En- andlinkfailures. terpriseEdition(J2EE)componentplatformandtwosample Therestofthepaperisorganizedasfollows. Section2 applicationsthatcovermostaspectsoftheplatform: Sun’s providessomebackgroundincomponentsoftwaretechnol- Java Pet Store and Rice University’s RUBiS. We deploy ogy,Java2EnterpriseEditioncomponentplatform,andthe Java Pet Store and RUBiS in a fixed, simulated wide-area Java Pet Store and RUBiS sample applications. Section 3 environment, apply various design patterns and optimiza- describes our testing methodology. Section 4 introduces tionsinanincrementalfashion,andaftereachstepmeasure designpatternsandoptimizationsoneatatimeanddetails the performance of the application and draw conclusions howtheywereappliedtothetestapplications,andoutlines abouttheimpactofthechanges. Ourapproachfocuseson the impact of the changes by analyzing resulting perfor- application-level design patterns and optimizations and is mance. Section5describeshowtheidentifieddesignrules orthogonal to other efforts that have looked at improving canbeincorporatedincomponentmodelsandframeworks, container-levelmechanismssuchasRMIperformance[20]. and discusses how some of the proposed functionality can While the overall performance of a network-accessible be automated by container environments. Related work is service usually depends on its component distribution and discussedinSection6andweconcludeinSection7. combined client load, request response times observed by clientsalsosignificantlydependonclientbehavior, asdif- ferenttypesofuserstendtomakedifferenttypesofrequests and,asaconsequence,differentsetsofservicecomponents areinvolvedinarequest’sexecution.Inthispaper,weintro- 2 2 Background izedstructureuponwhichdistributedcomponent-basedsys- temsshouldbebased. 2.1 ComponentSoftwareandComponentFrame- works 2.2 J2EE,JavaPetStore,andRUBiS Component software Traditional software development JavaPetStore[34]isabest-practicessampleapplication can broadly be divided into two camps. At one extreme, fromtheJavaEnterpriseBluePrintsprogrammaintainedby a project is developed entirely from scratch, with the help SunMicrosystems. Itrepresentsatypicale-commerceap- of only programming tools and libraries. At the other ex- plication. Customerscanbrowsethroughacatalogofprod- treme,everythingis“outsourced,”inotherwords,standard ucts, select items of interest and place them in a shopping softwareisboughtandparameterizedtoprovideasolution cart. Uponindicatingreadinesstobuywhatisintheshop- thatis“closeenough”towhatisneeded. ping cart, the application displays a bill detailing prices Theconceptofcomponentsoftwarerepresentsthemid- and quantities. The customer can also create a permanent dlepath,whereanentireapplicationisassembled fromin- account with the on-line shop, which includes billing and dividualatomiccomponents,developedbythirdparties.Al- shippinginformation. Thispaperreferstoversion1.1.2of though each component is a standardized product, with all JavaPetStore. the advantages that brings, the process of component as- RUBiS(RiceUniversityBiddingSystem)[35]isanauc- semblyallowstheopportunityforsignificantcustomization, tion site prototype modeled after the popular e-commerce thus avoiding the drawbacks of using standard monolitic web portal eBay.com [11]. RUBiS implements the core software applications. In addition, some individual com- functionalityofanauctionwebsite: selling, browsingand ponents can be custom-made to suit specific requirements bidding on items. Visitors can search through a catalog of ortofosterstrategicadvantages. itemsdevidedintoseveralcategoriesandbelongingtodif- Componentframeworks Initsearlydaysmostoftheem- ferentgeographicalregions. Theycanbidonitemsofinter- pasis in the development of component software was on est,aswellasputcommentsforotherusers.Usersmayalso theconstructionofindividualcomponentsandonthebasic choosetosellanitem,registeringitandspecifyingseveral “wiring” support of components, leading to specifications parameters,suchasactionduration,andinitial,reserveand suchasJavaRMIandCOM/DCOM.Itwashighlyunlikely buy-now prices. All non-browsing activities require cre- thatcomponentsdevelopedindependentlyundersuchcon- ationofapermanentaccountwiththewebsiteandlogging ditionswouldbeabletocooperateusefully. in. Inception of component frameworks was the most im- Java Pet Store aims at covering as much of the J2EE portantstepthatliftedcomponentsoftwareofftheground. componentplatformaspossibleinarelativelysmallappli- A component framework is a software system that sup- cation.Itsmainfocusisondesignpatternsandindustrybest ports components conforming to certain standards and al- practices that promote code and design reuse, extensibil- lows instances of these components to be “plugged” into ity, modularity, ease of maintenance, isolation of develop- thecomponentframework. Thecomponentframeworkes- menttasksbyskillsets,anddecouplingofcode-baseswith tablishesenvironmentalconditionsforthecomponentsand differing rates of change. RUBiS, on the contrary, uses a regulates the interactions between them. This is usually smallsubsetofJ2EEtechnology,butitdoessotoefficiently done through containers, component holders, which often emulate the behavior of an existing e-commerce web site. alsoprovidecommonlyrequiredsupportfornaming,secu- Therefore, together Java Pet Store and RUBiS represent a rity,transactions,andpersistence. Componentframeworks big class of component-based applications already widely provide an integrated environment for component execu- employed in the industry. So we believe that conclusions tion, as a result significantly reduce the effort it takes to drawn in this paper are relevant not only to Pet Store and design,implement,deploy,andmaintainapplications. Cur- RUBiS,buttoawideclassofgeneralpurposecomponent- rentdayindustrycomponentframeworkstandardsarerep- basedapplications. resentedbyObjectManagementGroup’sCORBACompo- Java 2 Enterprise Edition Java Pet Store and RU- nentModel[6],SunMicrosystems’Java2PlatformEnter- BiS demonstrate the use of the most common types of prise Edition (J2EE) [38] and Microsoft’s .NET [28], with J2EE components, with a focus on Enterprise JavaBeans J2EE being currently the most popular and widely used (EJB)[15]. Generallyspeaking,J2EEcomponentsfallinto componentframeworkintheenterprisearena. two main categories: stateless and stateful. Stateless com- The architecture of component-based systems is often ponentsareexemplifiedby(synchronous)statelesssession significantlymoredemandingthanthatoftraditionalmono- beansand(asynchronous)message-drivenbeans,andtypi- liticintegratedsolutions. Tomakedevelopmentofefficient callyprovidegenericapplication-wideservices. Sincethey component-basedapplicationsafeasibletask,acomponent do not contain any state, the replication of stateless com- modelincorporates“bestpractices”designs,andestablishes ponentsisratherstraightforward. Statefulcomponentscan themasa“normoflife”throughrepeatedreuse,byprovid- be largely classified into two categories: those that hold ingdeveloperswithdesignpatterns,suggestingastandard- session state on a per-client basis, thus effectively acting 3 Table1.EJBsinJavaPetStore. Web Tier EJB Tier Data Tier EJBName Description Session Entity StatelessSessionBeans AOccrdoeurnt Customer Account account Catalog Handlesread-onlyqueriestoproductdatabase Cart Shopping Cart Order oorrddeerrstatus lineitem Customer Servesasafac¸adetoOrderandAccount StatefulSessionBeans Catalog Catalog cpitareotmedguocrty ShoppingCart Maintainslistofitemstobeboughtbycustomer Inventory Inventory inventory Sh.Cl.Contr. Managesmodelobjectsandprocessesevents EntityBeans Figure1.PetStorecomponentarchitecture. Inventory Recordsavailabilityinformationforeachitem SignOn Keepsuserid/passwordinformation Order Keepsorderinformation The Controller translates user actions and inputs into Account Keepsaccountinformation methodcallsontheModel,andselectstheappropriateView basedonuserpreferencesandModelstate. IntheJavaPet asanextensionoftheclient’srun-timeenvironmentonthe Store application, the Controller is split between the Web server-side,andcomponentsthatrepresentsharedstatethat andEJBtiers. typically corresponds to the domain layer of the applica- The main relationships among the most accessed Java tion. IntheJ2EErealm,thefirstcategoryisexemplifiedby PetStorecomponentsareshowninFigure1, andthemost webcomponents-servletsandJavaServerPages(JSP)-that relevantEJBstoourexperimentsarelistedinTable1.Other holdHTTPsessioninformation,andstatefulsessionbeans middle tier components such as ProfileMgr, Mailer, thatofferimprovedscalabilityandtransactionalawareness, and AdminClientController were not used during whereasthesecondcategoryconsistsofentityEJBs,ortheir our tests. All entity beans in Pet Store 1.1.2 are imple- alternatives: direct Java Database Connectivity (JDBC) or mented using Bean Managed Persistence (BMP) since at stored procedures, Java Data Objects (JDO) [23], and pro- the time, Container-Managed Persistence (CMP) was not prietaryObject/Relationalmappingtools. Generallyspeak- standardized yet, and could have resulted in code that was ing, session-oriented stateful components tend to be in- notportableacrossdifferentapplicationservers. Laterver- memory objects, whereas shared stateful components are sions of Pet Store (starting from 1.3) conform to the EJB transactional,persistententitiesthataretypicallyco-located 2.0specificationandtakeadvantageofbothCMPandlocal with database servers. Since stateful session components interfaces. arenotsharedtheycanbedeployedinedgeserversforbet- RUBiS Originally RUBiS was developed at Rice Univer- terlocality. Wediscussourapproachforreplicatingshared sity as part of a study investigating the combined effect statefulcomponentslaterinthepaper. of application implementation methods, container design, Java Pet Store The fundamental design pattern used in andefficiencyofcommunicationlayersontheperformance Java Pet Store is the Model-View-Controller (MVC) archi- scalabilityofJ2EEapplicationsinaLANsetting[7]. Sev- tecture [36], which decouples the application’s data struc- eralimplementationsoftheapplicationweremade,ranging ture,businesslogic,datapresentation,anduserinteraction. from a servlets-only implementation, to one utilizing ses- TheModelrepresentsthestructureofthedataintheap- sion and entity beans. Even in the most elaborate version plication,aswellasapplication-specificoperationsonthose (a.k.a. Session Fac¸ade configuration), which we took as a data. Java Pet Store stores application state across three baselineforourexperiments,RUBiSissignificantlylighter tiers - Web, EJB, and Data. The Web tier uses servlet weightthanJavaPetStore. HTTPSession and ServletContext objects as well The application design of this RUBiS version is rather asJavaBeansaccessedfromJSPpages.Inaddition,theweb streamlined: for each type of web page there is a separate tierdirectlymanagesdatabaseconnections. IntheEJBtier, servletwhich,ifnecessarytogeneratetheresponseHTML state is maintained using stateful session beans and entity page, invokes business method(s) on associated stateless beans,whichimplementbusinessusecases,suchasbrows- session bean(s), that in turn access related entity EJBs to ing the catalog, manipulating the shopping cart, changing get application shared data, stored in the database. There- the inventory, and others. The application also maintains foretheRUBiS component architecture isalmost“linear”: persistent product, inventory, account, and order data in a each servlet has reference(s) to dedicated stateless session relationaldatabase. bean(s) only (almost always just one), which have refer- TheViewconsistsofobjectsthatdealwithpresentation encestorelatedentitybeansonly. Theapplicationdoesnot aspectsoftheapplication. TheimplementationoftheView keepper-clientsessionstate,soitneitherkeepsany(HTTP in Java Pet Store is completely contained in the Web tier, session)dataintheWebtier,nordoesitusestatefulsession andisbuiltontopofareusableframeworkforwebapplica- beansintheEJBtier. Theapplicationkeepssharedpersis- tions. tent data in the database and caches it in the entity beans. 4 Table2.JavaPetStoreBrowsersession. Page Functionality Requests Edge AS LAN (%) Main Servesasanentrypointtotheapplication 5% Remote clients WAN Main AS Category Displayslistofproductsassociatedwitha 15% RDBMS particularcategory LAN Edge AS Product Displayslistofitemsassociatedwithapar- 30% LAN Local ticularproduct clients Item Displays details about an item, including 45% description,price,andthequantityinstock Search Displays list of products, whose names 5% Figure2.Networkconfiguration. matchthespecifiedsearchkeyword(s) databasesaredesignedtosustain.Inallofthetestsdatabase As a consequence of such a design, there is no notion of CPUconsumptionneverexceeded5%. “logged in” user-driven sessions in RUBiS, i.e., where the Awide-areanetwork(WAN)separatesthethreeapplica- clientlogsinandperformsanarbitrarysequenceofactivi- tionservers. Oneoftheapplicationserversislocatedinthe tiesthatdonotrequirefurtherauthentication, andlogsout sameLANasthedatabaseserver(runsonthesamework- at the end of a session. In RUBiS, user authentication is station,intheRUBiStests),henceactingasthemainserver required before each essential non-browsing client activity of the system. Two other application servers act as edge andcoversonlyonesuchactivity. Passingsessionandau- servers. In addition, 9 client machines were used to gen- thenticationinformationbetweenrelatedHTTPrequestsis erate client load, three for each application server. Clients implementedthroughhiddenURLparameters. machinesarecollocatedwiththecorrespondingserver(sit- Such a “minimal” design, however, turns RUBiS into a tingonthesameLAN),emulatingclientloadcomingfrom high-performanceapplicationandallowsittoachievegood users“close”tothatserver. Thenetworktopologywasem- scalability,asseeninboththeoriginalRUBiSstudy[7]and ulated by connecting all of the above nodes using a soft- ourtests(section4). ware router built with the Click modular router infrastruc- ture;trafficshapingcomponentswereusedtosimulate100 3 Methodology ms latency each way in the WAN links, with 100 Mbit/s Wedeployedbothtestapplicationsinafixed,simulated maximumcombinednetworkbandwidth(seeFigure2). wide-areaenvironment,andappliedvariousdesignpatterns 3.2 Serviceusagepatterns and optimizations in an incremental fashion. After each step, we measured performance and drew conclusions on DuringpreliminarytestingofchangesmadetoJavaPet theimpactofthechanges. Store and RUBiS, we came to the conclusion, that while overallperformanceoftheapplicationdependedonitsdis- 3.1 Networktopology tributionandcombinedclientload,responsetimesobserved Ournetworktopologyaimsatcapturingasimplescaled- byclientsalsosignificantlydependedonclientbehavior,as downwide-areadistributeddeploymentofthetestapplica- different types of users tend to access different web pages tions. Eventhoughthetestbedconfigurationmayseemnot and,asaconsequence,differentsetsofservicecomponents representativeofactualWANconditions,itissufficientfor are involved in a request’s execution. In our subsequent demonstratingtheimportanceofusingidentifieddesignpat- testswedivideallclientsbetweentwodifferentserviceus- terns and optimizations for efficient wide-area distribution age patterns: Browser and Buyer for Java Pet Store, and ofcomponent-basedapplications. Browser and Bidder for RUBiS. Intuitively, Browser cor- The system consists of three application servers responds to read-only activities, while Buyer/Bidder is in- (JBoss 2.4.4 [22] bundled with Jetty 3.1.3 [24] web server volvedinread-writesessions. and JSP container, for the Java Pet Store tests; and JavaPetStoreBrowser Thispatternrepresentsauserthat JBoss3.0.3withJetty4.1.0,fortheRUBiStests)andasin- merelybrowsestheapplicationwebsiteinsearchofitems gle database server (Oracle 8.1.7 Enterprise Edition), each ofinterestorwithnoparticulargoal. Thisuserneitherlogs running on a dedicated 1GHz dual-processor Pentium III in,norbuysanyproducts. Atypicalscenarioforabrowser workstation.FortheRUBiStests,weusedaMySQL4.0.12 wouldconsistofa(relativelylong)sequenceofaccessesto databaserunningonthesameworkstationasoneoftheap- pagesthatpresentproduct-relatedinformation. Duringour plicationservers.Preliminarytestsshowedthatthedatabase tests,weusedJavaPetStorebrowsersessionsconsistingof never became a performance bottleneck. Putting database 20requeststothepagesdescribedinTable2. Eachsession onthesamemachineastheapplicationserverdoesnotaf- is a logically organized sequence of requests starting with fect performance of the latter, because database operation theMainpage. Forexample, arequestofanItempageal- rates produced by our tests were much lower than both waysgoesafterarequestforaProduct page,suchthatthe 5 Table3.JavaPetStoreBuyersession. Table5.RUBiSBiddersession. Page Functionality Page Functionality Main Entrypointtotheapplication Main Staticpage;servesasanentrypointtotheappli- Signin PromptsusertoenteruserIDandpassword cation VerifySignin Systemauthenticatessubmittedcredentials PutBidAuth PromptsbiddertoenterUserIDandpasswordto Shopping Upontheuseraddinganitemtotheshoppingcart, putbidonanitem Cart theupdatedcartcontentisdisplayed PutBidForm Afterverifyingusercredentials, systemdisplays Checkout Userinitiatescheckoutprocess thebiddingform PlaceOrder Userconfirmstheorder StoreBid Thebidisacceptedandstoredinthedatabase Billing and Userconfirmsbillingandshippinginformation Put Comment Promptsusertoauthenticatehim/herself,topro- Shipping Auth ceedwithwritingacomment Commit Usercommitsorder;allnecessarydatabaseupdates Put Comment Afterverifyingusercredentials, systemdisplays Order happenhere Form theformforwritingacomment Signout Usersignsout StoreComment The comment is accepted and stored in the database Table4.RUBiSBrowsersession. Page Functionality Requests onlyonetypeof“write”activity-buyinganitem, inRU- (%) BiS, a user can bid on an item and put a comment for an- Main Staticpage; servesasanentrypointto 2.5% other user. For our tests, we organized RUBiS bidder ses- theapplication sions as a sequence of pages emphasizing these activities: Browse Static page; displays several browsing 2.5% options bidderbidsonanitemandleavesacommentfortheseller All Cate- Displaysthelistofavailablecategories 2.5% oftheitem(seeTable5). gories Consideringdifferentserviceusagepatternsisessential AllRegions Displaysthelistofregions 2.5% for accurate and meaningful performance measurement of Region Displaysthelistofavailablecategories 2.5% a distributed component-based application for several rea- foraregion sons. First,ithelpstoidentify,whichgroupsofclientsben- Category Displaysthelistofavailableitemsina 7.5% efit most from certain service distribution and replication. category Second, it provides application deployers with the knowl- Category& Displaysthelistofavailableitemsina 7.5% edgeofhowapplicationsshouldbedistributedand/orrepli- Region categoryandaregion cated, in order to be adapted to the needs of certain client Item Displaysdetailsaboutanitem, suchas 42.5% groups. currentpriceandnumberofbids Bids Displaysthelistofbidsonanitem 15% 3.3 Clientsimulation UserInfo Displays public information about a 15% Clients were divided between Browsers and Buy- user, suchase-mail, currentratingand ers/Bidders. Each client ran a session consisting of a se- thelistofusercomments quenceofwebpagerequestswithdelaysinsertedaftereach request to simulate user think time. We used soft delays between successive page requests in a session, i.e. instead requesteditembelongstothepreviouslyrequestedproduct. of waiting a predefined DELAY time interval after receiv- JavaPetStoreBuyer Thispatternrepresentsthebehavior ingresponsefromthepreviousrequest,theclientwaitsfor ofaclientwhoalreadyknowswhattobuy. Abuyerlogsin, onlyDELAY - response time. SoeffectivelyDELAY findsitem(s)ofinterest,probablyaccessingafewproduct- becomesthetimeintervalbetweensendingrequests,which relatedpages,putsdesireditemsintotheshoppingcart,and allowedustosimulatesteadyclientloadindependentofre- checksthemout. Forthepurposeofourtests,weorganized sponsetimes. Java Pet Store buyer sessions as a sequence of pages em- Preliminary testing indicated that client response times phasizingbuyer’sessentialactivities: abuyersignsin,buys did not depend on the relative ratio of browsers and buy- anitem,andsignsout(seeTable3). ers/bidders, but rather on the combined load coming from RUBiS Browser This pattern represents, as in Java Pet all clients. In all of our tests, we use a combined client Store, a user that merely browses the RUBiS web site and load of 30 web page requests per second, coming from a neverbidsonitems. OurtestsuseRUBiSbrowsersessions mixtureof80%browsersand20%buyers/bidders,equally oflength40, madeupofindividualpagerequestswiththe dividedbetweenallclientmachines(10HTTPrequestsper weights shown in Table 4. Each session is a logically or- secondcomingfromeachofthethreeclientgroups). Each ganized sequence of requests starting with the Main page. testlastedforapproximatelyonehour,precededbyseveral minutesofsystem“warm-up,”ifneeded. RUBiS Bidder Unlike in Java Pet Store, where there is Someoftheapplicationstaticcontentconsistsof96im- 6 agestotaling318KBytesinJavaPetStore,and3images(28 4.DistributingJavaPetStoreandRUBiS KBytes)inRUBiS.Duringourtests,wedidnotsendHTTP Tables 6 and 7 show average response times per page requestsfortheseimages,becauseinreal-lifeenvironments for the five Java Pet Store and RUBiS configurations de- web browsers and proxies tend to successfully cache such scribedbelow(forwebpagedescriptionsrefertoTables2, content. 3, 4, and 5). Both remote group of clients (connecting to the edge servers) observed, as one would expect, prac- 3.4 Codemodifications tically equal response times, within a small error margin. JavaPetStore JavaPetStorewasnotdesignedasaper- Boldnumbersindicatesignificantchangesinperformance, formance benchmark (ECPerf is the standard J2EE bench- ascomparedtoconfigurationsappearingearlierinthetable. mark [12]) so we made several modifications that allowed 4.1 Centralizedapplication us to measure the performance of our browser and buyer sessions. We increased the size of the database to allow In the first experiment, we ran the centralized undis- testing a greater number of concurrent users without con- tributedversionofJavaPetStoreandRUBiSwiththemodi- tention for the data. Specifically, we added five artificial ficationsnotedabove. Inthisconfiguration,themainserver categories, 50 products and 300 items. We also removed got all 30 HTTP requests per second, whereas the edge extra database requests and made changes to allow simul- servers were not used at all. This configuration represents taneous database connections for users engaged in catalog thelowendofthedistributionspectrum, whereeffectively browsing. Most of these modifications have been applied no distribution takes place. As seen in Tables 6 and 7, ac- inanotherstudy[32]. Furthermore,weoptimizedallentity cessingtheservicefromaWANlinkincursapproximately beans so that ejbStore() does not go to the database an extra 400 ms, which is due to two round trips: one for at the end of read-only transactions, and also removed an TCPhandshakingandanotherfortheHTTPrequest(wedid excessive database call which was present in ejbFind- notusekeep-aliveHTTPconnectionsthroughoutourtests). ByPrimaryKey() methods. These modifications were 4.2 Remotefac¸ade aimedatprovidingafairbaselineforourexperiments,and werenotintendedtoturnJavaPetStoreintoahighperfor- The centralized configuration suffers from two major manceapplication. problems.First,thesystemdoesnotutilizeallitsresources, sincetheedgeserverisnotbeingusedatall.Second,HTTP RUBiS Aswealreadymentioned,RUBiSisasignificantly requestsgoingtothemainserverfromremoteclientsincur more lighter weight application than Java Pet Store, and significantly higher response times in comparison to local is already optimized to act as a performance benchmark. clientrequests. Bothoftheseproblemscanbeaddressedby Therefore we made minimal changes to this application, migratingpartoftheapplicationcomponentsintotheedge mostlynon-criticalrefactoringtowardscodeunificationand server. simplification: The second configuration in our experiments was ob- • EntitybeansmovedfromCMP1.1toCMP2.0. tainedbydeployingallwebcomponents(JSPsandservlets) • Database schema slightly changed to avoid less effi- and stateful session beans in all three servers. This con- cient custom BMP queries. All queries were imple- figuration addresses the problems of the previous central- mentedthroughCMP-renderedentitybeanhomefind- ized configuration by making better use of available re- ers. sources and also bringing some of the application compo- • Removed some unnecessary inter-component refer- nents closer to remote clients. However, wide-area HTTP encesandinvocations. requestsarenowsubstitutedbypossiblymultiplewide-area • Somecodeoptimizationsweremade, e.g., introduced inter-componentRMIcalls. static String fields instead of reading text from a In addition to contributing to less maintainable, less file each time HTML header and footer is generated reusable,andtightlycoupledcode,repeatedfine-grainedin- inservlets. vocations of core components, such as entity EJBs, from AsinJavaPetStore,weincreasedthesizeofthedatabaseto front-endcomponents(weblayer)addtheoverheadofmul- avoiddatacontention.Weadded400usersfrom20regions, tiple network calls, and reduce concurrency at the server- selling400itemsbelongingto20categories. side,sincetransactionsareeffectivelytakinglongertocom- Inthisstudy,wearenotinterestedontheimpactthatspe- plete. A superior alternative is to wrap the domain model, cificapplicationservers, webservers, anddatabaseservers typicallyimplementedasacollectionofpossiblyrelateden- (orcombinationsthereof)haveonoverallperformance.Our titybeans,withanewthinlayeroffac¸adeobjects[27,10]. focusisontheimpactthatwide-arealatencieshaveonclient Clients, that have access only to the fac¸ade, can delegate response time. Hence, we keep a modest load throughout theexecutionofusecasesinjustonenetworkcalltothere- all of our experiments, and do not overstress the servers. motefac¸ade,whichinturncanperformmultiplelocalcalls Throughout the tests, the CPU utilization on the machines needed to execute the use case against co-located domain runningtheJBoss/Jettybundleneverexceeded40%. objects. Besides reducing the number of remote method 7 Table6.Averageresponsetimes(inms)forfivePetStoreconfigurations. Client Browser Buyer h t . t g c f u r i t n e d m r n n i t o O l m u i t o e a i i r r / . l m o Configuration Page Ma Ca Pr It Se Ma S/ Ve Ca Ch Pl Bi Co S/ CentralizedPetStore Local 87 95 94 88 106 98 78 89 120 76 70 70 158 90 (section4.1) Remote 488 492 492 486 496 489 480 482 658 477 646 482 708 447 Remotefac¸ade Local 64 78 80 72 82 61 52 63 85 54 51 54 134 54 (section4.2) Remote 72 387 389 373 384 60 54 630 407 61 57 61 500 63 Statefulcomponent Local 55 82 84 55 77 60 51 65 77 53 50 55 584 54 caching(section4.3) Remote 55 394 390 57 393 68 52 629 80 50 49 53 950 62 Querycaching Local 56 50 51 54 87 58 51 61 70 50 50 54 614 52 (section4.4) Remote 55 51 51 55 481 61 49 638 69 51 52 53 966 54 Asynchronousupdates Local 61 54 53 57 92 61 53 64 75 53 53 56 195 56 (section4.5) Remote 59 51 53 58 459 59 48 632 69 50 50 50 536 52 invocations, the fac¸ade provides a single entry point into Edge Server Main Server thedomainmodel,enablingimprovedtransactionalandse- Catalog curity control. The pattern does not suggest a singleton CatalogWebImpl WAN <<SessionEJB>> <<JavaBean>> (Facade) fac¸aderesponsiblefortheentireapplication;instead,multi- JD B C plefac¸adeobjectsshouldbecreatedtoservecollectionsof product.jsp productdetails.jsp CatalogWebImpl relatedusecases. <<JavaBean>> We discuss in more detail below, the modifications that RDBMS product.jsp weremadetothetestapplications. productdetails.jsp Java Pet Store Pet Store uses stateful session beans (ShoppingCart and ShoppingClientControl- Figure3.RemoteFac¸ade. ler). Togetherwithwebcomonentstheyweredeployedin allthreeservers. IntheoriginalPetStore,Category,Prod- uct, Item and Search pages present product information to in the client side to avoid the penalty incurred by the RMI endusers,retrievinginformationfromtheProductdatabase callthatinitiallycreatestheremotestub. directlyviaJDBC.Thelifecycleofopening,managing,and Figure 3 illustrates an example of the use of the fac¸ade properlyrecyclingdatabaseconnections,aswellastravers- patternforPetStore(forbrevity,intherestofthepaper,we ingqueryresultsdemandsverbosecommunicationwiththe willshowsuchexamplesonlyfortheJavaPetStoreappli- databaseserver,resultinginoverwhelminglydegradedper- cation). formancewhenthewebtieranddatabaseareseparatedbya RUBiS RUBiSdoesnotusestatefulsessionbeans,soonly high-latencynetwork.Generally,suchscenarioscanbeeas- webcomponentsweredeployedintheedgeservers.RUBiS ilyavoidedbydirectingclientrequeststoafac¸adethatisco- required fewer code modifications because it already em- locatedwiththedatabaseserver. Inourcase,wesubstituted ployed Session Fac¸ade design pattern, as manifested all direct database accesses from the web layer with calls in the name of the RUBiS version, that we took for our totheCatalogbeanthatservedasafac¸ade. Furthermore, experiments. Execution of use cases is delegated by web forallthepagesusedinourexperiments,werewrotetheap- componentstothefac¸adesessionbeans,collocatedwiththe plicationcodesothateverypageincludedintheexperiment entitybeans. WeonlymadesurethatthereisonlyoneRMI incurs no more than one RMI call to shared components. callfromtheweblayertotheEJBlayerineveryservletweb TheonlyexceptionistheVerifySigninpage,whichmakes page generation method. Most changes were done to im- twoRMIcalls,onetocreateaCustomersessionbeanfor plementtheEJBHomeFactorydesignpattern. Servletsnow the customer that logged in, and another for retrieving the cached remote stubs of stateless session beans, while the customer’sprofileforfutureuse. latter cached home stubs of related entity beans, to reduce To further reduce the number of remote method invo- unnecessarylookupsintheJNDItreeofthemainserver. cations, we used the fac¸ade pattern in conjunction with Average client response times for this configuration for cachingofhomeandremoteRMIstubs. Homestubswere the two applications are shown in Tables 6 and 7. Several alwayscachedtoavoidunnecessarytripstothelocalJNDI points stand out from the measurements of this configura- tree(EJBHomeFactorydesignpattern[27]). Inthecaseof tion: statelessremotefac¸ades,remotestubswerepooledaswell • Many pages (HTTP requests) can be served com- 8 Table7.Averageresponsetimes(inms)forfiveRUBiSconfigurations. Cl. Browser Bidder n h m t atio g ons Reg o Auth Form d Aut For mmen r e i y f i m m o u t g r & n d d B m m C g e a e n o I i i o o fi s C R o g g B B e C C e Con 1Page Main Brow All All Regi Cate Cate Item Bids User Main Put Put Stor Put Put Stor Centr. L 14 12 33 26 35 43 21 27 40 43 12 13 32 36 13 25 35 RUBiS R 421 414 434 438 434 649 426 430 446 452 419 419 439 437 414 432 432 Remote L 10 11 27 30 34 35 19 24 35 34 10 13 30 30 14 26 30 fac¸ade R 4 3 424 407 399 499 265 275 300 379 4 3 408 284 3 284 282 St.comp. L 13 16 29 32 39 38 23 19 30 31 10 15 23 372 14 22 377 caching R 3 3 423 463 435 526 279 7 323 404 4 4 450 680 4 303 628 Query L 9 12 12 15 17 16 12 15 16 16 9 10 15 377 9 16 374 caching R 5 4 7 7 7 6 5 8 8 8 3 3 7 798 3 6 729 Async. L 12 12 9 9 11 13 13 14 15 15 10 15 15 32 9 10 34 updates R 4 5 9 7 6 6 4 7 10 10 5 4 9 421 4 12 419 pletely using only session information stored in the canbequiteinefficientwhenusedasdatacaches. Asamat- edgeserver. Thisisparticularlyprominentinthecase ter of fact, this is clearly manifested in the lifecycle and of the Pet Store buyer, whereby six out of nine page transactional management specifications of entity beans, requestscanbeservedlocally. and it simply reflects design choices made by the EJB ar- • If serving a page request from a remote client re- chitects. However,datalocalityiscriticalwhenitcomesto quiresgoingtothemainserver,awide-areaHTTPre- efficient wide-area service partitioning. Fortunately, entity quest in this configuration is substituted by one inter- beanscanbeeasilytransformedintodatacachesbyminor component RMI call. In this case the fac¸ade design modifications to their lifecycle definition. As a matter of patterndoesnotitselfsignificantlyimproverequestre- fact,mostapplicationservervendorsalreadysupportsome sponsetime,butitmakesitminimal,keepingthenum- form of read-only entity beans with a timeout invalidation berofwide-areaRMIcallsassmallaspossible. mechanism,andinsomecasestheyalsosupportaprogram- maticinvalidationinterface.Also,accordingtotheEJB2.0. • RMI can require more than one round trip for a sin- specification[15],plansareunderwaytoincludesomefla- glemethodinvocation. Ithasalreadybeenpointedout vorofread-onlyentitybeansaspartofthestandard. that these shortcomings are mainly due to ping pack- Commontoallthecurrentapproachesforupdatingread- ets and distributed garbage collection [5]. Generally onlybeansisthat,uponinvalidation,theread-onlybeanre- speaking,thebenefitsofthefac¸adepatternareslightly freshes itself with the database using a pull protocol. This diminishedsinceRMIcanincurmorethanoneround approachworkswellinalocal-areasetting,wheretheread- trippermethodinvocation. only bean communication overhead with the database is • The response times of local clients went down due to negligible, but as stated earlier, it results in unacceptable betterloaddistribution. performanceinthewide-area. Toavoidopeningandmain- taining remote database connections, read-only beans can 4.3 Statefulcomponentcaching efficientlyrefreshtheircontentbyqueryingaremotefac¸ade Inthepreviousconfiguration, allsession-orientedstate- upon the first business method call after the invalidation. ful components were deployed in both servers, improving Another approach would be to push the updated state to locality and load distribution. However, pages that trig- read-onlybeansasaparameteroftheinvalidationcall. This gerinvocationsonsharedstatefulcomponentsdidnotgain push-based scheme has the major advantage that clients muchbenefitfromthisapproach. Inthethirdconfiguration, of read-only beans will always have local response times, weturnedourattentiontothesesharedstatefulcomponents, whichisnotthecasewiththepull-basedapproach. Atfirst exemplifiedinJ2EEbyentityEJBsandrelationaldatabase sight, it might seem that since the push-based scheme is sources. notdemand-driven,itcanresultinsendingsuperfluousup- Our experience suggests that entity beans are excellent dates.However,thenumberofRMIcallsisthesameinboth athandlingheavy,concurrenttransactionalaccess,butthey cases,becausetheinvalidationcallhastobemadeanyway. In the push-based scheme, more data is being transferred, 1L–localclient;R–remoteclient. 9

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.