ebook img

Ontology-based Service Discovery in a Globally Distributed Network Knarig Arabshian Advisor ... PDF

221 Pages·2008·4.46 MB·English
by  
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 Ontology-based Service Discovery in a Globally Distributed Network Knarig Arabshian Advisor ...

Ontology-basedServiceDiscoveryinaGloballyDistributedNetwork KnarigArabshian AdvisorHenningSchulzrinne Submittedinpartialfulfillmentofthe Requirementsforthedegree ofDoctorofPhilosophy intheGraduateSchoolofArtsandSciences COLUMBIAUNIVERSITY 2008 (cid:13)c 2008 KnarigArabshian AllRightsReserved Abstract Ontology-basedServiceDiscoveryinaGloballyDistributedNetwork KnarigArabshian In order to accomplish context-aware service discovery, static or dynamic service infor- mation must be made available globally and represented in such a way that registering and queryingfor these servicescan be morecomplicated thanwhat is available to usnow. Imagineaservicediscoverysystemwhereausercanenterthefollowingsearches: ”Findme a nearby Italian restaurant that has available seating for 5 people” or ”Find me a Chinese restaurantorsomethingsimilartoitthathasanearbymovietheatreplayinganactionmovie”. This requires efficiently distributing dynamic service information which require frequent updates as well as enhancing querying and registration beyond text and key word search so thatspecificservicesaswellaslogicallysimilarservicescanbesearchedfor. ThisdissertationintroducesGloServ,anontology-basedglobalservicediscoverysystem. Twoofitsmaincontributionsareitsscalablenetworkarchitectureandintelligentquerying and registration of services. GloServ aggregates different types of services in a globally distributednetwork. Apartiallistofsuchservicesincludereal-timeevent-basedservices, location-based services, communication, e-commerce or web services. GloServ is a service discoveryarchitecturethatusesadescriptionlogicontology,suchastheWebOntologyLan- guage Description Language (OWL DL), for classifying service information and mapping themontoaphysicalhierarchicalpeer-to-peernetwork. GloServoperatesonawideaswell aslocalareanetworkandsupportsthediscoveryofalltypesofservicesthataredescribedin an ontology. Thisclassification ontologydefines serviceclasses andtheir relationshipswith otherservicesandproperties. Thus,Gloservaggregatesandclassifiesserviceinformationin adistributednetwork. Duetotheuseofdescriptionlogicontologies,GloServcanperformsemanticmatchingof queries to return results that are logically related to the user’s request, rather than searching only for exact information using attribute-value matching as current service discovery protocols do. Initially, the GloServ query matchmaking engine represents the query as a temporary class within the service ontology. This class is essentially a first order logic statementwhichhasanumberofitspropertiesrestricted. Thematchingenginethenuses an ontology reasoner to classify the temporary query class within the ontology. Service information within equivalent classes and subclasses are considered matches. Similar matchesareconsideredtobenon-disjointsiblingsoftheobjectpropertyvalueswithinthe query. Additionally, GloServ further refines the results obtained by combining both ontology- based querying with keyword matching. Since the service ontology may not capture all parts of a particular service, it allows each ontology to have a keyWords property which service providers can populate with keyword terms that describe the specifics of their service. Furthermore, GloServ allows querying of more than one service in a single query bysupportingsubqueryingbetweenitsservers,whichallowsservicesthatsharecommon properties tobe composedinto asingle query. This enhancementcauses fairlycomplicated queries to be issued in a single search such as the one given in the above example of searchingforarestaurantandanearbytheatre. We have built aprototype implementationof GloServ andthe resultshaveshownthat the underlying distributed architecture improves the query latency and load distribution of query and registration messages. Also, because GloServ uses an ontology to map a network,differentserviceclassesareaddedtothenetworkquiteeasilyasonlyanontology configuration file is needed for a service class to be generated and mapped to a network of servers. Furthermore, we have built a web-based front-end for a restaurant and theater servicesearchwhichdemonstratesthedifferentqueryingmethodsGloServallows. Contents ListofFigures x Acknowledgements xiv I Introduction and Background 1 1 Introduction 2 1.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.2 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.2.1 Location-BasedServices . . . . . . . . . . . . . . . . . . . . . . . 6 1.2.2 SocialNetworkingServices . . . . . . . . . . . . . . . . . . . . . 7 1.3 ProblemStatement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 1.4 Hypotheses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 1.5 Solutions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 1.5.1 Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 1.5.2 Contributions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 1.6 NovelComponents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 1.7 ThesisOutline . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 2 Ontologies 17 2.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 i 2.2 RDFandRDFSchema . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 2.2.1 Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 2.2.2 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2.3 OWL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 2.3.1 Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 2.3.2 Sublanguages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 2.3.3 OWLQuerying . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 2.3.4 OWLExamples . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 2.4 ConstructingOntologies . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 2.5 OntologySharing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 2.6 DifferencebetweenOntologiesandDatabases . . . . . . . . . . . . . . . . 30 3 Peer-to-PeerSystems 32 3.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 3.2 OverviewofPeer-to-PeerArchitectures . . . . . . . . . . . . . . . . . . . 33 3.3 ContentAddressableNetwork . . . . . . . . . . . . . . . . . . . . . . . . 34 3.4 Chord . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 3.5 Pastry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 3.6 Kademlia . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 3.7 UseofCANinGloServvs. OtherDHTs . . . . . . . . . . . . . . . . . . . 37 II GloServ Back-End Service Discovery Engine 40 4 NetworkArchitecture 41 4.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 4.2 HierarchicalNetwork . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 4.2.1 ElementswithinaGloServerinthehierarchicalnetwork . . . . . . 43 4.2.2 GeneratingtheHierarchicalNetwork . . . . . . . . . . . . . . . . 45 ii 4.2.3 ServerBootstrapping . . . . . . . . . . . . . . . . . . . . . . . . . 45 4.3 Peer-to-PeerNetwork . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 4.3.1 ElementswithinaP2PGloserver . . . . . . . . . . . . . . . . . . 49 4.3.2 OWLOntologyConstruction . . . . . . . . . . . . . . . . . . . . . 49 4.3.3 GeneratingCANOverlayNetworks . . . . . . . . . . . . . . . . . 52 4.4 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 4.4.1 OntologyGeneration . . . . . . . . . . . . . . . . . . . . . . . . . 61 4.4.2 CANNetworkGeneration . . . . . . . . . . . . . . . . . . . . . . 64 4.5 Contributions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 4.5.1 GenericNetworkArchitecture . . . . . . . . . . . . . . . . . . . . 67 4.5.2 DistributionofServiceData . . . . . . . . . . . . . . . . . . . . . 68 4.6 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 5 ServiceRegistration 69 5.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 5.2 UserServiceRegistration . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 5.2.1 Routing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 5.2.2 UserServiceRegistrationMessage . . . . . . . . . . . . . . . . . 72 5.3 InternalServiceRegistration . . . . . . . . . . . . . . . . . . . . . . . . . 73 5.3.1 Routing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74 5.3.2 InternalServiceRegistrationMessage . . . . . . . . . . . . . . . . 78 5.4 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 5.5 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 6 ServiceOntologyQuerying 84 6.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 6.2 UserQuerying . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 6.2.1 ExactUserQuery . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 iii 6.2.2 UserQuerywithSimilarityMatches . . . . . . . . . . . . . . . . . 86 6.2.3 UserQueryMessage . . . . . . . . . . . . . . . . . . . . . . . . . 87 6.3 InternalQuerying . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 6.3.1 InternalQueryRouting . . . . . . . . . . . . . . . . . . . . . . . . 89 6.3.2 InternalQueryMessage . . . . . . . . . . . . . . . . . . . . . . . 91 6.4 QueryParsing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 6.5 QueryResults . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 6.6 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 6.6.1 QueryRouting . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 6.6.2 QueryParsing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 6.7 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 7 ServiceInstances 97 7.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 7.2 OntologyModel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 7.2.1 RegisteringInstances . . . . . . . . . . . . . . . . . . . . . . . . . 97 7.2.2 QueryingInstances . . . . . . . . . . . . . . . . . . . . . . . . . . 99 7.3 DatabaseModel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 7.3.1 OntologytoDatabaseMapping . . . . . . . . . . . . . . . . . . . 100 7.3.2 RegisteringInstances . . . . . . . . . . . . . . . . . . . . . . . . . 101 7.3.3 QueryingInstances . . . . . . . . . . . . . . . . . . . . . . . . . . 103 7.4 Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 7.5 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 8 Evaluation 105 8.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 8.2 SetupofGloServ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 8.2.1 Ontology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 iv 8.2.2 System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 8.3 OntologyandQueryNotation . . . . . . . . . . . . . . . . . . . . . . . . 107 8.3.1 OntologyType . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 8.3.2 QueryType . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 8.4 DescriptionLogicReasonerType . . . . . . . . . . . . . . . . . . . . . . . 108 8.4.1 BenchmarkResults . . . . . . . . . . . . . . . . . . . . . . . . . . 108 8.4.2 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 8.5 QueryClassification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 8.5.1 OntologyType . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 8.5.2 MatchedClasses . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 8.5.3 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114 8.6 CANNetworkGeneration . . . . . . . . . . . . . . . . . . . . . . . . . . 114 8.7 QueryLatency . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 8.7.1 NewQueries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 8.7.2 CachedQueries . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 8.7.3 QueriesinOptimizedCAN . . . . . . . . . . . . . . . . . . . . . . 117 8.8 ServerLoad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 8.9 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120 III GloServ Query Extensions 121 9 CombiningMultipleServiceQueriesinaSingleSearch 122 9.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122 9.2 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 9.2.1 Location-basedServices . . . . . . . . . . . . . . . . . . . . . . . 123 9.2.2 ServiceTagging . . . . . . . . . . . . . . . . . . . . . . . . . . . 124 9.3 ProblemofCombinedServiceQueries . . . . . . . . . . . . . . . . . . . . 127 v

Description:
Ontology-based Service Discovery in a Globally Distributed Network Knarig Arabshian Advisor Henning Schulzrinne Submitted in partial fulfillment of the
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.