-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Initial setup and configuration for Docker Fluent Bit Collector #1
Merged
Merged
Changes from all commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
fb626da
initial-commit
bardabun ad1c822
Refactor based on code review feedback
bardabun 375bbf8
Remove manually download libssl-dev
bardabun 61d55d7
Enhance multi-arch support, add log rename filter, and resolve OpenSS…
bardabun b3a98e0
Update ci-tests.yml
bardabun File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
name: Tests | ||
|
||
on: | ||
pull_request: | ||
branches: | ||
- main | ||
|
||
jobs: | ||
unit-tests: | ||
name: Unit Tests | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@v4 | ||
|
||
# Set up Python environment | ||
- name: Set up Python | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: '3.x' | ||
|
||
- name: Install Python Dependencies | ||
run: | | ||
pip install -r requirements.txt | ||
|
||
# Run Python unit tests | ||
- name: Run Python Unit Tests | ||
run: | | ||
python -m unittest discover -s tests -p 'test_create_fluent_bit_config.py' -v | ||
|
||
# Set up Lua environment | ||
- name: Install Lua and LuaRocks | ||
run: | | ||
sudo apt-get update | ||
sudo apt-get install -y lua5.3 lua5.3-dev luarocks | ||
|
||
- name: Install Lua Dependencies | ||
run: | | ||
sudo luarocks install busted | ||
|
||
# Run Lua unit tests | ||
- name: Run Lua Unit Tests | ||
working-directory: tests | ||
run: | | ||
busted test_docker_metadata.lua | ||
|
||
e2e-tests: | ||
name: End-to-End Tests | ||
needs: unit-tests | ||
runs-on: ubuntu-latest | ||
services: | ||
docker: | ||
image: docker:20.10-dind | ||
options: --privileged | ||
env: | ||
LOGZIO_LOGS_TOKEN: ${{ secrets.LOGZIO_LOGS_TOKEN }} | ||
LOGZIO_API_TOKEN: ${{ secrets.LOGZIO_API_TOKEN }} | ||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@v4 | ||
|
||
# Set up Python environment | ||
- name: Set up Python | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: '3.x' | ||
|
||
- name: Install Python Dependencies | ||
run: | | ||
pip install -r requirements.txt | ||
|
||
# Build Docker Image | ||
- name: Build Docker Image | ||
run: | | ||
docker buildx build --platform linux/amd64 --load -t logzio/docker-logs-collector:amd64-test . | ||
|
||
# Install Docker Compose | ||
- name: Install Docker Compose | ||
run: | | ||
sudo apt-get update | ||
sudo apt-get install -y docker-compose | ||
|
||
# Run Docker Compose | ||
- name: Run Docker Compose | ||
run: docker-compose up -d | ||
|
||
# Wait for logs to be ingested | ||
- name: Wait for Logs to be Ingested | ||
run: sleep 60 # Adjust as necessary | ||
|
||
# Run End-to-End Tests | ||
- name: Run E2E Tests | ||
run: python tests/test_e2e.py | ||
|
||
# Output Docker Collector Logs | ||
- name: Output Docker Collector Logs | ||
if: always() | ||
run: docker logs docker-logs-collector || true | ||
|
||
# Tear down Docker Compose | ||
- name: Tear Down Docker Compose | ||
if: always() | ||
run: docker-compose down | ||
|
||
# Remove Local Docker Image | ||
- name: Remove Local Docker Image | ||
if: always() | ||
run: | | ||
docker rmi logzio/docker-logs-collector:amd64-test || true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
name: Release | ||
|
||
on: | ||
release: | ||
types: [published] | ||
|
||
jobs: | ||
build-and-push-images: | ||
name: Build and Push Multi-Arch Docker Image | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@v4 | ||
|
||
- name: Set up QEMU | ||
uses: docker/setup-qemu-action@v3 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v3 | ||
|
||
- name: Log in to Docker Hub | ||
uses: docker/login-action@v3 | ||
with: | ||
username: ${{ secrets.DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.DOCKERHUB_TOKEN }} | ||
|
||
- name: Build and push multi-arch image | ||
uses: docker/build-push-action@v5 | ||
with: | ||
context: . | ||
push: true | ||
platforms: linux/amd64,linux/arm64 | ||
tags: | | ||
logzio/docker-logs-collector:latest | ||
logzio/docker-logs-collector:${{ github.ref_name }} | ||
|
||
- name: Logout from Docker Hub | ||
if: always() | ||
run: docker logout |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
# syntax=docker/dockerfile:1 | ||
|
||
FROM python:3.12.4-slim-bullseye AS base | ||
|
||
# Install dependencies using apt-get | ||
RUN apt-get update && apt-get install -y --no-install-recommends \ | ||
wget \ | ||
bash \ | ||
libyaml-dev \ | ||
libsystemd-dev \ | ||
libsasl2-dev \ | ||
libpq-dev \ | ||
openssl \ | ||
libssl-dev \ | ||
gdb \ | ||
&& rm -rf /var/lib/apt/lists/* | ||
|
||
# Define build argument for architecture | ||
ARG TARGETARCH | ||
|
||
# Set the plugin URL based on the architecture | ||
ENV LOGZIO_PLUGIN_URL_AMD64=https://github.com/logzio/fluent-bit-logzio-output/raw/master/build/out_logzio-linux.so | ||
ENV LOGZIO_PLUGIN_URL_ARM64=https://github.com/logzio/fluent-bit-logzio-output/raw/master/build/out_logzio-linux-arm64.so | ||
|
||
# Determine the correct plugin URL based on TARGETARCH | ||
RUN mkdir -p /fluent-bit/plugins && \ | ||
if [ "$TARGETARCH" = "amd64" ]; then \ | ||
export LOGZIO_PLUGIN_URL=$LOGZIO_PLUGIN_URL_AMD64; \ | ||
elif [ "$TARGETARCH" = "arm64" ]; then \ | ||
export LOGZIO_PLUGIN_URL=$LOGZIO_PLUGIN_URL_ARM64; \ | ||
else \ | ||
echo "Unsupported architecture: $TARGETARCH"; exit 1; \ | ||
fi && \ | ||
wget -O /fluent-bit/plugins/out_logzio.so $LOGZIO_PLUGIN_URL | ||
|
||
# Set working directory | ||
WORKDIR /opt/fluent-bit | ||
|
||
# Copy configuration files and Lua script | ||
COPY configs/parser_multiline.conf /fluent-bit/etc/parsers_multiline.conf | ||
COPY configs/parsers.conf /fluent-bit/etc/parsers.conf | ||
COPY configs/plugins.conf /fluent-bit/etc/plugins.conf | ||
COPY docker-metadata.lua /fluent-bit/etc/docker-metadata.lua | ||
COPY create_fluent_bit_config.py /opt/fluent-bit/docker-collector-logs/create_fluent_bit_config.py | ||
|
||
# Use official Fluent Bit image for Fluent Bit binaries | ||
FROM fluent/fluent-bit:1.9.10 AS fluent-bit | ||
|
||
# Copy Fluent Bit binary to the base image | ||
FROM base | ||
COPY --from=fluent-bit /fluent-bit/bin/fluent-bit /usr/local/bin/fluent-bit | ||
|
||
# Copy entrypoint script | ||
COPY start.sh /start.sh | ||
RUN chmod +x /start.sh | ||
|
||
# Set the entrypoint to run the shell script | ||
ENTRYPOINT ["/start.sh"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
# docker-logs-collector | ||
|
||
docker-logs-collector is a Docker container that uses Fluent Bit to collect logs from other Docker containers and forward those logs to your Logz.io account. | ||
|
||
To use this container, you'll set environment variables in your `docker run` command. | ||
docker-logs-collector uses those environment variables to generate a valid Fluent Bit configuration for the container. | ||
docker-logs-collector mounts docker.sock and the Docker logs directory to the container itself, allowing Fluent Bit to collect the logs and metadata. | ||
|
||
docker-logs-collector ships logs only. | ||
If you want to ship metrics to Logz.io, see [docker-collector-metrics](https://github.com/logzio/docker-collector-metrics). | ||
|
||
**Note:** | ||
- Ensure your Fluent Bit configuration matches your logging requirements and environment variables are set correctly. | ||
|
||
## docker-logs-collector setup | ||
|
||
### 1. Pull the Docker image | ||
|
||
Download the appropriate Docker image for your architecture (amd64 or arm64): | ||
|
||
```shell | ||
docker pull logzio/docker-logs-collector:latest | ||
``` | ||
|
||
### 2. Run the container | ||
|
||
For a complete list of options, see the parameters below the code block.👇 | ||
|
||
```shell | ||
docker run --name docker-logs-collector \ | ||
--env LOGZIO_LOGS_TOKEN="<LOGS-SHIPPING-TOKEN>" \ | ||
-v /var/run/docker.sock:/var/run/docker.sock:ro \ | ||
-v /var/lib/docker/containers:/var/lib/docker/containers \ | ||
-e HEADERS="user-agent:logzio-docker-logs" \ | ||
logzio/docker-logs-collector:latest | ||
``` | ||
|
||
#### Parameters | ||
|
||
| Parameter | Description | | ||
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ||
| **LOGZIO_LOGS_TOKEN** | **Required**. Your Logz.io account logs token. Replace `<LOGS-SHIPPING-TOKEN>` with the [token](https://app.logz.io/#/dashboard/settings/general) of the account you want to ship to. | | ||
| **LOGZIO_URL** | **Default**: `https://listener.logz.io:8071`.<br> The full URL to send logs to, including your region if needed. For example, for the EU region, use `https://listener-eu.logz.io:8071`. to. | | ||
| **LOGZIO_TYPE** | **Default**: `logzio-docker-logs`. Sets the log type. | | ||
| **MATCH_CONTAINER_NAME** | Specify a container to collect logs from. If the container's name matches, its logs are shipped; otherwise, its logs are ignored. <br /> **Note**: This option cannot be used with SKIP_CONTAINER_NAMES. Use regular expressions to keep records that match a specific field. | | ||
| **SKIP_CONTAINER_NAMES** | Comma-separated list of containers to ignore. If a container's name matches a name on this list, its logs are ignored; otherwise, its logs are shipped. <br /> **Note**: This option cannot be used with MATCH_CONTAINER_NAME. Use regular expressions to exclude records that match a specific field. | | ||
| **MATCH_IMAGE_NAME** | Specify a image to collect logs from. If the image's name matches, its logs are shipped; otherwise, its logs are ignored. <br /> **Note**: This option cannot be used with SKIP_IMAGE_NAMES. Use regular expressions to keep records that match a specific field. | | ||
| **SKIP_IMAGE_NAMES** | Comma-separated list of images to ignore. If a image's name matches a name on this list, its logs are ignored; otherwise, its logs are shipped. <br /> **Note**: This option cannot be used with MATCH_IMAGE_NAME. Use regular expressions to exclude records that match a specific field. | | ||
| **INCLUDE_LINE** | Regular expression to match the lines that you want Fluent Bit to include. | | ||
| **EXCLUDE_LINES** | Regular expression to match the lines that you want Fluent Bit to exclude. | | ||
| **ADDITIONAL_FIELDS** | Include additional fields with every message sent, formatted as `"fieldName1:fieldValue1,fieldName2:fieldValue2"`. | | ||
| **SET_FIELDS** | Set fields with every message sent, formatted as `"fieldName1:fieldValue1,fieldName2:fieldValue2"`. | | ||
| **LOG_LEVEL** | **Default** `info`. Set log level for Fluent Bit. Allowed values are: `debug`, `info`, `warning`, `error`. | | ||
| **MULTILINE_START_STATE_RULE** | Regular expression for the start state rule of multiline parsing. <br /> See [Fluent Bit's official documentation](https://docs.fluentbit.io/manual/administration/configuring-fluent-bit/multiline-parsing#rules-definition) for further info. | | ||
| **MULTILINE_CUSTOM_RULES** | Custom rules for multiline parsing, separated by semicolons `;`. | | ||
| **READ_FROM_HEAD** | **Default** `true`. Specify if Fluent Bit should read logs from the beginning. | | ||
| **OUTPUT_ID** | **Default** `output_id`. Specify the output ID for Fluent Bit logs. | | ||
| **HEADERS** | Custom headers for Fluent Bit logs. | | ||
|
||
|
||
### 3. Check Logz.io for your logs | ||
|
||
Spin up your Docker containers if you haven’t done so already. Give your logs a few minutes to get from your system to your Logz.io account. | ||
|
||
### Change log | ||
|
||
- 0.1.0: | ||
- Initial release using Fluent Bit. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
|
||
[MULTILINE_PARSER] | ||
name multiline-regex | ||
type regex | ||
flush_timeout 1000 | ||
# | ||
# Regex rules for multiline parsing | ||
# --------------------------------- | ||
# | ||
# configuration hints: | ||
# | ||
# - first state always has the name: start_state | ||
# - every field in the rule must be inside double quotes | ||
# | ||
# rules | state name | regex pattern | next state | ||
# ------|---------------|-------------------------------------------- | ||
rule "start_state" "/^\[.*\] .*/" "cont" | ||
rule "cont" "/^\.*/" "cont" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
[PARSER] | ||
Name docker | ||
Format json | ||
Time_Key time | ||
Time_Format %Y-%m-%dT%H:%M:%S.%LZ | ||
Time_Keep On | ||
# Adjust these keys based on the structure of your logs | ||
# This example assumes the logs are in JSON format and the time field is named "time" | ||
Decode_Field_As json log | ||
Decode_Field_As escaped log |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
[PLUGINS] | ||
Path /fluent-bit/plugins/out_logzio.so |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
❗Cycode: Infrastructure configuration issue: 'Specific user should be defined'.
Severity: High
Description
The image will run as root unless a lesser privileged user is defined
Cycode Remediation Guideline
Ensure that at least one USER instruction is defined before or in any none 'FROM scratch' build stage)