diff --git a/Graylog/.env b/Graylog/.env new file mode 100644 index 0000000..9769c94 --- /dev/null +++ b/Graylog/.env @@ -0,0 +1,14 @@ +# You MUST set a secret to secure/pepper the stored user passwords here. Use at least 64 characters. +# Generate one by using for example: pwgen -N 1 -s 96 +# ATTENTION: This value must be the same on all Graylog nodes in the cluster. +# Changing this value after installation will render all user sessions and encrypted values in the database invalid. (e.g. encrypted access tokens) +GRAYLOG_PASSWORD_SECRET="" + +# You MUST specify a hash password for the root user (which you only need to initially set up the +# system and in case you lose connectivity to your authentication backend) +# This password cannot be changed using the API or via the web interface. If you need to change it, +# modify it in this file. +# Create one by using for example: echo -n yourpassword | shasum -a 256 +# and put the resulting hash value into the following line +# CHANGE THIS! +GRAYLOG_ROOT_PASSWORD_SHA2="" \ No newline at end of file diff --git a/Graylog/docker-compose.yml b/Graylog/docker-compose.yml new file mode 100644 index 0000000..22c811c --- /dev/null +++ b/Graylog/docker-compose.yml @@ -0,0 +1,69 @@ +services: + mongodb: + image: "mongo:5.0" + volumes: + - "mongodb_data:/data/db" + restart: "on-failure" + + datanode: + image: "${DATANODE_IMAGE:-graylog/graylog-datanode:5.2}" + hostname: "datanode" + environment: + GRAYLOG_DATANODE_NODE_ID_FILE: "/var/lib/graylog-datanode/node-id" + GRAYLOG_DATANODE_PASSWORD_SECRET: "${GRAYLOG_PASSWORD_SECRET:?Please configure GRAYLOG_PASSWORD_SECRET in the .env file}" + GRAYLOG_DATANODE_ROOT_PASSWORD_SHA2: "${GRAYLOG_ROOT_PASSWORD_SHA2:?Please configure GRAYLOG_ROOT_PASSWORD_SHA2 in the .env file}" + GRAYLOG_DATANODE_MONGODB_URI: "mongodb://mongodb:27017/graylog" + ulimits: + memlock: + hard: -1 + soft: -1 + nofile: + soft: 65536 + hard: 65536 + ports: + - "8999:8999/tcp" # DataNode API + - "9200:9200/tcp" + - "9300:9300/tcp" + volumes: + - "graylog-datanode:/var/lib/graylog-datanode" + restart: "on-failure" + + graylog: + hostname: "server" + image: "${GRAYLOG_IMAGE:-graylog/graylog-enterprise:5.2}" + depends_on: + mongodb: + condition: "service_started" + entrypoint: "/usr/bin/tini -- /docker-entrypoint.sh" + environment: + GRAYLOG_NODE_ID_FILE: "/usr/share/graylog/data/data/node-id" + GRAYLOG_PASSWORD_SECRET: "${GRAYLOG_PASSWORD_SECRET:?Please configure GRAYLOG_PASSWORD_SECRET in the .env file}" + GRAYLOG_ROOT_PASSWORD_SHA2: "${GRAYLOG_ROOT_PASSWORD_SHA2:?Please configure GRAYLOG_ROOT_PASSWORD_SHA2 in the .env file}" + GRAYLOG_HTTP_BIND_ADDRESS: "0.0.0.0:9000" + GRAYLOG_HTTP_EXTERNAL_URI: "http://localhost:9000/" + GRAYLOG_MONGODB_URI: "mongodb://mongodb:27017/graylog" + # To make reporting (headless_shell) work inside a Docker container + GRAYLOG_REPORT_DISABLE_SANDBOX: "true" + ports: + - "5044:5044/tcp" # Beats + - "5140:5140/tcp" # Syslog TCP + - "5140:5140/udp" # Syslog UDP + - "5555:5555/tcp" # RAW TCP + - "5555:5555/udp" # RAW TCP + - "9000:9000/tcp" # Server API + - "12201:12201/tcp" # GELF TCP + - "12201:12201/udp" # GELF UDP + #- "10000:10000/tcp" # Custom TCP port + #- "10000:10000/udp" # Custom UDP port + - "13301:13301/tcp" # Forwarder data + - "13302:13302/tcp" # Forwarder config + volumes: + - "graylog_data:/usr/share/graylog/data/data" + - "graylog_journal:/usr/share/graylog/data/journal" + restart: "on-failure" + +volumes: + mongodb_data: + graylog-datanode: + graylog_data: + graylog_journal: \ No newline at end of file