Skip to Content.
Sympa Menu

perfsonar-dev - Re: [pS-dev] Scheduler for CL-MP

Subject: perfsonar development work

List archive

Re: [pS-dev] Scheduler for CL-MP


Chronological Thread 
  • From: Guilherme Fernandes <>
  • To: perfsonar-dev <>
  • Subject: Re: [pS-dev] Scheduler for CL-MP
  • Date: Thu, 12 Apr 2007 18:19:12 -0300

Roman Lapacz wrote:


wrote:

Hi Guys,


Hi Guilherme

Hi Roman, sorry for the late response..


Before the release process started I was developing a cron-like scheduler for the CL-MP.


Did you take a look at the scheduler implemented by Maciej. It can be found in the base and, according to Maciej, it's generic and ready to be taken when scheduling is needed. He used it to implement LS registration and LS clean up stuff.

Yes, I had already looked at the code Maciej had implemented
(SimpleScheduler) before I started my implementation. To extend it would
be the same as making the actual component I made, but I didn't really
make it generic enough to be used by other services yet. I actually use
the SimpleScheduler to run the Cron Component every minute.

I just found the implementation Loukik developed of a more complex
Scheduler that uses a XML database, haven't looked at it yet though,
maybe it's similar to mine. Jeff had already pointed this out, but at
the time the work on the Cron component was already almost done.

The logical structure of the code is done, I now need to define the schemas for this communication. I have attached some examples of what I was thinking for the schemas, these are just sketches, I would really appreciate your opinions.

Some background: So CL-MP currently does on-demand measurements using command-line tools. This new component allows the CL-MP to schedule measurements using a structure very similar to unix cron. The user will request CL-MP to add the measurement he wants executed (in the requestCron.xml example it's an owamp measurement) and the scheduling information. The scheduled measurements will be identified by an entryId (these will be unique in some way).


I think the key could be the right element here. The service would return unique key to identify a measurement.

Yes, I agree we could use the key element in this case.


The measurements results are stored in a SQL MA. The user should be able to choose to which MA he wants the data sent.

In the examples I used different namespaces for each action, these could be put inside the same namespace 'cron' and identified by a 'action' parameter. I've initially put the MA IP address as an attribute of the <nmwg:messsage> element, I think this was suggested by Jeff before, but this isn't actually currently supported by the nmwg schema. So maybe it should go also as a parameter in the cron metadata.


I think the attribute in the message element is not a good place for MA's address. What if your request would have 2 sub-requests (2 data triggers) and results of them would have to be stored in separate MAs. I prefer to have it in some metadata element directly related with a measurement.

You're right, although it doesn't currently supports more than 1 request
in the same scheduler, this could be a wanted functionality in the future.

<nmwg:message type="MeasurementRequest" id="msg1"
ma="150.162.248.15:8080" xmlns:nmwg="http://ggf.org/ns/nmwg/base/2.0/";
xmlns:nmwgt="http://ggf.org/ns/nmwg/topology/2.0/";
xmlns:owamp="http://ggf.org/ns/nmwg/tools/owamp/2.0/";
xmlns:cron="http://ggf.org/ns/nmwg/tools/cron/modify/2.0/";>

<nmwg:metadata id="owamp">
<owamp:subject id="sub2">
<nmwgt:endPointPair>
<nmwgt:src type="ipv4" value="1.1.1.1" />
<nmwgt:dst type="ipv4" value="2.2.2.2" />
</nmwgt:endPointPair>
</owamp:subject>
<nmwg:eventType>http://ggf.org/ns/nmwg/tools/owamp/2.0</nmwg:eventType>
<owamp:parameters id="param2">
<nmwg:parameter name="direction">to</nmwg:parameter>
<nmwg:parameter name="count">5</nmwg:parameter>
<nmwg:parameter name="portRange">2500-2999</nmwg:parameter>
</owamp:parameters>
</nmwg:metadata>

<nmwg:metadata id="cron" metadataIdRef="owamp">


My understanding of nmwg chaining is that the metadataIdRef attribute in metadata element is used for base chaining. So only when we want to divide metadata block in order to reuse their parts. In this case if I decide that the metadata block with id="cron" will not be used elsewhere I could create one metadata element with contents of metadata id=owamp" and metadata id="cron". This of course would be wrong. That is why other chaining approach should be used:

This is exactly the type of thing I wanted to know, I don't really have
a deeper understanding of the nwmg schema, you're probably right. Maybe
someone else wants to comment on this? Jason, Jeff?

Thanks,

Guilherme


<nmwg:metadata id="cron">
<cron:subject id="iusub2" metadataIdRef="owamp"/>
<cron:parameters id="param1">
<nmwg:parameter name="minutes">20-30</nmwg:parameter>
<nmwg:parameter name="hours">*</nmwg:parameter>
<nmwg:parameter name="dom">*</nmwg:parameter>
<nmwg:parameter name="months">*</nmwg:parameter>
<nmwg:parameter name="dow">*</nmwg:parameter>
</cron:parameters>
<nmwg:eventType>
http://ggf.org/ns/nmwg/tools/cron/modify/2.0
</nmwg:eventType>
</nmwg:metadata>


Jason, Jeff, what's your view on this?



<nmwg:eventType>
http://ggf.org/ns/nmwg/tools/cron/modify/2.0
</nmwg:eventType>
<cron:parameters id="param1">
<!-- if entryId is missing, considered new entry -->
<nmwg:parameter name="entryId">1</nmwg:parameter> <nmwg:parameter name="minutes">20-30</nmwg:parameter>
<nmwg:parameter name="hours">*</nmwg:parameter>
<nmwg:parameter name="dom">*</nmwg:parameter>
<nmwg:parameter name="months">*</nmwg:parameter>
<nmwg:parameter name="dow">*</nmwg:parameter>
</cron:parameters>
</nmwg:metadata>

<nmwg:data id="data" metadataIdRef="cron" />

</nmwg:message>
------------------------------------------------------------------------

<nmwg:message type="MeasurementRequest" id="msg1"
xmlns:nmwg="http://ggf.org/ns/nmwg/base/2.0/";
xmlns:cron="http://ggf.org/ns/nmwg/tools/cron/list/2.0/";>

<nmwg:metadata id="meta1">
<schedule:subject id="sub1"></schedule:subject>
<nmwg:eventType>http://ggf.org/ns/nmwg/tools/cron/list/2.0</nmwg:eventType>
<cron:parameters id="param1">
<nmwg:parameter name="entries">all</nmwg:parameter>
</cron:parameters>
</nmwg:metadata>


As I wrote the idea of key could fit here


<nmwg:metadata id="meta1">
<nmwg:key>
<nmwg:parameters id="param1">
...
</nmwg:parameters>
</nmwg:key>
</nmwg:metadata>

<nmwg:data id="1" metadataIdRef="meta1" />





<nmwg:data id="1" metadataIdRef="meta1" />

</nmwg:message>
------------------------------------------------------------------------

<nmwg:message type="MeasurementRequest" id="msg1"
xmlns:nmwg="http://ggf.org/ns/nmwg/base/2.0/";
xmlns:cron="http://ggf.org/ns/nmwg/tools/cron/remove/2.0/";>

<nmwg:metadata id="meta1">
<nmwg:eventType>
http://ggf.org/ns/nmwg/tools/cron/remove/2.0
</nmwg:eventType>
<cron:parameters id="param1">
<nmwg:parameter name="entryID">1</nmwg:parameter>
</cron:parameters>
</nmwg:metadata>

<nmwg:data id="1" metadataIdRef="meta1" />

</nmwg:message>


The same here: key.



Roman






Archive powered by MHonArc 2.6.16.

Top of Page