Skip to main content

CLI/daemon to help with log archiving to OpenStack Swift

Project description

Reads RabbitMQ, reads Graylog+ElasticSearch JSON dumps.

Writes daily/hourly logs files to OpenStack Swift.

Encrypts data on the fly using qpress (.qz1) and GnuPG.

Why? Organised long term storage of logs.

Output file format

Time is duplicated in the file, as the datetime is taken from the JSON object. The compression will take care of excess size:

2020-01-25T00:00:12.217000Z: {"some": "json", "dict": "..."}
2020-01-25T00:00:12.496000Z: {"another": "json", "object": "..."}
...

Target file names will look like:

example-swift-container-2020/example.rabbit.queue/2020/05/31/
  example.rabbit-queue_2020-05-25T00:00:00Z+3600-0x72272_keyid.qz1.gpg

Which means:

  • the target container is example-swift-container-2020;

  • the source queue is example.rabbit.queue;

  • the first message is after 2020-05-25, at 00:00:00 (UTC);

  • the last message is before that time +3600 (i.e. one hour later);

  • there are no late message (-0);

  • the file contains 72272 lines (records).

  • keyid may describe which node this was produced on, and a short identifier which symmetric gpg key was used.

So, if you’re looking for old records, you can:

  • find all files in the right period (also check nearby files with -N-times);

  • fetch, decrypt and decompress the files;

  • scan the lines by the consistently formatted timestamps.

TODO

  • Add commands, so we can do ‘ls’ and ‘get’ and ‘post’ on the archived files. (Use argparse.)

  • Add sample ini-file.

  • Fix suffix (split node-X and keyname).

  • Add Immutable middleware to Swift so we can make it harder to accidentally delete stored logs.

  • Don’t forget about chmod 600 in swiftbunny.ini and chmod 700 on /var/spool/swiftbunny.

Project details


Release history Release notifications | RSS feed

This version

1.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

swiftbunny-1.1.tar.gz (30.4 kB view details)

Uploaded Source

File details

Details for the file swiftbunny-1.1.tar.gz.

File metadata

  • Download URL: swiftbunny-1.1.tar.gz
  • Upload date:
  • Size: 30.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.9.1 pkginfo/1.4.1 requests/2.18.4 setuptools/37.0.0 requests-toolbelt/0.8.0 tqdm/4.19.4 CPython/2.7.17

File hashes

Hashes for swiftbunny-1.1.tar.gz
Algorithm Hash digest
SHA256 849f9fc77e9dc109c07a1a0f7732650b6f6d3986e211920cd4cb65f781ca9ce3
MD5 9c93dcda02d1f4b7e1cb4d8802206cb0
BLAKE2b-256 04904a3b015a73a771fc6eaf73f1b18543d006899050e457d2bf5fa17066c9d1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page