Fluentd HTTP input plugin for CloudWebManage Logging Component.
This plugin:
- receives the incoming JSON logs from MinIO using an HTTP endpoint,
- validates the required JSON fields,
- aggregates the logging metrics,
- flushes the aggregated metrics to the configured Redis instance; and,
- routes logs to the configured log targets e.g. S3, ElasticSearch, etc.
+------------------+
| MinIO |
+------------------+
|
| JSON
| logs
v
+------------------+
| fluentd |
| |
| +--------------+ | +-----------------+
| | http_cwm | | [metrics] | Redis |
| | (input) |-------------------->| Server |
| +--------------+ | +-----------------+
| |
| +--------------+ | +-----------------+
| | s3 | | [raw logs] | S3 |
| | (output) |-------------------->| (log target) |
| +--------------+ | +-----------------+
| |
| +--------------+ | +-----------------+
| |elasticsearch | | [raw logs] | ElasticSearch |
| | (output) |-------------------->| (log target) |
| +--------------+ | +-----------------+
| |
+------------------+
The following metrics are aggregated:
metric | description |
---|---|
bytes_in |
size of Request header and its Content-Length |
bytes_out |
size of Response header and its Content-Length |
num_requests_in |
count of APIs [WebUpload, PutObject, DeleteObject] |
num_requests_out |
count of APIs [WebDownload, GetObject] |
num_requests_misc |
count of APIs other than in and out |
gem install fluent-plugin-cwm-http
Add the following line to your Gemfile:
gem 'fluent-plugin-cwm-http'
And then execute:
bundle
host
(string) (optional): The address to bind to.- Default value:
localhost
.
- Default value:
port
(integer) (optional): The port to listen to.- Default value:
8080
.
- Default value:
tag
(string) (required): The tag for the event.
host
(string) (optional): The address of Redis server.- Default value:
localhost
.
- Default value:
port
(integer) (optional): The port of Redis server.- Default value:
6379
.
- Default value:
db
(integer) (optional): The db to use.- Default value:
0
.
- Default value:
grace_period
(time) (optional): The grace period for last action update.- Default value:
300s
.
- Default value:
flush_interval
(time) (optional): The flush interval to send metrics.- Default value:
300s
.
- Default value:
last_update_prefix
(string) (optional): The prefix for last update key.- Default value:
deploymentid:last_action
.
- Default value:
metrics_prefix
(string) (optional): The prefix for metrics key.- Default value:
deploymentid:minio-metrics
.
- Default value:
# Endpoint for incoming logs: http://host:port/<tag>
# HTTP Input
<source>
@type http_cwm
@id http_cwm_logs
host localhost
port 8080
tag logs
<redis>
host localhost
port 6379
db 0
grace_period 10s
flush_interval 10s
last_update_prefix deploymentid:last_action
metrics_prefix deploymentid:minio-metrics
</redis>
</source>
# Output e.g. ElasticSearch, S3, etc.
<match logs>
@type elasticsearch
# ...
</match>
The environment variables may also be used for the configuration.
Example:
<source>
@type http_cwm
@id http_cwm_logs
host "#{ENV['HTTP_HOST']}"
port "#{ENV['HTTP_PORT']}"
# ...
</source>
- Fork the project.
- Check out the latest
main
branch. - Create a feature or bugfix branch from
main
. - Commit and push your changes.
- Make sure to add and run tests locally:
bundle exec rake test
. - Run Rubocop locally and fix all the lint warnings.
- Make sure to update Gemfile.lock:
sudo bundle update
. - Submit the PR.
The gem is published via the publish.yml
Workflow on tagging. The tag must be of the format v0.3.0
. This workflow
depends on the successful completion of the ci.yml
workflow and then it looks for the tag. So, make sure that all the CI issues are
resolved before creating a new tag. If there are issues while publishing the gem
i.e. publish workflow doesn't work properly, you can delete and then recreate
the tag to retrigger this workflow.