Skip to content

PayU/fluentBit-sqs-plugin

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

77 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FluentBit AWS-SQS Output Plugin

FluntBit custom output plugin which allows sending messages to AWS-SQS.

Configuration Parameters

Configuration Key Name Description Mandatory
QueueUrl the queue url in your aws account yes
QueueRegion the queue region in your aws account yes
PluginTagAttribute attribute name of the message tag no
QueueMessageGroupId the group id required for fifo queues fifo-only
ProxyUrl the proxy address between fluentbit and sqs (if exists) no
BatchSize set amount of messages to be sent in a batch request yes
[SERVICE]
    Flush        5
    Daemon       Off
    Log_Level    info

    HTTP_Server  On
    HTTP_Listen  0.0.0.0
    HTTP_Port    2020

[INPUT]
    Name   dummy
    Rate   1
    Tag    dummy.log

[OUTPUT]
    Name  sqs
    Match *
    QueueUrl    http://aws-sqs-url.com
    QueueRegion eu-central-1
    BatchSize   10

Installation

Example of installation in docker file:

FROM golang:1.12 as gobuilder

WORKDIR /root

ENV GOOS=linux\
    GOARCH=amd64

COPY / /root/

RUN go build \
    -buildmode=c-shared \
    -o /out_sqs.so \
    github.com/PayU/fluentBit-sqs-plugin

FROM fluent/fluent-bit:1.1

COPY --from=gobuilder /out_sqs.so /fluent-bit/bin/

EXPOSE 2020

ENTRYPOINT ["/fluent-bit/bin/fluent-bit"]
CMD ["-c", "/fluent-bit/etc/some_configuration.conf", "-e", "/fluent-bit/bin/fluentBit-sqs-plugin.so"]

More information about the usage and installation of golang plugins can be found here: https://docs.fluentbit.io/manual/development/golang_plugins

Special Notes

  • Aws Sqs credentials in golang SDK:
    When you initialize a new service client without providing any credential arguments, the SDK uses the default credential provider chain to find AWS credentials. The SDK uses the first provider in the chain that returns credentials without an error. The default provider chain looks for credentials in the following order:

    1. Environment variables. (AWS_SECRET_ACCESS_KEY and AWS_ACCESS_KEY_ID)

    2. Shared credentials file.

    3. If your application is running on an Amazon EC2 instance, IAM role for Amazon EC2. The IAM role should have full access to your SQS and in addition, it should add the following KMS permissions: kms:GenerateDataKey*, kms:Get*, kms:Decrypt*

  • The plugin uses specific environment variable for log level: SQS_OUT_LOG_LEVEL. Supported values are: debug, info or error