Skip to content

Custom arm64v8 / Raspberry Pi 4 version of Official Graylog Docker repo. All changes and README.md are in the Docker/oss-arm64 directory. Only Dockerfile and build script are modified for available arm64v8 dependencies and additional JVM options.

License

Notifications You must be signed in to change notification settings

phantomski77/graylog-docker

 
 

Repository files navigation

Graylog Docker Image

Docker Stars Docker Pulls

The latest stable version of Graylog is 4.3.15.

What is Graylog?

Graylog is a centralized logging solution that enables aggregating and searching through logs. It provides a powerful query language, a processing pipeline for data transformation, alerting abilities, and much more. It is fully extensible through a REST API. Add-ons can be downloaded from the Graylog Marketplace.

Image Details

There are several different image variants available, with variants for Java 8 and 11 on platforms linux/amd64 and linux/arm64. All images are based on the latest Eclipse Temurin image (JRE + Ubuntu LTS variant) available at build time.

Note: Images released prior to August 2022 were based on variants of the now-deprecated openjdk image.

graylog/graylog

This is the open source Graylog image. It contains Graylog as well as the Integrations plugin.

Java Version Platform Tags
OpenJDK 8 linux/amd64, linux/arm64 4.3, 4.3.15, 4.3.15-1
OpenJDK 11 linux/amd64, linux/arm64 4.3-jre11, 4.3.15-jre11, 4.3.15-1-jre11

Note: There is no 'latest' tag. You'll need to specify which version you want.

graylog/graylog-enterprise

This is the Graylog Enterprise image. It contains Graylog, the Graylog Enterprise plugin, the Integrations plugin, and the Enterprise Integrations plugin.

Java Version Platform Tags
OpenJDK 8 linux/amd64 4.3, 4.3.15, 4.3.15-1
OpenJDK 11 linux/amd64 4.3-jre11, 4.3.15-jre11, 4.3.15-1-jre11

graylog/graylog-forwarder

This image runs the Graylog Forwarder. Documentation on the Forwarder can be found here.

The latest stable version is 4.10, with support for Java 8 on platform linux/amd64 and linux/arm64.

Java Version Platform Tags
OpenJDK 8 linux/amd64, linux/arm64 4.10, forwarder-4.10-1

Architecture

Take a look at the minimal Graylog architecture to get the big picture of a Graylog setup. In essence, Graylog needs to talk to MongoDB to store configuration data as well as Elasticsearch to store the actual log data.

Configuration

Please refer to the Graylog Docker documentation for a comprehensive overview and detailed description of the Graylog Docker image.

If you want to quickly spin up an instance for testing, you can use our Docker Compose template.

Notably, this image requires that two important configuration options be set (although in practice you will likely need to set more):

  1. password_secret (environment variable GRAYLOG_PASSWORD_SECRET)
    • A secret that is used for password encryption and salting.
    • Must be at least 16 characters, however using at least 64 characters is strongly recommended.
    • Must be the same on all Graylog nodes in the cluster.
    • May be generated with something like: pwgen -N 1 -s 96
  2. root_password_sha2 (environment variable GRAYLOG_ROOT_PASSWORD_SHA2)
    • A SHA2 hash of a password you will use for your initial login as Graylog's root user.
      • The default username is admin. This value is customizable via configuration option root_username (environment variable GRAYLOG_ROOT_USERNAME).
    • In general, these credentials will only be needed to initially set up the system or reconfigure the system in the event of an authentication backend failure.
    • This password cannot be changed using the API or via the Web interface.
    • May be generated with something like: echo -n "Enter Password: " && head -1 </dev/stdin | tr -d '\n' | sha256sum | cut -d" " -f1

Every Graylog configuration option can be set via environment variable. To get the environment variable name for a given configuration option, simply prefix the option name with GRAYLOG_ and put it all in upper case. Another option is to store the configuration file outside of the container and edit it directly.

This image includes the wait-for-it script, which allows you to have Docker wait for Elasticsearch to start up before starting Graylog. For example, if you are using Docker Compose you could override the entrypoint for Graylog like this:

entrypoint: /usr/bin/tini -- wait-for-it elasticsearch:9200 -- /docker-entrypoint.sh

Documentation

Documentation for Graylog is hosted here. Please read through the docs and familiarize yourself with the functionality before opening an issue on GitHub.

License

Graylog itself is licensed under the Server Side Public License (SSPL), see license information.

This Docker image is licensed under the Apache 2.0 license, see LICENSE.

About

Custom arm64v8 / Raspberry Pi 4 version of Official Graylog Docker repo. All changes and README.md are in the Docker/oss-arm64 directory. Only Dockerfile and build script are modified for available arm64v8 dependencies and additional JVM options.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Dockerfile 36.9%
  • Shell 35.5%
  • Groovy 21.0%
  • Python 3.2%
  • Smarty 2.7%
  • Makefile 0.7%