Giter Club home page Giter Club logo

hmrc.flume-byte-handler's Introduction

flume-byte-handler

Build Status Download

This is a high performance handler for use with the Flume HttpSource. It does no processing of the HTTP request beyond copying the byte payload into a single Flume event. It is also coded to support large message payloads by minimising the amount of memory allocated for each event, and pre-allocating the correct event memory size based on the HTTP Content-Length header value (where this is available).

Configuration

To use this handler, you must specify its class in the HttpSource in your Flume configuration file. An example of this is :

audit.sources = httpSource
audit.channels = memoryChannel
audit.sinks = nullSink

# Source for accepting HTTP calls
audit.sources.httpSource.type = http
audit.sources.httpSource.channels = memoryChannel
audit.sources.httpSource.port = 9001
audit.sources.httpSource.handler = uk.gov.hmrc.flume.handler.SimpleByteHandler

# Provides an in-memory channel
audit.channels.memoryChannel.type = memory

# Null Sink
audit.sinks.nullSink.type = null
audit.sinks.nullSink.channel = memoryChannel

Building

To run unit tests, you can use the usual SBT command sbt test.

To run some simple ScalaMeter benchmark tests, us sbt bench:test.

Gatling tests need a running Flume process, which can use the configuration above. The assembly binary will need to be included in the Flume path for this to work correctly, as it contains the Scala dependencies needed by the handler code. Run the tests using sbt gatling-it:test.

License

This code is open source software licensed under the Apache 2.0 License.

hmrc.flume-byte-handler's People

Contributors

benwheeler avatar hmrc-web-operations avatar tomasz-rosiek avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.