nixos/services.kubernetes.scheduler: remove with lib;
This commit is contained in:
@@ -1,7 +1,4 @@
|
|||||||
{ config, lib, options, pkgs, ... }:
|
{ config, lib, options, pkgs, ... }:
|
||||||
|
|
||||||
with lib;
|
|
||||||
|
|
||||||
let
|
let
|
||||||
top = config.services.kubernetes;
|
top = config.services.kubernetes;
|
||||||
otop = options.services.kubernetes;
|
otop = options.services.kubernetes;
|
||||||
@@ -11,42 +8,42 @@ in
|
|||||||
###### interface
|
###### interface
|
||||||
options.services.kubernetes.scheduler = with lib.types; {
|
options.services.kubernetes.scheduler = with lib.types; {
|
||||||
|
|
||||||
address = mkOption {
|
address = lib.mkOption {
|
||||||
description = "Kubernetes scheduler listening address.";
|
description = "Kubernetes scheduler listening address.";
|
||||||
default = "127.0.0.1";
|
default = "127.0.0.1";
|
||||||
type = str;
|
type = str;
|
||||||
};
|
};
|
||||||
|
|
||||||
enable = mkEnableOption "Kubernetes scheduler";
|
enable = lib.mkEnableOption "Kubernetes scheduler";
|
||||||
|
|
||||||
extraOpts = mkOption {
|
extraOpts = lib.mkOption {
|
||||||
description = "Kubernetes scheduler extra command line options.";
|
description = "Kubernetes scheduler extra command line options.";
|
||||||
default = "";
|
default = "";
|
||||||
type = separatedString " ";
|
type = separatedString " ";
|
||||||
};
|
};
|
||||||
|
|
||||||
featureGates = mkOption {
|
featureGates = lib.mkOption {
|
||||||
description = "Attribute set of feature gates.";
|
description = "Attribute set of feature gates.";
|
||||||
default = top.featureGates;
|
default = top.featureGates;
|
||||||
defaultText = literalExpression "config.${otop.featureGates}";
|
defaultText = lib.literalExpression "config.${otop.featureGates}";
|
||||||
type = attrsOf bool;
|
type = attrsOf bool;
|
||||||
};
|
};
|
||||||
|
|
||||||
kubeconfig = top.lib.mkKubeConfigOptions "Kubernetes scheduler";
|
kubeconfig = top.lib.mkKubeConfigOptions "Kubernetes scheduler";
|
||||||
|
|
||||||
leaderElect = mkOption {
|
leaderElect = lib.mkOption {
|
||||||
description = "Whether to start leader election before executing main loop.";
|
description = "Whether to start leader election before executing main loop.";
|
||||||
type = bool;
|
type = bool;
|
||||||
default = true;
|
default = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
port = mkOption {
|
port = lib.mkOption {
|
||||||
description = "Kubernetes scheduler listening port.";
|
description = "Kubernetes scheduler listening port.";
|
||||||
default = 10251;
|
default = 10251;
|
||||||
type = port;
|
type = port;
|
||||||
};
|
};
|
||||||
|
|
||||||
verbosity = mkOption {
|
verbosity = lib.mkOption {
|
||||||
description = ''
|
description = ''
|
||||||
Optional glog verbosity level for logging statements. See
|
Optional glog verbosity level for logging statements. See
|
||||||
<https://github.com/kubernetes/community/blob/master/contributors/devel/logging.md>
|
<https://github.com/kubernetes/community/blob/master/contributors/devel/logging.md>
|
||||||
@@ -58,7 +55,7 @@ in
|
|||||||
};
|
};
|
||||||
|
|
||||||
###### implementation
|
###### implementation
|
||||||
config = mkIf cfg.enable {
|
config = lib.mkIf cfg.enable {
|
||||||
systemd.services.kube-scheduler = {
|
systemd.services.kube-scheduler = {
|
||||||
description = "Kubernetes Scheduler Service";
|
description = "Kubernetes Scheduler Service";
|
||||||
wantedBy = [ "kubernetes.target" ];
|
wantedBy = [ "kubernetes.target" ];
|
||||||
@@ -67,12 +64,12 @@ in
|
|||||||
Slice = "kubernetes.slice";
|
Slice = "kubernetes.slice";
|
||||||
ExecStart = ''${top.package}/bin/kube-scheduler \
|
ExecStart = ''${top.package}/bin/kube-scheduler \
|
||||||
--bind-address=${cfg.address} \
|
--bind-address=${cfg.address} \
|
||||||
${optionalString (cfg.featureGates != {})
|
${lib.optionalString (cfg.featureGates != {})
|
||||||
"--feature-gates=${concatStringsSep "," (builtins.attrValues (mapAttrs (n: v: "${n}=${trivial.boolToString v}") cfg.featureGates))}"} \
|
"--feature-gates=${lib.concatStringsSep "," (builtins.attrValues (lib.mapAttrs (n: v: "${n}=${lib.trivial.boolToString v}") cfg.featureGates))}"} \
|
||||||
--kubeconfig=${top.lib.mkKubeConfig "kube-scheduler" cfg.kubeconfig} \
|
--kubeconfig=${top.lib.mkKubeConfig "kube-scheduler" cfg.kubeconfig} \
|
||||||
--leader-elect=${boolToString cfg.leaderElect} \
|
--leader-elect=${lib.boolToString cfg.leaderElect} \
|
||||||
--secure-port=${toString cfg.port} \
|
--secure-port=${toString cfg.port} \
|
||||||
${optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \
|
${lib.optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \
|
||||||
${cfg.extraOpts}
|
${cfg.extraOpts}
|
||||||
'';
|
'';
|
||||||
WorkingDirectory = top.dataDir;
|
WorkingDirectory = top.dataDir;
|
||||||
@@ -94,7 +91,7 @@ in
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
services.kubernetes.scheduler.kubeconfig.server = mkDefault top.apiserverAddress;
|
services.kubernetes.scheduler.kubeconfig.server = lib.mkDefault top.apiserverAddress;
|
||||||
};
|
};
|
||||||
|
|
||||||
meta.buildDocsInSandbox = false;
|
meta.buildDocsInSandbox = false;
|
||||||
|
|||||||
Reference in New Issue
Block a user