Book Image

Architecting Data-Intensive Applications

By : Anuj Kumar
Book Image

Architecting Data-Intensive Applications

By: Anuj Kumar

Overview of this book

<p>Are you an architect or a developer who looks at your own applications gingerly while browsing through Facebook and applauding it silently for its data-intensive, yet ?uent and efficient, behaviour? This book is your gateway to build smart data-intensive systems by incorporating the core data-intensive architectural principles, patterns, and techniques directly into your application architecture.</p> <p>This book starts by taking you through the primary design challenges involved with architecting data-intensive applications. You will learn how to implement data curation and data dissemination, depending on the volume of your data. You will then implement your application architecture one step at a time. You will get to grips with implementing the correct message delivery protocols and creating a data layer that doesn’t fail when running high traffic. This book will show you how you can divide your application into layers, each of which adheres to the single responsibility principle. By the end of this book, you will learn to streamline your thoughts and make the right choice in terms of technologies and architectural principles based on the problem at hand.</p>
Table of Contents (18 chapters)
Title Page
Packt Upsell
Contributors
Preface
Index

ELK


ELK (shorthand for ElasticSearch-Logstash-Kibana) is a set of independent tools that work in tandem to collect Data from various sources and transfer them to Elastic Search. Kibana is then used to build a visualization of top of the indexed data.

ELK started as a distributed, highly-scalable system for aggregating Logs, but has since evolved to collect a variety of data.

Collecting data with ELK usually consists of the following phases:

  1. Shipping the data from the host system to a set of collection agents
  2. Agrregating the data from different sources at the collection phase and queuing them for resilience requirements
  1. Processing the aggregated data by taking batches of collected data from the queue and indexing it in Elastic Search:

Different systems/libraries are responsible for handling different phases of the complete life cycle.

Let's look at these systems and libraries in a bit more detail.

Beats

Beats are lightweight, single-purpose data-shipper agents. They are installed on the machines where...