use of org.apache.apex.malhar.lib.util.DimensionTimeBucketSumOperator in project apex-malhar by apache.
the class Application method getApacheDimensionTimeBucketSumOperator.
public DimensionTimeBucketSumOperator getApacheDimensionTimeBucketSumOperator(String name, DAG dag) {
DimensionTimeBucketSumOperator oper = dag.addOperator(name, DimensionTimeBucketSumOperator.class);
// 0
oper.addDimensionKeyName(APACHE_KEYS.host.value);
// 1
oper.addDimensionKeyName(APACHE_KEYS.clientip.value);
// 2 url
oper.addDimensionKeyName(APACHE_KEYS.request.value);
// 3
oper.addDimensionKeyName(APACHE_KEYS.response.value);
// 4
oper.addDimensionKeyName(APACHE_KEYS.referrer.value);
// 5
oper.addDimensionKeyName(APACHE_KEYS.country_name.value);
// 6
oper.addDimensionKeyName(APACHE_KEYS.os.value);
// 7 browser
oper.addDimensionKeyName(APACHE_KEYS.browser_name.value);
oper.addValueKeyName(APACHE_KEYS.bytes.value);
// dimension set # 1
// url
Set<String> dimensionKey1 = new HashSet<String>();
dimensionKey1.add(APACHE_KEYS.request.value);
// dimension set # 2
// ip
Set<String> dimensionKey2 = new HashSet<String>();
dimensionKey2.add(APACHE_KEYS.clientip.value);
// dimension set # 3
// url, ip
Set<String> dimensionKey3 = new HashSet<String>();
dimensionKey3.add(APACHE_KEYS.clientip.value);
dimensionKey3.add(APACHE_KEYS.request.value);
// dimension set # 4
// country, os, browser
Set<String> dimensionKey4 = new HashSet<String>();
dimensionKey4.add(APACHE_KEYS.country_name.value);
dimensionKey4.add(APACHE_KEYS.os.value);
dimensionKey4.add(APACHE_KEYS.browser_name.value);
// dimension set # 5
// country, url --> sum of bytes
Set<String> dimensionKey5 = new HashSet<String>();
dimensionKey5.add(APACHE_KEYS.request.value);
dimensionKey5.add(APACHE_KEYS.country_name.value);
// dimension set # 6
// os, browser --> sum of bytes
Set<String> dimensionKey6 = new HashSet<String>();
dimensionKey6.add(APACHE_KEYS.os.value);
dimensionKey6.add(APACHE_KEYS.browser_name.value);
// dimension set # 7
// os
Set<String> dimensionKey7 = new HashSet<String>();
dimensionKey7.add(APACHE_KEYS.os.value);
// dimension set # 8
// browser
Set<String> dimensionKey8 = new HashSet<String>();
dimensionKey8.add(APACHE_KEYS.browser_name.value);
// dimension set # 9
// host
Set<String> dimensionKey9 = new HashSet<String>();
dimensionKey9.add(APACHE_KEYS.host.value);
// dimension set # 10
// request, response
Set<String> dimensionKey10 = new HashSet<String>();
dimensionKey10.add(APACHE_KEYS.request.value);
dimensionKey10.add(APACHE_KEYS.response.value);
// dimension set # 11
// host, response
Set<String> dimensionKey11 = new HashSet<String>();
dimensionKey11.add(APACHE_KEYS.host.value);
dimensionKey11.add(APACHE_KEYS.response.value);
// dimension set # 12
// host, response
Set<String> dimensionKey12 = new HashSet<String>();
dimensionKey12.add(APACHE_KEYS.response.value);
try {
oper.addCombination(dimensionKey1);
oper.addCombination(dimensionKey2);
oper.addCombination(dimensionKey3);
oper.addCombination(dimensionKey4);
oper.addCombination(dimensionKey5);
oper.addCombination(dimensionKey6);
oper.addCombination(dimensionKey7);
oper.addCombination(dimensionKey8);
oper.addCombination(dimensionKey9);
oper.addCombination(dimensionKey10);
oper.addCombination(dimensionKey11);
oper.addCombination(dimensionKey12);
} catch (NoSuchFieldException e) {
throw new RuntimeException("Exception while while adding operator " + name, e);
}
oper.setTimeBucketFlags(AbstractDimensionTimeBucketOperator.TIMEBUCKET_MINUTE);
return oper;
}
use of org.apache.apex.malhar.lib.util.DimensionTimeBucketSumOperator in project apex-malhar by apache.
the class Application method populateDAG.
@Override
public void populateDAG(DAG dag, Configuration conf) {
// set app name
dag.setAttribute(DAG.APPLICATION_NAME, "Logstream Application");
dag.setAttribute(DAG.STREAMING_WINDOW_SIZE_MILLIS, 1000);
ConsoleOutputOperator mysqlConsole = dag.addOperator("MysqlConsole", ConsoleOutputOperator.class);
ConsoleOutputOperator syslogConsole = dag.addOperator("SyslogConsole", ConsoleOutputOperator.class);
ConsoleOutputOperator systemConsole = dag.addOperator("SystemlogConsole", ConsoleOutputOperator.class);
LogScoreOperator logScoreOperator = dag.addOperator("logscore", new LogScoreOperator());
/*
* Read log file messages from a messaging system (Redis, RabbitMQ, etc)
* Typically one message equates to a single line in a log file, but in
* some cases may be multiple lines such as java stack trace, etc.
*/
// Get logs from RabbitMQ
RabbitMQLogsInputOperator apacheLogInput = dag.addOperator("ApacheLogInput", RabbitMQLogsInputOperator.class);
RabbitMQLogsInputOperator mysqlLogInput = dag.addOperator("MysqlLogInput", RabbitMQLogsInputOperator.class);
RabbitMQLogsInputOperator syslogLogInput = dag.addOperator("SyslogLogInput", RabbitMQLogsInputOperator.class);
RabbitMQLogsInputOperator systemLogInput = dag.addOperator("SystemLogInput", RabbitMQLogsInputOperator.class);
/*
* Convert incoming JSON structures to flattened map objects
*/
JsonByteArrayOperator apacheLogJsonToMap = dag.addOperator("ApacheLogJsonToMap", JsonByteArrayOperator.class);
dag.addStream("apache_convert_type", apacheLogInput.outputPort, apacheLogJsonToMap.input);
JsonByteArrayOperator mysqlLogJsonToMap = dag.addOperator("MysqlLogJsonToMap", JsonByteArrayOperator.class);
dag.addStream("mysql_convert_type", mysqlLogInput.outputPort, mysqlLogJsonToMap.input);
JsonByteArrayOperator syslogLogJsonToMap = dag.addOperator("SyslogLogJsonToMap", JsonByteArrayOperator.class);
dag.addStream("syslog_convert_type", syslogLogInput.outputPort, syslogLogJsonToMap.input);
JsonByteArrayOperator systemLogJsonToMap = dag.addOperator("SystemLogJsonToMap", JsonByteArrayOperator.class);
dag.addStream("system_convert_type", systemLogInput.outputPort, systemLogJsonToMap.input);
// operator for tuple counter
Counter apacheLogCounter = dag.addOperator("ApacheLogCounter", new Counter());
/*
* operators for sum of bytes
*/
SumItemFromMapOperator<String, Object> apacheLogBytesSum = dag.addOperator("ApacheLogBytesSum", new SumItemFromMapOperator<String, Object>());
apacheLogBytesSum.setSumDimension("bytes");
/*
* opeartor filter 404 logs
*/
SelectOperator filter404 = getFilteredMessagesOperator("Filter404", dag);
/*
* Explode dimensions based on log types ( apache, mysql, syslog, etc)
*/
DimensionTimeBucketSumOperator apacheDimensionOperator = getApacheDimensionTimeBucketSumOperator("ApacheLogDimension", dag);
DimensionTimeBucketSumOperator apacheFilteredDimensionOperator = getFilteredApacheDimensionTimeBucketSumOperator("ApacheFilteredLogDimension", dag);
dag.addStream("apache_dimension_in", apacheLogJsonToMap.outputFlatMap, apacheDimensionOperator.in, apacheLogCounter.input, apacheLogBytesSum.mapInput, filter404.inport);
dag.addStream("apache_filtered_dimension_in", filter404.outport, apacheFilteredDimensionOperator.in);
DimensionTimeBucketSumOperator mysqlDimensionOperator = getMysqlDimensionTimeBucketSumOperator("MysqlLogDimension", dag);
dag.addStream("mysql_dimension_in", mysqlLogJsonToMap.outputFlatMap, mysqlDimensionOperator.in);
DimensionTimeBucketSumOperator syslogDimensionOperator = getSyslogDimensionTimeBucketSumOperator("syslogLogDimension", dag);
dag.addStream("syslog_dimension_in", syslogLogJsonToMap.outputFlatMap, syslogDimensionOperator.in);
// DimensionTimeBucketSumOperator systemDimensionOperator = getSystemDimensionTimeBucketSumOperator("systemLogDimension", dag);
// dag.addStream("system_dimension_in", systemLogJsonToMap.outputMap, systemDimensionOperator.in);
/*
* Calculate average, min, max, etc from dimensions ( based on log types )
*/
// aggregating over sliding window
MultiWindowDimensionAggregation apacheMultiWindowAggCountOpr = getApacheAggregationCountOper("apache_sliding_window_count", dag);
MultiWindowDimensionAggregation apacheMultiWindowAggSumOpr = getApacheAggregationSumOper("apache_sliding_window_sum", dag);
dag.addStream("apache_dimension_out", apacheDimensionOperator.out, apacheMultiWindowAggCountOpr.data, apacheMultiWindowAggSumOpr.data);
MultiWindowDimensionAggregation apacheFilteredMultiWindowAggCountOpr = getFilteredApacheAggregationCountOper("apache_filtered_sliding_window_count", dag);
dag.addStream("apache_filtered_dimension_out", apacheFilteredDimensionOperator.out, apacheFilteredMultiWindowAggCountOpr.data);
MultiWindowDimensionAggregation mysqlMultiWindowAggOpr = getMysqlAggregationOper("mysql_sliding_window", dag);
dag.addStream("mysql_dimension_out", mysqlDimensionOperator.out, mysqlMultiWindowAggOpr.data);
MultiWindowDimensionAggregation syslogMultiWindowAggOpr = getSyslogAggregationOper("syslog_sliding_window", dag);
dag.addStream("syslog_dimension_out", syslogDimensionOperator.out, syslogMultiWindowAggOpr.data);
// MultiWindowDimensionAggregation systemMultiWindowAggOpr = getSystemAggregationOper("system_sliding_window", dag);
// dag.addStream("system_dimension_out", systemDimensionOperator.out, systemMultiWindowAggOpr.data);
// adding top N operator
TopN<String, DimensionObject<String>> apacheTopNCountOpr = dag.addOperator("apache_topN_count", new TopN<String, DimensionObject<String>>());
apacheTopNCountOpr.setN(10);
TopN<String, DimensionObject<String>> apacheFilteredTopNCountOpr = dag.addOperator("apache_filtered_topN_count", new TopN<String, DimensionObject<String>>());
apacheFilteredTopNCountOpr.setN(10);
TopN<String, DimensionObject<String>> apacheTopNSumOpr = dag.addOperator("apache_topN_sum", new TopN<String, DimensionObject<String>>());
apacheTopNSumOpr.setN(10);
TopN<String, DimensionObject<String>> mysqlTopNOpr = dag.addOperator("mysql_topN", new TopN<String, DimensionObject<String>>());
mysqlTopNOpr.setN(5);
TopN<String, DimensionObject<String>> syslogTopNOpr = dag.addOperator("syslog_topN", new TopN<String, DimensionObject<String>>());
syslogTopNOpr.setN(5);
// TopN<String, DimensionObject<String>> systemTopNOpr = dag.addOperator("system_topN", new TopN<String, DimensionObject<String>>());
// systemTopNOpr.setN(5);
/*
* Analytics Engine
*/
dag.addStream("ApacheLogScoreCount", apacheMultiWindowAggCountOpr.output, apacheTopNCountOpr.data, logScoreOperator.apacheLogs);
dag.addStream("ApacheFilteredLogScoreCount", apacheFilteredMultiWindowAggCountOpr.output, apacheFilteredTopNCountOpr.data);
dag.addStream("ApacheLogScoreSum", apacheMultiWindowAggSumOpr.output, apacheTopNSumOpr.data);
dag.addStream("MysqlLogScore", mysqlMultiWindowAggOpr.output, mysqlTopNOpr.data, logScoreOperator.mysqlLogs);
dag.addStream("SyslogLogScore", syslogMultiWindowAggOpr.output, syslogTopNOpr.data, logScoreOperator.syslogLogs);
// dag.addStream("SystemLogScore", systemLogJsonToMap.outputMap, logScoreOperator.systemLogs);
/*
* Alerts
*/
// TODO
/*
* Console output for debugging purposes
*/
// ConsoleOutputOperator console = dag.addOperator("console", ConsoleOutputOperator.class);
// dag.addStream("topn_output", apacheTopNOpr.top);entry.getValue()
/*
* write to redis for siteops
*/
// prepare operators to convert output streams to redis output format
AggregationsToRedisOperator<Integer, Integer> apacheLogCounterToRedis = dag.addOperator("ApacheLogCounterToRedis", new AggregationsToRedisOperator<Integer, Integer>());
apacheLogCounterToRedis.setKeyIndex(11);
AggregationsToRedisOperator<String, String> apacheLogBytesSumToRedis = dag.addOperator("ApacheLogBytesSumToRedis", new AggregationsToRedisOperator<String, String>());
apacheLogBytesSumToRedis.setKeyIndex(9);
AggregationsToRedisOperator<String, DimensionObject<String>> topNCountToRedis = getApacheTopNToRedisOperatorCountAggregation("topNCountToRedis", dag);
AggregationsToRedisOperator<String, DimensionObject<String>> filteredTopNCountToRedis = getFilteredApacheTopNToRedisOperatorCountAggregation("filteredTopNCountToRedis", dag);
AggregationsToRedisOperator<String, DimensionObject<String>> topNSumToRedis = getApacheTopNToRedisOperatorSumAggregation("topNSumToRedis", dag);
// convert ouputs for redis output operator and send output to web socket output
dag.addStream("apache_log_counter", apacheLogCounter.output, apacheLogCounterToRedis.valueInput);
dag.addStream("apache_log_bytes_sum", apacheLogBytesSum.output, apacheLogBytesSumToRedis.valueInput);
dag.addStream("topn_redis_count", apacheTopNCountOpr.top, topNCountToRedis.multiWindowDimensionInput, wsOutput(dag, "apacheTopAggrs"));
dag.addStream("topn_redis_sum", apacheTopNSumOpr.top, topNSumToRedis.multiWindowDimensionInput, wsOutput(dag, "apacheTopSumAggrs"));
dag.addStream("filtered_topn_redis_count", apacheFilteredTopNCountOpr.top, filteredTopNCountToRedis.multiWindowDimensionInput);
// redis output operators
RedisKeyValPairOutputOperator<String, String> redisOutTotalCount = dag.addOperator("RedisOutTotalCount", new RedisKeyValPairOutputOperator<String, String>());
redisOutTotalCount.getStore().setDbIndex(15);
RedisKeyValPairOutputOperator<String, String> redisOutTotalSumBytes = dag.addOperator("RedisOutTotalSumBytes", new RedisKeyValPairOutputOperator<String, String>());
redisOutTotalSumBytes.getStore().setDbIndex(15);
RedisMapOutputOperator<String, String> redisOutTopNCount = dag.addOperator("RedisOutTopNCount", new RedisMapOutputOperator<String, String>());
redisOutTopNCount.getStore().setDbIndex(15);
RedisMapOutputOperator<String, String> redisOutTopNSum = dag.addOperator("RedisOutTopNSum", new RedisMapOutputOperator<String, String>());
redisOutTopNSum.getStore().setDbIndex(15);
RedisMapOutputOperator<String, String> redisOutFilteredTopNSum = dag.addOperator("RedisOutFilteredTopNSum", new RedisMapOutputOperator<String, String>());
redisOutFilteredTopNSum.getStore().setDbIndex(15);
// redis output streams
dag.addStream("apache_log_counter_to_redis", apacheLogCounterToRedis.keyValPairOutput, redisOutTotalCount.input);
dag.addStream("apache_log_bytes_sum_to_redis", apacheLogBytesSumToRedis.keyValPairOutput, redisOutTotalSumBytes.input);
dag.addStream("apache_log_dimension_counter_to_redis", topNCountToRedis.keyValueMapOutput, redisOutTopNCount.input);
dag.addStream("apache_log_dimension_sum_to_redis", topNSumToRedis.keyValueMapOutput, redisOutTopNSum.input);
dag.addStream("apache_log_filtered_dimension_count_to_redis", filteredTopNCountToRedis.keyValueMapOutput, redisOutFilteredTopNSum.input);
/*
* Websocket output to UI from calculated aggregations
*/
dag.addStream("MysqlTopAggregations", mysqlTopNOpr.top, wsOutput(dag, "mysqlTopAggrs"), mysqlConsole.input);
dag.addStream("SyslogTopAggregations", syslogTopNOpr.top, wsOutput(dag, "syslogTopAggrs"), syslogConsole.input);
dag.addStream("SystemData", systemLogJsonToMap.outputMap, wsOutput(dag, "systemData"), logScoreOperator.systemLogs, systemConsole.input);
}
use of org.apache.apex.malhar.lib.util.DimensionTimeBucketSumOperator in project apex-malhar by apache.
the class Application method getSystemDimensionTimeBucketSumOperator.
public DimensionTimeBucketSumOperator getSystemDimensionTimeBucketSumOperator(String name, DAG dag) {
DimensionTimeBucketSumOperator oper = dag.addOperator(name, DimensionTimeBucketSumOperator.class);
oper.addDimensionKeyName(SYSTEM_KEYS.host.value);
oper.addValueKeyName(SYSTEM_KEYS.MemFree.value);
oper.addValueKeyName(SYSTEM_KEYS.SwapFree.value);
oper.addValueKeyName(SYSTEM_KEYS.system_hz.value);
oper.addValueKeyName(SYSTEM_KEYS.user_hz.value);
oper.addValueKeyName(SYSTEM_KEYS.io.value);
oper.addValueKeyName(SYSTEM_KEYS.io_ms.value);
oper.addValueKeyName(SYSTEM_KEYS.io_wait_ms.value);
Set<String> dimensionKey = new HashSet<String>();
dimensionKey.add(SYSTEM_KEYS.host.value);
try {
oper.addCombination(dimensionKey);
} catch (NoSuchFieldException e) {
throw new RuntimeException("Exception while while adding operator " + name, e);
}
oper.setTimeBucketFlags(AbstractDimensionTimeBucketOperator.TIMEBUCKET_MINUTE);
return oper;
}
use of org.apache.apex.malhar.lib.util.DimensionTimeBucketSumOperator in project apex-malhar by apache.
the class Application method getFilteredApacheDimensionTimeBucketSumOperator.
public DimensionTimeBucketSumOperator getFilteredApacheDimensionTimeBucketSumOperator(String name, DAG dag) {
DimensionTimeBucketSumOperator oper = dag.addOperator(name, DimensionTimeBucketSumOperator.class);
// 0
oper.addDimensionKeyName(APACHE_KEYS.host.value);
// 1
oper.addDimensionKeyName(APACHE_KEYS.request.value);
// dimension set # 1
// url
Set<String> dimensionKey1 = new HashSet<String>();
dimensionKey1.add(APACHE_KEYS.host.value);
// dimension set # 2
// ip
Set<String> dimensionKey2 = new HashSet<String>();
dimensionKey2.add(APACHE_KEYS.request.value);
try {
oper.addCombination(dimensionKey1);
oper.addCombination(dimensionKey2);
} catch (NoSuchFieldException e) {
throw new RuntimeException("Exception while while adding operator " + name, e);
}
oper.setTimeBucketFlags(AbstractDimensionTimeBucketOperator.TIMEBUCKET_MINUTE);
return oper;
}
use of org.apache.apex.malhar.lib.util.DimensionTimeBucketSumOperator in project apex-malhar by apache.
the class Application method getMysqlDimensionTimeBucketSumOperator.
public DimensionTimeBucketSumOperator getMysqlDimensionTimeBucketSumOperator(String name, DAG dag) {
DimensionTimeBucketSumOperator oper = dag.addOperator(name, DimensionTimeBucketSumOperator.class);
oper.addDimensionKeyName(MYSQL_KEYS.user.value);
oper.addDimensionKeyName(MYSQL_KEYS.query_time.value);
oper.addDimensionKeyName(MYSQL_KEYS.rows_sent.value);
oper.addDimensionKeyName(MYSQL_KEYS.rows_examined.value);
oper.addValueKeyName(MYSQL_KEYS.lock_time.value);
Set<String> dimensionKey = new HashSet<String>();
dimensionKey.add(MYSQL_KEYS.user.value);
try {
oper.addCombination(dimensionKey);
} catch (NoSuchFieldException e) {
throw new RuntimeException("Exception while while adding operator " + name, e);
}
oper.setTimeBucketFlags(AbstractDimensionTimeBucketOperator.TIMEBUCKET_MINUTE);
return oper;
}
Aggregations