Search in sources :

Example 1 with ApacheLogParseMapOutputOperator

use of org.apache.apex.malhar.lib.logs.ApacheLogParseMapOutputOperator in project apex-malhar by apache.

the class ApplicationLocalLog method populateDAG.

@Override
public void populateDAG(DAG dag, Configuration conf) {
    TailFsInputOperator log = dag.addOperator("log", new TailFsInputOperator());
    log.setDelimiter('\n');
    log.setFilePath("/var/log/apache2/access.log");
    ApacheLogParseMapOutputOperator parse = dag.addOperator("parse", new ApacheLogParseMapOutputOperator());
    GeoIPExtractor geoIPExtractor = new GeoIPExtractor();
    // Can't put this file in resources until licensing issue is straightened out
    geoIPExtractor.setDatabasePath("/home/david/GeoLiteCity.dat");
    parse.registerInformationExtractor("ip", geoIPExtractor);
    parse.registerInformationExtractor("agent", new UserAgentExtractor());
    TimestampExtractor timestampExtractor = new TimestampExtractor();
    timestampExtractor.setDateFormatString("dd/MMM/yyyy:HH:mm:ss Z");
    parse.registerInformationExtractor("time", timestampExtractor);
    ConsoleOutputOperator console = dag.addOperator("console", new ConsoleOutputOperator());
    dag.addStream("log-parse", log.output, parse.data);
    dag.addStream("parse-console", parse.output, console.input).setLocality(Locality.CONTAINER_LOCAL);
}
Also used : ConsoleOutputOperator(org.apache.apex.malhar.lib.io.ConsoleOutputOperator) ApacheLogParseMapOutputOperator(org.apache.apex.malhar.lib.logs.ApacheLogParseMapOutputOperator) TailFsInputOperator(org.apache.apex.malhar.lib.io.fs.TailFsInputOperator)

Example 2 with ApacheLogParseMapOutputOperator

use of org.apache.apex.malhar.lib.logs.ApacheLogParseMapOutputOperator in project apex-malhar by apache.

the class ApplicationLogGenerator method populateDAG.

// private void setLibraryJars(DAG dag)
// {
// List<Class<?>> containingJars = new ArrayList<Class<?>>();
// containingJars.add(com.maxmind.geoip.LookupService.class);
// containingJars.add(net.sf.uadetector.UserAgentStringParser.class);
// containingJars.add(net.sf.uadetector.service.UADetectorServiceFactory.class);
// containingJars.add(net.sf.qualitycheck.Check.class);
// 
// String oldlibjar = dag.getValue(Context.DAGContext.LIBRARY_JARS);
// if (oldlibjar == null) {
// oldlibjar = "";
// }
// 
// StringBuilder libjars = new StringBuilder(oldlibjar);
// for (Class<?> clazz : containingJars) {
// if (libjars.length() != 0) {
// libjars.append(",");
// }
// libjars.append(clazz.getProtectionDomain().getCodeSource().getLocation().toString());
// }
// dag.setAttribute(Context.DAGContext.LIBRARY_JARS, libjars.toString());
// }
@Override
public void populateDAG(DAG dag, Configuration conf) {
    // The code left here so that when a package gets built out of this, the builder scambles
    // a tiny bit less to identify the jars
    // setLibraryJars(dag);
    ApacheLogInputGenerator log = dag.addOperator("log", new ApacheLogInputGenerator());
    log.setIpAddressFile("/com/datatorrent/contrib/apachelog/ipaddress.txt");
    log.setUrlFile("/com/datatorrent/contrib/apachelog/urls.txt");
    log.setAgentFile("/com/datatorrent/contrib/apachelog/agents.txt");
    log.setRefererFile("/com/datatorrent/contrib/apachelog/referers.txt");
    ApacheLogParseMapOutputOperator parse = dag.addOperator("parse", new ApacheLogParseMapOutputOperator());
    GeoIPExtractor geoIPExtractor = new GeoIPExtractor();
    // Can't put this file in resources until licensing issue is straightened out
    geoIPExtractor.setDatabasePath("/home/david/GeoLiteCity.dat");
    parse.registerInformationExtractor("ip", geoIPExtractor);
    parse.registerInformationExtractor("agent", new UserAgentExtractor());
    TimestampExtractor timestampExtractor = new TimestampExtractor();
    timestampExtractor.setDateFormatString("dd/MMM/yyyy:HH:mm:ss Z");
    parse.registerInformationExtractor("time", timestampExtractor);
    ConsoleOutputOperator console = dag.addOperator("console", new ConsoleOutputOperator());
    dag.addStream("log-parse", log.output, parse.data);
    dag.addStream("parse-console", parse.output, console.input).setLocality(Locality.CONTAINER_LOCAL);
}
Also used : ConsoleOutputOperator(org.apache.apex.malhar.lib.io.ConsoleOutputOperator) ApacheLogParseMapOutputOperator(org.apache.apex.malhar.lib.logs.ApacheLogParseMapOutputOperator)

Aggregations

ConsoleOutputOperator (org.apache.apex.malhar.lib.io.ConsoleOutputOperator)2 ApacheLogParseMapOutputOperator (org.apache.apex.malhar.lib.logs.ApacheLogParseMapOutputOperator)2 TailFsInputOperator (org.apache.apex.malhar.lib.io.fs.TailFsInputOperator)1