Hi All, I was able to take the timestamp from the cartridge agent (WSO2CEPHealthStatisticsPublisher and WSO2CEPInFlightRequestPublisher) to CEP PayLoad definition.Git Hub commits can be found here[1], [2]. Currently working on sending the timestamp to the RDBMS without conflicting execution plans.
I have included the read-me [2] file to the cep extensions how to configure should happen for the Health Stat publishing to the RDBMS. [1]= https://github.com/apache/stratos/commit/4c65e705be822fd420b4e48ebafef789c8686b76 [2]= https://github.com/apache/stratos/commit/e09334cd98f245a4633c992f02db2878ac24d3d0 [3]= https://github.com/apache/stratos/commit/5ca895ef030f6aaeba56183d982aa5ae95db9337 Thank You! Best Regards, Ashan On Tue, Jul 7, 2015 at 1:13 PM, Lasantha Fernando <lasantha....@gmail.com> wrote: > Hi Ashan, > > Currently, you would not be able to get the timestamp out of the event > unless you use a databridge agent callback. In that case, you can use > Java code to simply get by calling event.getTimestamp(). > > However, if you want to use the timestamp as an attribute while doing > processing within CEP, you would have to pass the timestamp as an > attribute of the stream. i.e. add it as an attribute of either meta, > correlation or payload data. Then you can use that timestamp and > format the output event as necessary. > > Thanks, > Lasantha > > On Tue, Jul 7, 2015 at 1:04 PM, Ashan Dhananjaya <dhananjay...@gmail.com> > wrote: > > Hi All, > > > > I applied the above patch and get the timestamp in the Input Adapter. The > > formatter i used was "member_average_memory_consumption_stats:1.0.0". I > > tried several time to get the timeStamp attribute but failed. Is there > any > > way to get a data which is outside in the payload? The Input stream is as > > below, > > > > 10:40:27,757 [-] [DataBridge-Core-pool-2-thread-1] INFO TenantId=-1234 : > > Input Event Adaptor : DefaultWSO2EventInputAdaptor, received > > > > Event{ > > streamId='cartridge_agent_health_stats:1.0.0', > > timeStamp=1436245827731, > > metaData=null, > > correlationData=null, > > payloadData=[single-cartridge-app.my-php.php.domain, > > single-cartridge-app-1, network-partition-1, > > > single-cartridge-app.my-php.php.domaina5598e2b-995f-4620-b652-e66341e24c99, > > partition-1, memory_consumption, 20.0], > > arbitraryDataMap={}, > > } > > > > Any help will be really appreciated. > > > > Thank You! > > Best Regards, > > Ashan > > > > On Tue, Jul 7, 2015 at 9:32 AM, Chamila De Alwis <chami...@wso2.com> > wrote: > >> > >> Hi Ashan, > >> > >> As I've seen from the PCA testing recently, the timestamp is added to > >> every ThriftEvent before publishing. Are you working on PCA or the Mock > >> IaaS? I took a look at the Mock IaaS and the WSO2CEPStatisticsPublisher > as > >> well, and found out that the latter indeed doesn't add the timestamp to > the > >> ThriftEvents. This means that the JCA also publishes Thrift Events with > >> empty timestamp fields. > >> > >> Following is the simple fix for that. I've attached the patch herewith. > >> Could you quickly verify with the patch applied build also? > >> > >> chamilad@chamilad-ThinkPad-T530:~/dev/stratos[master *]$ git diff > >> diff --git > >> > a/components/org.apache.stratos.common/src/main/java/org/apache/stratos/common/statistics/publisher/wso2/cep/WSO2CEPStatisticsPublisher.java > >> b/c > >> index 653288d..f1fe426 100644 > >> --- > >> > a/components/org.apache.stratos.common/src/main/java/org/apache/stratos/common/statistics/publisher/wso2/cep/WSO2CEPStatisticsPublisher.java > >> +++ > >> > b/components/org.apache.stratos.common/src/main/java/org/apache/stratos/common/statistics/publisher/wso2/cep/WSO2CEPStatisticsPublisher.java > >> @@ -29,6 +29,7 @@ import > >> org.wso2.carbon.databridge.agent.thrift.exception.AgentException; > >> import org.wso2.carbon.databridge.commons.Event; > >> import org.wso2.carbon.databridge.commons.StreamDefinition; > >> > >> +import java.util.Date; > >> import java.util.HashMap; > >> > >> /** > >> @@ -98,6 +99,7 @@ public class WSO2CEPStatisticsPublisher implements > >> StatisticsPublisher { > >> > >> Event event = new Event(); > >> event.setPayloadData(payload); > >> + event.setTimeStamp(new Date().getTime()); > >> event.setArbitraryDataMap(new HashMap<String, String>()); > >> > >> try { > >> > >> > >> > >> > >> > >> Regards, > >> Chamila de Alwis > >> Committer and PMC Member - Apache Stratos > >> Software Engineer | WSO2 | +94772207163 > >> Blog: code.chamiladealwis.com > >> > >> > > >
_______________________________________________ Dev mailing list Dev@wso2.org http://wso2.org/cgi-bin/mailman/listinfo/dev