kminion: 2.2.7 → 2.2.13, init module (#318792)
This commit is contained in:
commit
4b66d476f3
@ -92,6 +92,8 @@
|
|||||||
|
|
||||||
- [conman](https://github.com/dun/conman), a serial console management program. Available as [services.conman](#opt-services.conman.enable).
|
- [conman](https://github.com/dun/conman), a serial console management program. Available as [services.conman](#opt-services.conman.enable).
|
||||||
|
|
||||||
|
- [KMinion](https://github.com/redpanda-data/kminion), feature-rich Prometheus exporter for Apache Kafka. Available as [services.prometheus.exporters.kafka](options.html#opt-services.prometheus.exporters.kafka).
|
||||||
|
|
||||||
## Backward Incompatibilities {#sec-release-25.11-incompatibilities}
|
## Backward Incompatibilities {#sec-release-25.11-incompatibilities}
|
||||||
|
|
||||||
<!-- To avoid merge conflicts, consider adding your item at an arbitrary place in the list instead. -->
|
<!-- To avoid merge conflicts, consider adding your item at an arbitrary place in the list instead. -->
|
||||||
|
|||||||
@ -79,6 +79,7 @@ let
|
|||||||
"jitsi"
|
"jitsi"
|
||||||
"json"
|
"json"
|
||||||
"junos-czerwonk"
|
"junos-czerwonk"
|
||||||
|
"kafka"
|
||||||
"kea"
|
"kea"
|
||||||
"keylight"
|
"keylight"
|
||||||
"klipper"
|
"klipper"
|
||||||
|
|||||||
@ -0,0 +1,56 @@
|
|||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.services.prometheus.exporters.kafka;
|
||||||
|
inherit (lib)
|
||||||
|
mkIf
|
||||||
|
mkOption
|
||||||
|
mkMerge
|
||||||
|
types
|
||||||
|
concatStringsSep
|
||||||
|
;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
port = 8080;
|
||||||
|
|
||||||
|
extraOpts = {
|
||||||
|
package = lib.mkPackageOption pkgs "kminion" { };
|
||||||
|
|
||||||
|
environmentFile = mkOption {
|
||||||
|
type = with types; nullOr path;
|
||||||
|
default = null;
|
||||||
|
description = ''
|
||||||
|
File containing the credentials to access the repository, in the
|
||||||
|
format of an EnvironmentFile as described by systemd.exec(5)
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
serviceOpts = mkMerge (
|
||||||
|
[
|
||||||
|
{
|
||||||
|
serviceConfig = {
|
||||||
|
ExecStart = ''
|
||||||
|
${lib.getExe cfg.package}
|
||||||
|
'';
|
||||||
|
EnvironmentFile = mkIf (cfg.environmentFile != null) cfg.environmentFile;
|
||||||
|
RestartSec = "5s";
|
||||||
|
RestrictAddressFamilies = [
|
||||||
|
"AF_INET"
|
||||||
|
"AF_INET6"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
++ [
|
||||||
|
(mkIf config.services.apache-kafka.enable {
|
||||||
|
after = [ "apache-kafka.service" ];
|
||||||
|
requires = [ "apache-kafka.service" ];
|
||||||
|
})
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
||||||
@ -587,6 +587,63 @@ let
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
kafka = {
|
||||||
|
exporterConfig = {
|
||||||
|
enable = true;
|
||||||
|
environmentFile = pkgs.writeTextFile {
|
||||||
|
name = "/tmp/prometheus-kafka-exporter.env";
|
||||||
|
text = ''
|
||||||
|
KAFKA_BROKERS="localhost:9092"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
metricProvider = {
|
||||||
|
services.apache-kafka = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
clusterId = "pHG8aWuXSfWAibHFDCnsCQ";
|
||||||
|
|
||||||
|
formatLogDirs = true;
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
"node.id" = 1;
|
||||||
|
"process.roles" = [
|
||||||
|
"broker"
|
||||||
|
"controller"
|
||||||
|
];
|
||||||
|
"listeners" = [
|
||||||
|
"PLAINTEXT://:9092"
|
||||||
|
"CONTROLLER://:9093"
|
||||||
|
];
|
||||||
|
"listener.security.protocol.map" = [
|
||||||
|
"PLAINTEXT:PLAINTEXT"
|
||||||
|
"CONTROLLER:PLAINTEXT"
|
||||||
|
];
|
||||||
|
"controller.quorum.voters" = [
|
||||||
|
"1@localhost:9093"
|
||||||
|
];
|
||||||
|
"controller.listener.names" = [ "CONTROLLER" ];
|
||||||
|
"log.dirs" = [ "/var/lib/apache-kafka" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.services.apache-kafka.serviceConfig.StateDirectory = "apache-kafka";
|
||||||
|
};
|
||||||
|
exporterTest = ''
|
||||||
|
wait_for_unit("apache-kafka")
|
||||||
|
wait_for_open_port(9092)
|
||||||
|
wait_for_open_port(9093)
|
||||||
|
wait_for_unit("prometheus-kafka-exporter.service")
|
||||||
|
wait_for_open_port(8080)
|
||||||
|
wait_until_succeeds(
|
||||||
|
"journalctl -o cat -u prometheus-kafka-exporter.service | grep '\"version\":\"${pkgs.kminion.version}\"'"
|
||||||
|
)
|
||||||
|
succeed(
|
||||||
|
"curl -sSf http://localhost:8080/metrics | grep 'kminion_exporter_up'"
|
||||||
|
)
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
knot = {
|
knot = {
|
||||||
exporterConfig = {
|
exporterConfig = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|||||||
@ -2,30 +2,42 @@
|
|||||||
lib,
|
lib,
|
||||||
fetchFromGitHub,
|
fetchFromGitHub,
|
||||||
buildGoModule,
|
buildGoModule,
|
||||||
|
nixosTests,
|
||||||
}:
|
}:
|
||||||
|
|
||||||
buildGoModule {
|
buildGoModule (finalAttrs: {
|
||||||
pname = "kafka-minion";
|
pname = "kafka-minion";
|
||||||
version = "2.2.7";
|
version = "2.2.13";
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "redpanda-data";
|
owner = "redpanda-data";
|
||||||
repo = "kminion";
|
repo = "kminion";
|
||||||
rev = "0c90d4301ed4600d1aaf3345b6f16587d2f282fc";
|
rev = "v${finalAttrs.version}";
|
||||||
hash = "sha256-CWjX46Sfc9Xj+R7+CZeMuTY0iUStzyZXI4FotwqR44M=";
|
hash = "sha256-s7kHMMU/srqww/N5szTvX6hOFDV9k9hm+0EZUxIj9So=";
|
||||||
};
|
};
|
||||||
|
|
||||||
vendorHash = "sha256-6yfQVoY/bHMA4s0IN5ltnQdHWnE3kIKza36uEcGa11U=";
|
vendorHash = "sha256-vdbSKEWlFH4UkuBxu0LFs8+Rwa4aWTjE8gD4zKuvcs4=";
|
||||||
|
|
||||||
doCheck = false;
|
doCheck = false;
|
||||||
|
|
||||||
passthru.updateScript = ./update.sh;
|
ldflags = [
|
||||||
|
"-s"
|
||||||
|
"-w"
|
||||||
|
"-X main.version=${finalAttrs.version}"
|
||||||
|
"-X main.builtAt=unknown"
|
||||||
|
];
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
tests = {
|
||||||
|
inherit (nixosTests.prometheus-exporters) kafka;
|
||||||
|
};
|
||||||
|
updateScript = ./update.sh;
|
||||||
|
};
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
description = "Feature-rich Prometheus exporter for Apache Kafka written in Go";
|
description = "Feature-rich Prometheus exporter for Apache Kafka written in Go";
|
||||||
license = licenses.mit;
|
license = licenses.mit;
|
||||||
platforms = platforms.linux;
|
|
||||||
maintainers = with maintainers; [ cafkafk ];
|
maintainers = with maintainers; [ cafkafk ];
|
||||||
mainProgram = "kminion";
|
mainProgram = "kminion";
|
||||||
};
|
};
|
||||||
}
|
})
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user