Presentation is loading. Please wait.

Presentation is loading. Please wait.

Building Services in WSRF Ben Clifford GGF Summer School July 2004.

Similar presentations


Presentation on theme: "Building Services in WSRF Ben Clifford GGF Summer School July 2004."— Presentation transcript:

1 Building Services in WSRF Ben Clifford GGF Summer School July 2004

2 TODOs l This should be a hidden slide l Modify RP exercise to use Query not GMRP l Interop slide l 2 hours exercise = 60 slides = 15 slides per module

3 Module 1 l Overview l WSRF l Globus Alliance WSRF implementation

4 Overview l 4 modules l Each module has: u Slides & talk u Hands on l Covers: u WSRF specification u Globus Alliance implementation of WSRF

5 History and Motivation (1) l Often we think we want standard APIs u Eg. MPI l But on the grid, we actually want standard wire protocols u the API can be different on each system

6 History and Motivation (2) l Open Grid Services Infrastructure (OGSI) l GGF standard l Identified a number of common ‘building blocks’ used in grid protocols u Inspecting state, creating and removing state, detecting changes in state, naming state l Defined standard ways to do these things, based on web services (defined a thing called a Grid Service)

7 History and Motivation (3) l But then… l Realised that this was useful for web services in general, not just for the grid. l Moved out of GGF, into OASIS l Split the single OGSI specification into a number of other specifications called WSRF.

8 WSRF WSRF is a framework consisting of a number of specifications. l WS-Resource Properties * l WS-Resource Lifetime * l WS-Service Groups l WS-Notification l WS-BaseFaults l WS-Renewable References (unpublished) Other WS specifications such as: l WS-Addressing * * will be talked about in this tutorial

9 How WS-RF fits in with other standards, specifications and protocols. Internet protocols Web services WSRF Grid stuff Globus (GRAM, MDS) WSDL, SOAP HTTP, TCP/IP

10 WS-Resources l Web services often provide access to state u Job submissions, databases l A WS-Resource is standard way of representing that state. l In this tutorial, we will be using ‘counter’ resources which are simple accumulators.

11 WS-Resources l WSRF specifications provide: u XML-based Resource Properties u Lifetime management (creation/destruction) of resources u Servicegroups, which group together WS- Resources u Notification l (for example of changes in resource properties) u Faults u Renewable References

12 Examples of WS-Resources l Files on a file server l Rows in a database l Jobs in a job submission system l Accounts in a bank

13 Web service

14 Web service with WS-Resource

15 Web Service with WS-Resources

16 WS-Resources

17 GT WSRF core l Container u Hosts services u Built on top of Apache Axis l Clients u Interact with services l Build tools u For writing new services u Based around Apache Ant

18 Files used in the exercise l WSDL and XML Schema: u counter_port_type.wsdl l Java u Several Java source files l Deployment information u deploy-server.wsdd u deploy-jndi-config.xml l Build.xml u Tells Ant how to build and deploy the code

19 Notes on the exercises l Read notes.txt for information on each exercise. l Only do one exercise at a time, then wait for next module. l Each exercise consists of uncommenting code fragments. However, you should READ AND UNDERSTAND what you are uncommenting. l If you are brave, you can make your own extra changes too – but be careful not to break anything!

20 Exercise 1 l Exercise: stand up supplied installation and check it works. l Install software l Start the container  this will have a counter service and one counter resource. l Interact with the counter resource l Do the exercise now.

21 C Exercise 1 overview One host (your own machine) One web service running on own machine One counter resource, which will already exist Client running on own machine Counter service One counter resource Container Client

22 C Exercise 1 overview Counter service One counter resource Container globus-start-container Starts up container, with counter service and a single counter resource.

23 C Exercise 1 overview Counter service One counter resource Container Client show-counter and increment-counter clients interact with the resource through the web service.

24 C Exercise 1 overview Client increment-counter invokes the add operation in counter_port_type.wsdl add(1)

25 Module 2 – Resource Addressing l Endpoint References

26 Why? l Need some way to refer to web services and WS-Resources from anywhere on the network.

27 Endpoint References l WS-Addressing specification l An Endpoint Reference (EPR) points to a web service by including a URL.

28 Endpoint References l WS-Addressing specification l An Endpoint Reference (EPR) points to a web service by including a URL. <EPR xsi:type="ns2:EndpointReferenceType" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ns2="http://schemas.xmlsoap.org/ws/2004/03/addressing”> http://localhost:8080/wsrf/services/CounterService

29 Endpoint References l WS-Addressing specification l An Endpoint Reference (EPR) points to a web service by including a URL. l EPRs can also contain extra information l For WSRF, can include ReferenceProperties that identify a resource – will see this later on.

30 Endpoint References l WS-Addressing specification l An Endpoint Reference (EPR) points to a web service by including a URL. l EPRs can also contain extra information l For WSRF, can include ReferenceProperties that identify a resource – will see this later on. l Can also contain other information u Security u Renewable Refence information

31 Client code fragment CounterServiceAddressingLocator locator = new CounterServiceAddressingLocator(); EndpointReferenceType endpoint; endpoint = EPRUtils.loadEPR(args); CounterPortType counterPort = locator.getCounterPortTypePort(endpoint); counterPort.add(1);

32 Automatically Generated types CounterServiceAddressingLocator locator = new CounterServiceAddressingLocator(); EndpointReferenceType endpoint; endpoint = EPRUtils.loadEPR(args); CounterPortType counterPort = locator.getCounterPortTypePort(endpoint); counterPort.add(1); Highlighted types are generated by the build system automatically, based on XSD and WSDL.

33 *AddressingLocator l Every WSDL service has a corresponding AddressingLocator Java class automatically generated. l For the CounterService, we get: u CounterServiceAddressingLocator l An AddressingLocator knows how to take an EPR and return a java stub for the remote service: u CounterPortType counterPort = locator.getCounterPortTypePort(endpoint);

34 *PortType l Every port type has a PortType Java interface automatically generated. l For the counter port type, we have u CounterPortType l The interface has a method for each operation on the port type: u counterPort.add(1);

35 Exercise 2 l Talk to someone else’s service on a different laptop l Modify clients to read an EPR file l Should be able to run the clients against any machine in the room. l Do the exercise now.

36 Exercise 2 scenario Two hosts (your own machine and your friend’s machine) One web service running on friend’s machine One counter resource on friend’s machine Client running on your own machine

37 Exercise 2 scenario Client can talk to everyone’s servers – so the situation in this room looks more like this.

38 Module 3 – Resource Properties l Resources have Resource Properties l Defined in XML l Resource Properties document in portType l Querying Resource Properties

39 Why? l Resources represent state l Often we want to inspect that state l In this tutorial, we want to know the value stored in each counter u show-counter client

40 XML based l Each resource has a Resource Properties document. l Defined in XML schema l Each element in the Resource Properties document is a Resource Property (RP).

41 Ways to access RPs l Pull u Client can query the RP document l GetResourceProperty l GetMultipleResourceProperties l QueryResourceProperties l Push u Allows services to send changes in their resources’ RPs to interested parties. l WS-Notification l Not covered in this tutorial

42 Pull operations l GetResourceProperty u Requests a single resource property by name l GetMultipleResourceProperties u Requests several resource properties (from the same resource) by name l QueryResourceProperties u More advanced queries against RP document. u eg. XPath

43 Counter example The counter service’s Resource Property Document is defined in schema/core/samples/counter/counter_port_type.wsdl l <xsd:element ref="tns:Value" minOccurs="1" maxOccurs="1"/>

44 Operation Providers l WSRF Core allows operations to be implemented by Operation Providers. l Service writers can include these in WSDD, rather than writing Java code. l Exercise will involve adding operation provider to support QueryResourceProperties operation

45 Exercise 3 l Exercise: add a resource property to the service to give ‘last incremented time’. New client to query this RP. l Query own counters and query other peoples’ counters. l Do the exercise now.

46 Module 4 – Resource Lifetime l Creating new resources l Destroying old resources l Soft-state lifetime management

47 Why? l Resources come and go l For example: u jobs in a batch submission system could be represented as resources u submitting a new job causes a new resource to be created u when the job is completed, the resource goes away

48 Creating new resources l Factory pattern l A web service operation causes a new resource to come into existence. l For example, in job submission: u submit(JobDescription)

49 Destroying resources l Two ways: u Immediate Destruction u Scheduled Destruction

50 Immediate destruction l Destroy the resource now! Destroy operation

51 Scheduled Destruction l Scheduled destruction allows soft management of state. TerminationTime RP Keep state alive for as long as we need it, by calling SetTerminationTime operation periodically.

52 Scheduled Destruction l Remote service is ‘self-cleaning’ u old unwanted state gets cleaned up automatically if no-one keeps it alive l Problem: if interested party is disconnected from network for a long time, then it cannot extend lifetime and state may be cleaned up prematurely.

53 EPRs with ReferenceProperties l If there are several counters accessible through a service, we need some way to tell them apart when making calls. l Add ReferenceProperties to EPR with a key that identifies counter.

54 EPRs with ReferenceProperties <EPR xsi:type="ns2:EndpointReferenceType" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ns2="http://schemas.xmlsoap.org/ws/2004/03/addressing"> http://localhost:8080/wsrf/services/CounterService 42 l Note that the CounterKey field is meaningless to everyone apart from the service.

55 EPRs with ReferenceProperties <EPR xsi:type="ns2:EndpointReferenceType" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ns2="http://schemas.xmlsoap.org/ws/2004/03/addressing"> http://localhost:8080/wsrf/services/CounterService 42 l Note that the CounterKey field is meaningless to everyone apart from the service.

56 EPRs with ReferenceProperties <EPR xsi:type="ns2:EndpointReferenceType" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ns2="http://schemas.xmlsoap.org/ws/2004/03/addressing"> http://localhost:8080/wsrf/services/CounterService 42 l Note that the CounterKey field is meaningless to everyone apart from the service.

57 Resource Homes l Resource Homes map from key in EPR to a resource object l So far, CounterService has used SingletonResorceHome. u Always returns the same single resource u So CounterService only provides access to one resource u No key needed in EPR l Will now use ResourceHomeImpl u Allows creation of new resource objects u Maps from key in EPR to resource objects u Counter service will provide access to many resource objects

58 Exercise 4 l Exercise: create new counters. Destroy old counters. l Two new clients: u create-counter u destroy-counter

59 Exercise 4 scenario Created new counters Destroyed existing counters

60 The rest of WSRF l WS-Resource Properties l WS-Resource Lifetime l WS-Servicegroups l WS-BaseFaults l WS-Renewable References l WS-Notification

61 WS-ServiceGroups l Form groups of services and/or resources l Represent those groups as Resources. l Registries etc

62 WS-BaseFaults l Standard datatype for transmitting webservice faults u Originator u Timestamp u Etc…

63 WS-Renewable References l EPRs can become stale u Service might move to a different host l Renewable References provide a way to take a stale reference and try to a fresh one.

64 WS-Notification l A group of 3 standards l Deliver notifications of events l For example, change in value of a resource property l Started as one WSRF standard, but split off into three separate standards.

65 Fin


Download ppt "Building Services in WSRF Ben Clifford GGF Summer School July 2004."

Similar presentations


Ads by Google