SlideShare a Scribd company logo
Fluentd Overview, Now and Then
Satoshi Tagomori (@tagomoris)
Fluentd meetup in Matsue #fluentdmeetup
Satoshi "Moris" Tagomori
(@tagomoris)
Fluentd, MessagePack-Ruby, Norikra, ...
Treasure Data, Inc.
Fluentd overview
What’s Fluentd?
Simple core

+ Variety of plugins
Buffering, HA (failover),
Secondary output, etc.
Like syslogd in streaming manner
AN EXTENSIBLE & RELIABLE DATA COLLECTION TOOL
Log collection with traditional logrotate + rsync
Log Server
Application
Server A
File FileFile
Hard to analyze!!

Complex text parsers
Application
Server C
File FileFile
Application
Server B
File FileFile
High latency!!

Must wait for a day
Streaming way with Fluentd
Log Server
Application
Server A
File FileFile
Application
Server C
File FileFile
Application
Server B
File FileFile
Low latency!

Seconds or minutes
Easy to analyze!!

Parsed and formatted
M x N problem for data integration
LOG
script to
parse data
cron job for
loading
filtering
script
syslog
script
Tweet-
fetching
script
aggregation
script
aggregation
script
script to
parse data
rsync
server
LOG
A solution: centralized log collection service
M + N
Fluentd Architecture
Internal Architecture (simplified)
Plugin
Input Filter Buffer Output
Plugin Plugin Plugin
2012-02-04 01:33:51

myapp.buylog{

“user”:”me”,

“path”: “/buyItem”,

“price”: 150,

“referer”: “/landing”

}
Time
Tag
Record
Architecture: Input Plugins
HTTP+JSON (in_http)

File tail (in_tail)

Syslog (in_syslog)

…
Receive logs
Or pull logs from data sources
In non-blocking manner
Plugin
Input
Filter
Architecture: Filter Plugins
Transform logs
Filter out unnecessary logs
Enrich logs
Plugin
Encrypt personal data

Convert IP to countries

Parse User-Agent

…
Buffer
Architecture: Buffer Plugins
Plugin
Improve performance
Provide reliability
Provide thread-safety
Memory (buf_memory)

File (buf_file)
Buffer
Architecture: Buffer Plugins
Chunk
Plugin
Improve performance
Provide reliability
Provide thread-safety
Input
Output
Chunk
Chunk
Architecture: Output Plugins
Output
Write or send event logs
Plugin
File (out_file)

Amazon S3 (out_s3)

kafka (out_kafka_buffered)

…
Retry
Error
Retry
Batch
Stream Error
Retry
Retry
Divide & Conquer for retry
Divide & Conquer for recovery
Buffer
(on-disk or in-memory)
Error
Overloaded!!
recovery
recovery + flow control
queued chunks
Example Use Cases
Streaming from Apache/Nginx to Elasticsearch
in_tail
/var/log/access.log
/var/log/fluentd/buffer
but_file
Error Handling and Recovery
in_tail
/var/log/access.log
/var/log/fluentd/buffer
but_file
Buffering for any outputs
Retrying automatically
With exponential wait
and persistence on a disk
and secondary output
Tailing & parsing files
Supported built-in formats:
Read a log file
Custom regexp
Custom parser in Ruby
• apache
• apache_error
• apache2
• nginx
• json
• csv
• tsv
• ltsv
• syslog
• multiline
• none
pos fileevents.log
?
(your app)
Out to Multiple Locations
Routing based on tags
Copy to multiple storages
buffer
access.log
in_tail
Example configuration for real time batch combo
Data partitioning by time on HDFS / S3
access.log
buffer
Custom file
formatter
Slice files based on time
2016-01-01/01/access.log.gz
2016-01-01/02/access.log.gz
2016-01-01/03/access.log.gz
…
in_tail
3rd party input plugins
dstat
df AMQL
munin
jvmwatcher
SQL
3rd party output plugins
Graphite
Real World Use Cases
Microsoft
Operations Management Suite uses Fluentd: "The core of the agent uses an existing
open source data aggregator called Fluentd. Fluentd has hundreds of existing
plugins, which will make it really easy for you to add new data sources."
Syslog
Linux Computer
Operating System
Apache
MySQL
Containers
omsconfig (DSC)
PS DSC
Providers
OMI Server
(CIM Server)
omsagent
Firewall/proxy
OMSService
Upload Data

(HTTPS)
Pull

configuration

(HTTPS)
Atlassian
"At Atlassian, we've been impressed by Fluentd and have chosen to use it in
Atlassian Cloud's logging and analytics pipeline."
Kinesis
Elasticsearch

cluster
Ingestion

service
Amazon web services
The architecture of Fluentd (Sponsored by Treasure Data) is very similar to Apache
Flume or Facebook’s Scribe. Fluentd is easier to install and maintain and has better
documentation and support than Flume and Scribe.
Types of DataStoreCollect
Transactional
• Database reads & write (OLTP)

• Cache
Search
• Logs

• Streams
File
• Log files (/val/log)

• Log collectors & frameworks
Stream
• Log records

• Sensors & IoT data
Web Apps
IoTApplicationsLogging
Mobile Apps
Database
Search
File Storage
Stream Storage
Container and Logging
The Container Era
Server Era Container Era
Service Architecture Monolithic Microservices
System Image Mutable Immutable
Managed By Ops Team DevOps Team
Local Data Persistent Ephemeral
Log Collection syslogd / rsync ?
Metrics Collection Nagios / Zabbix ?
Server Era Container Era
Service Architecture Monolithic Microservices
System Image Mutable Immutable
Managed By Ops Team DevOps Team
Local Data Persistent Ephemeral
Log Collection syslogd / rsync ?
Metrics Collection Nagios / Zabbix ?
The Container Era
How should log & metrics collection
be done in The Container Era?
Problems
The traditional logrotate + rsync on containers
Log Server
Application
Container A
File FileFile
Hard to analyze!!

Complex text parsers
Application
Container C
File FileFile
Application
Container B
File FileFile
High latency!!

Must wait for a day
Ephemeral!!

Could be lost at any time
Server 1
Container A
Application
Container B
Application
Server 2
Container C
Application
Container D
Application
Kafka
elasticsearch
HDFS
Container
Container
Container
Container
Small & many containers make storages overloaded
Too many
connections from
micro containers!
Server 1
Container A
Application
Container B
Application
Server 2
Container C
Application
Container D
Application
Kafka
elasticsearch
HDFS
Container
Container
Container
Container
System images are immutable
Too many
connections from
micro containers!
Embedding destination
IPsin ALL Docker images

makes management hard
How to collect logs from

Docker containers
Text logging with --log-driver=fluentd
Server
Container
App
FluentdSTDOUT / STDERR
docker run 
--log-driver=fluentd 

--log-opt 
fluentd-address=localhost:24224
{

“container_id”: “ad6d5d32576a”,

“container_name”: “myapp”,

“source”: stdout

}
Metrics collection with fluent-logger
Server
Container
App
Fluentd
from fluent import sender
from fluent import event
sender.setup('app.events', host='localhost')
event.Event('purchase', {
'user_id': 21, 'item_id': 321, 'value': '1'
})
tag = app.events.purchase

{

“user_id”: 21,

“item_id”: 321

“value”: 1,

}
fluent-logger library
Shared data volume and tailing
Server
Container
App
Fluentd
<source>
@type tail
path /mnt/nginx/logs/access.log
pos_file /var/log/fluentd/access.log.pos
format nginx
tag nginx.access
</source>
/mnt/nginx/logs
Logging methods for each purpose
• Collecting log messages
> --log-driver=fluentd
• Application metrics
> fluent-logger
• Access logs, logs from middleware
> Shared data volume
• System metrics (CPU usage, Disk capacity, etc.)
> Fluentd’s input plugins

(Fluentd pulls those data periodically)
Deployment Patterns
Server 1
Container A
Application
Container B
Application
Server 2
Container C
Application
Container D
Application
Kafka
elasticsearch
HDFS
Container
Container
Container
Container
Primitive deployment…
Too many
connections from
many containers!
Embedding destination
IPsin ALL Docker images

makes management hard
Server 1
Container A
Application
Container B
Application
Fluentd
Server 2
Container C
Application
Container D
Application
Fluentd Kafka
elasticsearch
HDFS
Container
Container
Container
Container
destination is always
localhost from app’s
point of view
Source aggregation decouples config
from apps
Server 1
Container A
Application
Container B
Application
Fluentd
Server 2
Container C
Application
Container D
Application
Fluentd
active / standby /
load balancing
Destination aggregation makes storages scalable
for high traffic
Aggregation server(s)
Aggregation servers
• Logging directly from microservices makes log
storages overloaded.
> Too many RX connections
> Too frequent import API calls
• Aggregation servers make the logging infrastracture
more reliable and scalable.
> Connection aggregation
> Buffering for less frequent import API calls
> Data persistency during downtime
> Automatic retry at recovery from downtime
Fluentd ♡ Container
• Fluentd model fits container based systems
> This is why Treasure Data joined CNCF
> TD wants to improve cloud native ecosystem
• Fluentd, Prometheus, Docker and Kubernetes
collabolation is good for modern systems
• Easy to scale and easy to maintain
• Fluentd logging driver in Docker
• fluent-plugin-prometheus to send application metrics
to prometheus
• EFK for log visualization in Kubernetes
Fluentd v0.14 and Later
• v0.14.0: Released at May 31, 2016
• v0.14.1: Released at Jun 30, 2016
• New Features
• New Plugin APIs, Plugin Helpers & Plugin Storage
• Time with Nanosecond resolution
• ServerEngine based Supervisor
• Windows support
v0.14
New Plugin APIs
• Input/Output plugin APIs w/ well-controlled lifecycle
• stop, shutdown, close, terminate
• New Buffer API for delayed commit of chunks
• parallel/async "commit" operation for chunks
• 100% Compatible w/ v0.12 plugins
• compatibility layer for traditional APIs
• it will be supported between v1.x versions
Router
buffer_chunk_limit
enqueue: exceed flush_interval
or buffer_chunk_limit
Key pattern:
- BufferedOutput
empty string or specified key
-ObjectBufferedOutput tag
-TimeSlicedOutput time slice
emit emit
Buffer
Queue
buffer_queue_limit
Output
OutputInput / Filter
Tag Time
Record Chunk
Chunk
Chunk Chunk
Chunk
key:foo
key:bar
key:baz
v0.12 buffer design
v0.14 buffer design
Plugin Storage & Helpers
• Plugin Storage: new plugin type for plugins
• provides key-value storage for plugins
• to persistent intermediate status of plugins
• built-in plugins (in plan): in-memory, local file
• pluggable: 3rd party plugin to store data to Redis?
• Plugin Helpers:
• collections of utility methods for plugins
• making threads, sockets, network servers, ...
• fully integrated with test drivers to run test codes after
setup phase of helpers (e.g., after created threads started)
v0.12 plugins
ParserInput Buffer Output FormatteFilter
“output-ish”“input-ish”
v0.14 plugins
ParserInput Buffer Output FormatteFilter
“output-ish”“input-ish”
Storag
Helper
Time with nanosecond
• For sub-second systems: Elasticsearch, InfluxData and etc
• Fluent::EventTime
• behaves as Integer (used as time in v0.12)
• has methods to get sub-second resolution
• be serialized into msgpack using Ext type
• Fluentd core can handle both of Integer and EventTime as
time
• compatible with older versions and software in eco-
system (e.g., fluent-logger, Docker logging driver)
ServerEngine based
Supervisor
• Replacing supervisor process with ServerEngine
• it has SocketManager to share listening sockets
between 2 or more worker processes
• Replacing Fluentd's processing model from fork to
spawn
• to support Windows environment
Windows support
• Fluentd and core plugin work on Windows
• several companies have already used

v0.14.0.pre version on production
• We will send a patch to popular plugins if

it doesn’t work on Windows
• Use HTTP RPC instead of signals
v0.14.x - v1
• v0.14.x (some versions in 2016)
• Symmetric multi-core processing
• Counter API
• TLS/authentication/authorization support
(merging secure forward)
• https://github.com/fluent/fluentd/issues/1000
• v1 (4Q in 2016 or 1Q in 2017)
• Stable version for new APIs / features
• Fully compatible with v0.12
• exclude v0 config syntax and detach_process
Symmetric multi core processing
• 2 or more workers share a configuration file
• and share listening sockets via PluginHelper
• under a supervisor process (ServerEngine)
• Multi core scalability for huge traffic
• one input plugin for a tcp port, some filters and
one (or some) output plugin
• buffer paths are managed automatically by
Fluentd core
Worker
Supervisor
Worker Worker
Worker
Supervisor
Worker Worker
Supervisor Supervisor
Using fluent-plugin-multiprocess
v0.14
Counter API
• APIs to increment/decrement values
• shared by some processes
• persisted on disk backed by Storage API
• Useful for collecting metrics or stats filters
TLS/Authn/Authz support for forward plugin
• secure-forward will be merged into built-in forward
• TLS w/ at-least-one semantics
• Simple authentication/authorization w/ non-SSL
forwarding
• Authentication and Authorization providers
• Who can connect to input plugins?

What tags are permitted for clients?
• New plugin types (3rd party authors can write it)
• Mainly for in/out forward, but available from others
Benchmark (1 CPU usage)
100,000msgs/sec v0.14 v0.12
in_tail (none) +
out_forward
70% 66%
in_forward +
flowcounter_simple
11% 11%
in_forward + tdlog 43% 38%
※ Use EC2 c3.8xlarge ※ Not fully optimized yet
Treasure Agent 3.0 (td-agent 3)
• fluentd v0.14
• Ruby 2.3 and latest core components
• Environments
• Add msi Windows package
• Remove CentOS 5, Ubuntu 10.04 support
• Release date is not fixed…
Enjoy logging!
Fluentd Overview, Now and Then
H.A. configuration (high availability)
Retry automatically
Exponential retry wait
Persistent on a disk
buffer
Automatic fail-over
Load balancing
access.log
in_tail

More Related Content

PDF
The basics of fluentd
PDF
The Patterns of Distributed Logging and Containers
PDF
Fluentd and Distributed Logging at Kubecon
PDF
The basics of fluentd
PDF
Fluentd v1.0 in a nutshell
PDF
Fluentd 101
PDF
Apache kafka 모니터링을 위한 Metrics 이해 및 최적화 방안
PDF
Loki - like prometheus, but for logs
The basics of fluentd
The Patterns of Distributed Logging and Containers
Fluentd and Distributed Logging at Kubecon
The basics of fluentd
Fluentd v1.0 in a nutshell
Fluentd 101
Apache kafka 모니터링을 위한 Metrics 이해 및 최적화 방안
Loki - like prometheus, but for logs

What's hot (20)

PPTX
NGINX Installation and Tuning
PDF
A Deep Dive into Kafka Controller
PDF
Apache kafka performance(latency)_benchmark_v0.3
PDF
[오픈소스컨설팅] EFK Stack 소개와 설치 방법
PPTX
Kafka replication apachecon_2013
PPTX
Apache Flink: API, runtime, and project roadmap
ODP
Introduction to Nginx
PPTX
Prometheus - Intro, CNCF, TSDB,PromQL,Grafana
PPTX
Data Engineering Efficiency @ Netflix - Strata 2017
PDF
How Netflix Tunes EC2 Instances for Performance
PDF
Grafana Loki: like Prometheus, but for Logs
PPTX
[211] HBase 기반 검색 데이터 저장소 (공개용)
PPTX
Centralized Logging System Using ELK Stack
PPT
Monitoring using Prometheus and Grafana
PPTX
Kafka + Uber- The World’s Realtime Transit Infrastructure, Aaron Schildkrout
PDF
LogbackからLog4j 2への移行によるアプリケーションのスループット改善 ( JJUG CCC 2021 Fall )
PPTX
From cache to in-memory data grid. Introduction to Hazelcast.
PDF
Introducing the Apache Flink Kubernetes Operator
PDF
카프카, 산전수전 노하우
PDF
Using eBPF for High-Performance Networking in Cilium
NGINX Installation and Tuning
A Deep Dive into Kafka Controller
Apache kafka performance(latency)_benchmark_v0.3
[오픈소스컨설팅] EFK Stack 소개와 설치 방법
Kafka replication apachecon_2013
Apache Flink: API, runtime, and project roadmap
Introduction to Nginx
Prometheus - Intro, CNCF, TSDB,PromQL,Grafana
Data Engineering Efficiency @ Netflix - Strata 2017
How Netflix Tunes EC2 Instances for Performance
Grafana Loki: like Prometheus, but for Logs
[211] HBase 기반 검색 데이터 저장소 (공개용)
Centralized Logging System Using ELK Stack
Monitoring using Prometheus and Grafana
Kafka + Uber- The World’s Realtime Transit Infrastructure, Aaron Schildkrout
LogbackからLog4j 2への移行によるアプリケーションのスループット改善 ( JJUG CCC 2021 Fall )
From cache to in-memory data grid. Introduction to Hazelcast.
Introducing the Apache Flink Kubernetes Operator
카프카, 산전수전 노하우
Using eBPF for High-Performance Networking in Cilium
Ad

Viewers also liked (12)

PDF
How To Write Middleware In Ruby
PDF
Modern Black Mages Fighting in the Real World
PDF
Fighting API Compatibility On Fluentd Using "Black Magic"
PDF
How to Make Norikra Perfect
PDF
20160730 fluentd meetup in matsue slide
PDF
Open Source Software, Distributed Systems, Database as a Cloud Service
PDF
AWSにおけるバッチ処理の ベストプラクティス - Developers.IO Meetup 05
PDF
To Have Own Data Analytics Platform, Or NOT To
PDF
Perfect Norikra 2nd Season
PDF
Ruby and Distributed Storage Systems
PDF
Fluentd v0.14 Plugin API Details
PDF
Distributed Logging Architecture in Container Era
How To Write Middleware In Ruby
Modern Black Mages Fighting in the Real World
Fighting API Compatibility On Fluentd Using "Black Magic"
How to Make Norikra Perfect
20160730 fluentd meetup in matsue slide
Open Source Software, Distributed Systems, Database as a Cloud Service
AWSにおけるバッチ処理の ベストプラクティス - Developers.IO Meetup 05
To Have Own Data Analytics Platform, Or NOT To
Perfect Norikra 2nd Season
Ruby and Distributed Storage Systems
Fluentd v0.14 Plugin API Details
Distributed Logging Architecture in Container Era
Ad

Similar to Fluentd Overview, Now and Then (20)

PDF
Fluentd at Bay Area Kubernetes Meetup
PDF
Fluentd at HKOScon
PDF
Logging for Production Systems in The Container Era
PDF
Fluentd - RubyKansai 65
PDF
fluentd -- the missing log collector
PDF
Fluentd and AWS at classmethod
PPTX
Supporting Digital Media Workflows in the Cloud with Perforce Helix
PDF
Treasure Data and OSS
PDF
Lunar Way and the Cloud Native "stack"
PDF
Cloud lunch and learn real-time streaming in azure
PDF
Serverless Data Platform
PDF
Fluentd and Embulk Game Server 4
PDF
Monitoring&Logging - Stanislav Kolenkin
PDF
DBCC 2021 - FLiP Stack for Cloud Data Lakes
PDF
Apache Kafka - Scalable Message-Processing and more !
PPTX
Deploying Apache Flume to enable low-latency analytics
PDF
Scenic City Summit (2021): Real-Time Streaming in any and all clouds, hybrid...
PDF
Lightbend Fast Data Platform
PDF
Music city data Hail Hydrate! from stream to lake
PDF
Big mountain data and dev conference apache pulsar with mqtt for edge compu...
Fluentd at Bay Area Kubernetes Meetup
Fluentd at HKOScon
Logging for Production Systems in The Container Era
Fluentd - RubyKansai 65
fluentd -- the missing log collector
Fluentd and AWS at classmethod
Supporting Digital Media Workflows in the Cloud with Perforce Helix
Treasure Data and OSS
Lunar Way and the Cloud Native "stack"
Cloud lunch and learn real-time streaming in azure
Serverless Data Platform
Fluentd and Embulk Game Server 4
Monitoring&Logging - Stanislav Kolenkin
DBCC 2021 - FLiP Stack for Cloud Data Lakes
Apache Kafka - Scalable Message-Processing and more !
Deploying Apache Flume to enable low-latency analytics
Scenic City Summit (2021): Real-Time Streaming in any and all clouds, hybrid...
Lightbend Fast Data Platform
Music city data Hail Hydrate! from stream to lake
Big mountain data and dev conference apache pulsar with mqtt for edge compu...

More from SATOSHI TAGOMORI (18)

PDF
Ractor's speed is not light-speed
PDF
Good Things and Hard Things of SaaS Development/Operations
PDF
Maccro Strikes Back
PDF
Invitation to the dark side of Ruby
PDF
Hijacking Ruby Syntax in Ruby (RubyConf 2018)
PDF
Make Your Ruby Script Confusing
PDF
Hijacking Ruby Syntax in Ruby
PDF
Lock, Concurrency and Throughput of Exclusive Operations
PDF
Data Processing and Ruby in the World
PDF
Planet-scale Data Ingestion Pipeline: Bigdam
PDF
Technologies, Data Analytics Service and Enterprise Business
PDF
Overview of data analytics service: Treasure Data Service
PDF
Hive dirty/beautiful hacks in TD
PDF
Data Analytics Service Company and Its Ruby Usage
PDF
Tale of ISUCON and Its Bench Tools
PDF
Data Analytics Service Company and Its Ruby Usage
PDF
Data-Driven Development Era and Its Technologies
PDF
Engineer as a Leading Role
Ractor's speed is not light-speed
Good Things and Hard Things of SaaS Development/Operations
Maccro Strikes Back
Invitation to the dark side of Ruby
Hijacking Ruby Syntax in Ruby (RubyConf 2018)
Make Your Ruby Script Confusing
Hijacking Ruby Syntax in Ruby
Lock, Concurrency and Throughput of Exclusive Operations
Data Processing and Ruby in the World
Planet-scale Data Ingestion Pipeline: Bigdam
Technologies, Data Analytics Service and Enterprise Business
Overview of data analytics service: Treasure Data Service
Hive dirty/beautiful hacks in TD
Data Analytics Service Company and Its Ruby Usage
Tale of ISUCON and Its Bench Tools
Data Analytics Service Company and Its Ruby Usage
Data-Driven Development Era and Its Technologies
Engineer as a Leading Role

Recently uploaded (20)

PPTX
Transform Your Business with a Software ERP System
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PPTX
Online Work Permit System for Fast Permit Processing
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PPTX
ai tools demonstartion for schools and inter college
PDF
Digital Strategies for Manufacturing Companies
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
Design an Analysis of Algorithms I-SECS-1021-03
PDF
Complete React Javascript Course Syllabus.pdf
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PPTX
Operating system designcfffgfgggggggvggggggggg
PPTX
Materi-Enum-and-Record-Data-Type (1).pptx
PDF
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
PDF
AI in Product Development-omnex systems
PPTX
L1 - Introduction to python Backend.pptx
PPT
JAVA ppt tutorial basics to learn java programming
Transform Your Business with a Software ERP System
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Online Work Permit System for Fast Permit Processing
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
ai tools demonstartion for schools and inter college
Digital Strategies for Manufacturing Companies
Wondershare Filmora 15 Crack With Activation Key [2025
PTS Company Brochure 2025 (1).pdf.......
Design an Analysis of Algorithms I-SECS-1021-03
Complete React Javascript Course Syllabus.pdf
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
Internet Downloader Manager (IDM) Crack 6.42 Build 41
Operating system designcfffgfgggggggvggggggggg
Materi-Enum-and-Record-Data-Type (1).pptx
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
AI in Product Development-omnex systems
L1 - Introduction to python Backend.pptx
JAVA ppt tutorial basics to learn java programming

Fluentd Overview, Now and Then

  • 1. Fluentd Overview, Now and Then Satoshi Tagomori (@tagomoris) Fluentd meetup in Matsue #fluentdmeetup
  • 2. Satoshi "Moris" Tagomori (@tagomoris) Fluentd, MessagePack-Ruby, Norikra, ... Treasure Data, Inc.
  • 4. What’s Fluentd? Simple core
 + Variety of plugins Buffering, HA (failover), Secondary output, etc. Like syslogd in streaming manner AN EXTENSIBLE & RELIABLE DATA COLLECTION TOOL
  • 5. Log collection with traditional logrotate + rsync Log Server Application Server A File FileFile Hard to analyze!! Complex text parsers Application Server C File FileFile Application Server B File FileFile High latency!! Must wait for a day
  • 6. Streaming way with Fluentd Log Server Application Server A File FileFile Application Server C File FileFile Application Server B File FileFile Low latency! Seconds or minutes Easy to analyze!! Parsed and formatted
  • 7. M x N problem for data integration LOG script to parse data cron job for loading filtering script syslog script Tweet- fetching script aggregation script aggregation script script to parse data rsync server
  • 8. LOG A solution: centralized log collection service M + N
  • 10. Internal Architecture (simplified) Plugin Input Filter Buffer Output Plugin Plugin Plugin 2012-02-04 01:33:51 myapp.buylog{ “user”:”me”, “path”: “/buyItem”, “price”: 150, “referer”: “/landing” } Time Tag Record
  • 11. Architecture: Input Plugins HTTP+JSON (in_http) File tail (in_tail) Syslog (in_syslog) … Receive logs Or pull logs from data sources In non-blocking manner Plugin Input
  • 12. Filter Architecture: Filter Plugins Transform logs Filter out unnecessary logs Enrich logs Plugin Encrypt personal data Convert IP to countries Parse User-Agent …
  • 13. Buffer Architecture: Buffer Plugins Plugin Improve performance Provide reliability Provide thread-safety Memory (buf_memory) File (buf_file)
  • 14. Buffer Architecture: Buffer Plugins Chunk Plugin Improve performance Provide reliability Provide thread-safety Input Output Chunk Chunk
  • 15. Architecture: Output Plugins Output Write or send event logs Plugin File (out_file) Amazon S3 (out_s3) kafka (out_kafka_buffered) …
  • 17. Divide & Conquer for recovery Buffer (on-disk or in-memory) Error Overloaded!! recovery recovery + flow control queued chunks
  • 19. Streaming from Apache/Nginx to Elasticsearch in_tail /var/log/access.log /var/log/fluentd/buffer but_file
  • 20. Error Handling and Recovery in_tail /var/log/access.log /var/log/fluentd/buffer but_file Buffering for any outputs Retrying automatically With exponential wait and persistence on a disk and secondary output
  • 21. Tailing & parsing files Supported built-in formats: Read a log file Custom regexp Custom parser in Ruby • apache • apache_error • apache2 • nginx • json • csv • tsv • ltsv • syslog • multiline • none pos fileevents.log ? (your app)
  • 22. Out to Multiple Locations Routing based on tags Copy to multiple storages buffer access.log in_tail
  • 23. Example configuration for real time batch combo
  • 24. Data partitioning by time on HDFS / S3 access.log buffer Custom file formatter Slice files based on time 2016-01-01/01/access.log.gz 2016-01-01/02/access.log.gz 2016-01-01/03/access.log.gz … in_tail
  • 25. 3rd party input plugins dstat df AMQL munin jvmwatcher SQL
  • 26. 3rd party output plugins Graphite
  • 27. Real World Use Cases
  • 28. Microsoft Operations Management Suite uses Fluentd: "The core of the agent uses an existing open source data aggregator called Fluentd. Fluentd has hundreds of existing plugins, which will make it really easy for you to add new data sources." Syslog Linux Computer Operating System Apache MySQL Containers omsconfig (DSC) PS DSC Providers OMI Server (CIM Server) omsagent Firewall/proxy OMSService Upload Data (HTTPS) Pull configuration (HTTPS)
  • 29. Atlassian "At Atlassian, we've been impressed by Fluentd and have chosen to use it in Atlassian Cloud's logging and analytics pipeline." Kinesis Elasticsearch cluster Ingestion service
  • 30. Amazon web services The architecture of Fluentd (Sponsored by Treasure Data) is very similar to Apache Flume or Facebook’s Scribe. Fluentd is easier to install and maintain and has better documentation and support than Flume and Scribe. Types of DataStoreCollect Transactional • Database reads & write (OLTP) • Cache Search • Logs • Streams File • Log files (/val/log) • Log collectors & frameworks Stream • Log records • Sensors & IoT data Web Apps IoTApplicationsLogging Mobile Apps Database Search File Storage Stream Storage
  • 32. The Container Era Server Era Container Era Service Architecture Monolithic Microservices System Image Mutable Immutable Managed By Ops Team DevOps Team Local Data Persistent Ephemeral Log Collection syslogd / rsync ? Metrics Collection Nagios / Zabbix ?
  • 33. Server Era Container Era Service Architecture Monolithic Microservices System Image Mutable Immutable Managed By Ops Team DevOps Team Local Data Persistent Ephemeral Log Collection syslogd / rsync ? Metrics Collection Nagios / Zabbix ? The Container Era How should log & metrics collection be done in The Container Era?
  • 35. The traditional logrotate + rsync on containers Log Server Application Container A File FileFile Hard to analyze!! Complex text parsers Application Container C File FileFile Application Container B File FileFile High latency!! Must wait for a day Ephemeral!! Could be lost at any time
  • 36. Server 1 Container A Application Container B Application Server 2 Container C Application Container D Application Kafka elasticsearch HDFS Container Container Container Container Small & many containers make storages overloaded Too many connections from micro containers!
  • 37. Server 1 Container A Application Container B Application Server 2 Container C Application Container D Application Kafka elasticsearch HDFS Container Container Container Container System images are immutable Too many connections from micro containers! Embedding destination IPsin ALL Docker images
 makes management hard
  • 38. How to collect logs from
 Docker containers
  • 39. Text logging with --log-driver=fluentd Server Container App FluentdSTDOUT / STDERR docker run --log-driver=fluentd 
 --log-opt fluentd-address=localhost:24224 { “container_id”: “ad6d5d32576a”, “container_name”: “myapp”, “source”: stdout }
  • 40. Metrics collection with fluent-logger Server Container App Fluentd from fluent import sender from fluent import event sender.setup('app.events', host='localhost') event.Event('purchase', { 'user_id': 21, 'item_id': 321, 'value': '1' }) tag = app.events.purchase { “user_id”: 21, “item_id”: 321 “value”: 1, } fluent-logger library
  • 41. Shared data volume and tailing Server Container App Fluentd <source> @type tail path /mnt/nginx/logs/access.log pos_file /var/log/fluentd/access.log.pos format nginx tag nginx.access </source> /mnt/nginx/logs
  • 42. Logging methods for each purpose • Collecting log messages > --log-driver=fluentd • Application metrics > fluent-logger • Access logs, logs from middleware > Shared data volume • System metrics (CPU usage, Disk capacity, etc.) > Fluentd’s input plugins
 (Fluentd pulls those data periodically)
  • 44. Server 1 Container A Application Container B Application Server 2 Container C Application Container D Application Kafka elasticsearch HDFS Container Container Container Container Primitive deployment… Too many connections from many containers! Embedding destination IPsin ALL Docker images
 makes management hard
  • 45. Server 1 Container A Application Container B Application Fluentd Server 2 Container C Application Container D Application Fluentd Kafka elasticsearch HDFS Container Container Container Container destination is always localhost from app’s point of view Source aggregation decouples config from apps
  • 46. Server 1 Container A Application Container B Application Fluentd Server 2 Container C Application Container D Application Fluentd active / standby / load balancing Destination aggregation makes storages scalable for high traffic Aggregation server(s)
  • 47. Aggregation servers • Logging directly from microservices makes log storages overloaded. > Too many RX connections > Too frequent import API calls • Aggregation servers make the logging infrastracture more reliable and scalable. > Connection aggregation > Buffering for less frequent import API calls > Data persistency during downtime > Automatic retry at recovery from downtime
  • 48. Fluentd ♡ Container • Fluentd model fits container based systems > This is why Treasure Data joined CNCF > TD wants to improve cloud native ecosystem • Fluentd, Prometheus, Docker and Kubernetes collabolation is good for modern systems • Easy to scale and easy to maintain • Fluentd logging driver in Docker • fluent-plugin-prometheus to send application metrics to prometheus • EFK for log visualization in Kubernetes
  • 50. • v0.14.0: Released at May 31, 2016 • v0.14.1: Released at Jun 30, 2016 • New Features • New Plugin APIs, Plugin Helpers & Plugin Storage • Time with Nanosecond resolution • ServerEngine based Supervisor • Windows support v0.14
  • 51. New Plugin APIs • Input/Output plugin APIs w/ well-controlled lifecycle • stop, shutdown, close, terminate • New Buffer API for delayed commit of chunks • parallel/async "commit" operation for chunks • 100% Compatible w/ v0.12 plugins • compatibility layer for traditional APIs • it will be supported between v1.x versions
  • 52. Router buffer_chunk_limit enqueue: exceed flush_interval or buffer_chunk_limit Key pattern: - BufferedOutput empty string or specified key -ObjectBufferedOutput tag -TimeSlicedOutput time slice emit emit Buffer Queue buffer_queue_limit Output OutputInput / Filter Tag Time Record Chunk Chunk Chunk Chunk Chunk key:foo key:bar key:baz v0.12 buffer design
  • 54. Plugin Storage & Helpers • Plugin Storage: new plugin type for plugins • provides key-value storage for plugins • to persistent intermediate status of plugins • built-in plugins (in plan): in-memory, local file • pluggable: 3rd party plugin to store data to Redis? • Plugin Helpers: • collections of utility methods for plugins • making threads, sockets, network servers, ... • fully integrated with test drivers to run test codes after setup phase of helpers (e.g., after created threads started)
  • 55. v0.12 plugins ParserInput Buffer Output FormatteFilter “output-ish”“input-ish”
  • 56. v0.14 plugins ParserInput Buffer Output FormatteFilter “output-ish”“input-ish” Storag Helper
  • 57. Time with nanosecond • For sub-second systems: Elasticsearch, InfluxData and etc • Fluent::EventTime • behaves as Integer (used as time in v0.12) • has methods to get sub-second resolution • be serialized into msgpack using Ext type • Fluentd core can handle both of Integer and EventTime as time • compatible with older versions and software in eco- system (e.g., fluent-logger, Docker logging driver)
  • 58. ServerEngine based Supervisor • Replacing supervisor process with ServerEngine • it has SocketManager to share listening sockets between 2 or more worker processes • Replacing Fluentd's processing model from fork to spawn • to support Windows environment
  • 59. Windows support • Fluentd and core plugin work on Windows • several companies have already used
 v0.14.0.pre version on production • We will send a patch to popular plugins if
 it doesn’t work on Windows • Use HTTP RPC instead of signals
  • 60. v0.14.x - v1 • v0.14.x (some versions in 2016) • Symmetric multi-core processing • Counter API • TLS/authentication/authorization support (merging secure forward) • https://github.com/fluent/fluentd/issues/1000 • v1 (4Q in 2016 or 1Q in 2017) • Stable version for new APIs / features • Fully compatible with v0.12 • exclude v0 config syntax and detach_process
  • 61. Symmetric multi core processing • 2 or more workers share a configuration file • and share listening sockets via PluginHelper • under a supervisor process (ServerEngine) • Multi core scalability for huge traffic • one input plugin for a tcp port, some filters and one (or some) output plugin • buffer paths are managed automatically by Fluentd core
  • 62. Worker Supervisor Worker Worker Worker Supervisor Worker Worker Supervisor Supervisor Using fluent-plugin-multiprocess v0.14
  • 63. Counter API • APIs to increment/decrement values • shared by some processes • persisted on disk backed by Storage API • Useful for collecting metrics or stats filters
  • 64. TLS/Authn/Authz support for forward plugin • secure-forward will be merged into built-in forward • TLS w/ at-least-one semantics • Simple authentication/authorization w/ non-SSL forwarding • Authentication and Authorization providers • Who can connect to input plugins?
 What tags are permitted for clients? • New plugin types (3rd party authors can write it) • Mainly for in/out forward, but available from others
  • 65. Benchmark (1 CPU usage) 100,000msgs/sec v0.14 v0.12 in_tail (none) + out_forward 70% 66% in_forward + flowcounter_simple 11% 11% in_forward + tdlog 43% 38% ※ Use EC2 c3.8xlarge ※ Not fully optimized yet
  • 66. Treasure Agent 3.0 (td-agent 3) • fluentd v0.14 • Ruby 2.3 and latest core components • Environments • Add msi Windows package • Remove CentOS 5, Ubuntu 10.04 support • Release date is not fixed…
  • 69. H.A. configuration (high availability) Retry automatically Exponential retry wait Persistent on a disk buffer Automatic fail-over Load balancing access.log in_tail