Skip to content

Releases: telenornms/skogul

v0.23.0

06 Jul 10:51
68c6786
Compare
Choose a tag to compare

Release date: 2023-06-06

Bump Juniper telemetry protocolbuffers from Junos 21.3R1 to 23.2R1.

Adds a small fix to the influx sender, preventing it from sending
empty tag strings to Influx. Fixes #294.

Adds support for renaming metadata and data fields using the "rename"
key to the metadata/data transformer. Example::

"transformers": {
	"ok": {
		"type": "data",
		"rename": [
			{ "source": "old_key_name", "destination": "new_key_name" }
		]
}

v0.22.0

09 May 11:11
1f98be5
Compare
Choose a tag to compare

Release date: 2023-05-09

Add JSON unmarshalling to SQL receiver, add unflatten to metadata
transformer as well, and allow banning with ban transformer by path.

v0.21.1

27 Feb 14:51
f7972b3
Compare
Choose a tag to compare

Release date: 2023-02-27

Add SIGHUP-handling to file-sender.

Add JSON-casting to cast transformer.

Upgrade to Go 1.20, and bump various libs past security lol.

v0.21.0

10 Feb 07:06
8249c69
Compare
Choose a tag to compare

Release date: 2023-02-10

Add NATS sender and receiver (thanks Niklas Holmstedt!), add support for
"match any"/presence in switch-transformer and fix a minor issue where
blank string could never match.

v0.20.11

05 Jan 13:18
7712880
Compare
Choose a tag to compare

Release date: 2023-01-05

Releases v0.20.0 to v0.20.10 are all build-system/CI/CD-related tweaks and
basically irrelevant to end users.

The following is the release notes for v0.20.0:

This is a small, but important release that adds support for loadable
plugins, and also the LineFileAdvanced file reader that allows log
rotation-based file reading (e.g.: Move a file, send sigup, then parse it).

The plugin support is very much experimental, see docs/plugins.rst for
discussion. There's also an example-plugin at
https://github.com/telenornms/skogul-plugin-example which demonstrates how
to build an out-of-tree plugin.

Skogul v0.19.1

15 Nov 10:33
9b11e3c
Compare
Choose a tag to compare

Release date: 2022-11-15

This is an "emergency release" of sorts, that REMOVES SQLITE SUPPORT.

We need to nuke this because it introduces what turned out to be unacceptable dependencies which can't be (easily) met on, e.g., CentOS 7.

This means Skogul 0.19.0 RPMS wont work on CentOS/RHEL 7, while Skogul 0.19.1 should.

Sorry for the inconvenience. We will re-visit SQLite when a more appropriate library can be used.

Skogul v0.19.0

14 Nov 19:22
4392c5b
Compare
Choose a tag to compare

Release date: 2022-11-14

Somewhat large release, but:

  • Drone is on the fringe, so manual release. GH actions incoming.
  • New SQLite sender
  • New Experimental prometheus parser
  • New unflatten transformer
  • Cast transformer: Add casting of IPs to integers

Minor:

  • Several minor chores from Håkon Solbjørg that increases consistency and correctness, with minor negative user-impact.
  • Splunk: Send metadata as fields to spluk HEC
  • Deperecate "Path" and use "File" instead for consistency (deprecation, old configs will keep working)
  • Add KeepOriginal flag to the Data transformer
  • Many log cleanups

All in all, this is a larger release than we'd like, but also largely isolated features.

Since this will be a manual release, it might deviate SLIGHTLY from the other releases, but should be mostly the same.

Skogul v0.18.0

20 Sep 10:28
9fd26e9
Compare
Choose a tag to compare

Release date: 2022-09-20

Adds USP protocol buffer parser and AVRO encoder/parser time support, adds
worksarounds for Juniper -Inf transceivers, adds dummy parser.

USP

The USP parser will parse a protocol buffer-encoded USP message contained
in a record, and use the payload as JSON. This might change if hardware
surfaces that use USP differently.

AVRO

The AVRO encoder/parser now handles time fields, using a minor workaround.
Shouldn't require any changes for users.

Juniper

We now apply various hacks to fix #218, where juniper telemetry reports
-Infinity, which is impossible to encode as JSON. Intead, we silently
convert it to -40, horrifying any mathematicians in the room.

Dummy parser

The dummy parser is meant as a developer-tool where we can save un-parsed
bytes to disk, thereby allowing us to acquire test data for development.
Not useful in any production environment.

Skogul v0.17.0

24 Aug 09:51
54f96c1
Compare
Choose a tag to compare

Release date: 2022-08-24

In short:

  • AVRO and GOB encoding and parsing
  • SQL receiver
  • Encoder-support in file sender
  • Docker images!

Docker images - first release, so let's see how well this works :D

SQL receiver will periodically poll an SQL database for data, it is a bit
immature, but it should be solid. You write a query, the query needs a
field named 'time' (select foo as TIME ...) for the timestamp, and you also
select which columns are metadata - the rest will be data.

While GOB could theoretically improve performance, it's not possible in
practice because GOB isn't schemaless, but embeds a schema in the initial
packet. This means that GOB data depends on the receiver having the initial
packet, and there is no convenient way to achieve that except
re-initializing the encoder every time. The end result is that gob is no
better or worse then JSON in regards to performance, but, unlike JSON, it
can support every data type that Go supports, fully, without losing
accuracy.

The AVRO format is still missing support for timestamps, see #247, but
that's being worked on.

To use AVRO, you need to specify a schema. One is provided in
docs/examples/avro, which is a very generic schema. You can write a more
specific one as well, for your specific data, but so far there is no
support for time stamps. To be able to actually USE Avro today, you need to
add a transformer on the handler to add a timestamp.

Skogul v0.16.0

28 May 19:25
1ab4768
Compare
Choose a tag to compare

Release date: 2022-05-28

TL;DR:

  • Kafka sender and receiver
  • Default configuration file moved to /etc/skogul/conf.d in systemd units
  • Enricher transformer MUST be used together with enricher updater sender
  • "Wholefile" receiver will read a file and treat it as a single container
  • Much needed docs/examples cleanup
  • Dummy timestamp transformer

If you are using an unaltered systemd unit file and our RPM packages, you
will have to move your configuration from /etc/skogul/default.json into
/etc/skogul/conf.d/ - the file name can be whatever, as long as it ends in
.json - Skogul will load every configuration file present.

This better allows dynamic configuration through, e.g., Ansible and is
what we've been using for a while.

The Kafka sender has one little quirk: Since Kafka allows batching messages
natively, it was decided that it is better for overall performance to
encode each metric in a container as an individual message, instead of
encoding the entire container as one message. This will better exploit the
nature of Kafka and make it easier to use the data, hopefully.

The enricher also went through a major simplification: It no longer has a
native loader function, and instead you have to configure an enricher
updater sender. The configuration becomes slightly more cumbersome, but the
end result is a much more elegant solution.