Skip to content

Kubernetes Application Controller/Operator for managing cloud native logging.

Notifications You must be signed in to change notification settings

platform9/fluentd-operator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

56 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Log pipeline management for Kubernetes

Logging operator provides Kubernetes native log management for developers and devops teams. Main benefits are:

  • Configure logging using Kubernetes constructs. No need to learn log configurations.
  • Flexibility and Reuse through Kubernetes Custom Resource Definitions.
  • Handles logging service deployment and scaling.
  • Support for popular datastores like ElasticSearch, S3 and Loki.

Concepts

  1. Output: An output defines a datastore where logs are to be stored. Currently, the operator supports ElasticSearch, S3 and Loki as log stores. Outputs are defined at cluster scope -- all logs from containers in the cluster get routed to each output.

Architecture

Logging operator uses fluent-bit and fluentd for collection and processing of logs respectively. The fluent-bit component is deployed as daemonset and is present on each node. Its main function is log formatting and filtering. fluentd is used as aggregator and buffer. It ships logs to chosen datastore. The fluentd layer can scale per log traffic.

Architecture

Install

Simplest way to install is with bundled deploy script

./hack/deploy.sh

If you are curious, deploy.sh creates prerequesite namespaces and applies yaml manifests under deploy/ directory.

Example Usage With Object Store

Samples for all the datastores are stored in examples directory.

The below example shows how to forward logs to an object storage. We will be using S3.

  1. Deploy random logger as kubernetes deployment
kubectl apply -f docs/getting-started/user-guides/random-logger.yaml
  1. Create a bucket named "test" in S3.
  2. Create a kubernetes secret and specify your access and secret keys to gain access to this S3 bucket
apiVersion: v1
kind: Secret
metadata:
  name: s3
type: Opaque
stringData:
  access_key: <aws access key>
  secret_key: <aws secret key>
  1. Create output CR indicating S3 as destination. Note the AWS secrets referenced by specifying the secret name and key within it.
apiVersion: logging.pf9.io/v1alpha1
kind: Output
metadata:
  name: objstore
spec:
  type: s3
  params:
    - name: aws_key_id
      valueFrom:
        name: s3
        namespace: default
        key: access_key
    - name: aws_sec_key
      valueFrom:
        name: s3
        namespace: default
        key: secret_key
    - name: s3_region
      value: <s3 region name>
    - name: s3_bucket
      value: <s3 bucket name>

About

Kubernetes Application Controller/Operator for managing cloud native logging.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •