Anchor | ||||
---|---|---|---|---|
|
Tip | ||
---|---|---|
| ||
It's simple! Learn to create customized Mathematical Function/Action in InSights Inference on this page. |
In order to run create a new Mathematical Function/Action in InSights Inference, there are changes that should be made in list of files shown on this page. Please adhere the following instructions, and make respective changes -
Panel | |
---|---|
On this page:
|
Info |
---|
%WORKSPACE% is the directory which contains InSights - Development Platform. |
Changes in ConfigAttributes.java
Browse the directory - "%WORKSPACE%\Insights\PlatformInsights\src\main\java\com\cognizant\devops\platforminsights\core\enums\ConfigAttributes.java"
Add the changes in ConfigAttributes.java as highlighted in Red in the below panel.
Panel | ||||
---|---|---|---|---|
| ||||
package com.cognizant.devops.platformcommons.core.enums; public enum ExecutionActions { AVERAGE, COUNT, MINMAX, (Add your new Mathematical Function/Action Name here) } |
Writing Java code for Custom Mathematical Function/Action
- Create a new package under "%WORKSPACE%\Insights\PlatformInsights\src\main\java". Use "com.cognizant.devops.platforminsights.core" as base, then append your custom package structure.
- Import "ConfigConstants.java" from the package, and use the constants specified there to code the Mathematical Function/Action.
Panel | ||||
---|---|---|---|---|
| ||||
package com.cognizant.devops.platforminsights.configs; public interface ConfigConstants { String APP_NAME = ApplicationConfigProvider.getInstance().getSparkConfigurations().getAppName(); String MASTER = ApplicationConfigProvider.getInstance().getSparkConfigurations().getMaster(); String SPARK_EXECUTOR_MEMORY = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkExecutorMemory(); String SPARK_ES_HOST = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchHost(); String SPARK_ES_PORT = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchPort(); String SPARK_ES_CONFIGINDEX = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchConfigIndex(); String SPARK_ES_RESULTINDEX = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchResultIndex(); String KPISIZE = ApplicationConfigProvider.getInstance().getSparkConfigurations().getKpiSize(); Long SPARK_RESULT_SINCE = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkResultSince(); String SPARK_TIMEZONE = ApplicationConfigProvider.getInstance().getInsightsTimeZone(); } |
Changes in SparkJobExecutor.java
Browse the directory - "%WORKSPACE%\Insights\PlatformInsights\src\main\java\com\cognizant\devops\platforminsights\core\SparkJobExecutor.java"
Add the changes in ConfigAttributes.java as highlighted in Red in the below panel.
Panel | ||||
---|---|---|---|---|
| ||||
package com.cognizant.devops.platforminsights.core; public enum SparkJobExecutor implements Job,Serializable{ ... ... ... private void executeJob(SparkJobConfiguration job) throws InsightsSparkJobFailedException{ KPIDefinition kpiDefinition = job.getKpiDefinition(job.getKpiDefinition()); if(ExecutionActions.AVERAGE == kpiDefinition.getAction()){ log.debug("KPI action found as AVERAGE"); BaseActionImpl impl = new AverageActionImpl(kpiDefinition); impl.execute(); } else if(ExecutionActions.COUNT == kpiDefinition.getAction()){ log.debug("KPI action found as COUNT"); BaseActionImpl impl = new CountActionImpl(kpiDefinition); impl.execute(); } else if(ExecutionActions.MINMAX == kpiDefinition.getAction()){ log.debug("KPI action found as MINMAX"); BaseActionImpl impl = new MinMaxActionImpl(kpiDefinition); impl.execute(); } //(Instance of a Custom Mathematical Function/Action) else if(ExecutionActions.YourCustomActionName == kpiDefinition.getAction()){ log.debug("KPI action found as Your Custom Action name"); BaseActionImpl impl = new YourCustomActionImplementationClassName(kpiDefinition); impl.execute(); } } ... ... ... } |