nixpkgs/nixos/modules/services/databases/hbase-standalone.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

149 lines
3.8 KiB
Nix
Raw Normal View History

{ config, options, lib, pkgs, ... }:
2014-11-20 11:29:07 +00:00
with lib;
let
2022-05-07 13:30:04 +01:00
cfg = config.services.hbase-standalone;
opt = options.services.hbase-standalone;
buildProperty = configAttr:
(builtins.concatStringsSep "\n"
(lib.mapAttrsToList
(name: value: ''
<property>
<name>${name}</name>
<value>${builtins.toString value}</value>
</property>
'')
configAttr));
configFile = pkgs.writeText "hbase-site.xml"
''<configuration>
${buildProperty (opt.settings.default // cfg.settings)}
</configuration>
'';
configDir = pkgs.runCommand "hbase-config-dir" { preferLocalBuild = true; } ''
mkdir -p $out
cp ${cfg.package}/conf/* $out/
rm $out/hbase-site.xml
ln -s ${configFile} $out/hbase-site.xml
'' ;
2014-11-20 11:29:07 +00:00
in {
imports = [
(mkRenamedOptionModule [ "services" "hbase" ] [ "services" "hbase-standalone" ])
];
2014-11-20 11:29:07 +00:00
###### interface
options = {
2022-05-07 13:30:04 +01:00
services.hbase-standalone = {
2014-11-20 11:29:07 +00:00
enable = mkEnableOption (lib.mdDoc ''
2022-05-07 13:30:04 +01:00
HBase master in standalone mode with embedded regionserver and zookeper.
Do not use this configuration for production nor for evaluating HBase performance.
'');
2014-11-20 11:29:07 +00:00
package = mkOption {
type = types.package;
default = pkgs.hbase;
defaultText = literalExpression "pkgs.hbase";
description = lib.mdDoc ''
2014-11-20 11:29:07 +00:00
HBase package to use.
'';
};
user = mkOption {
type = types.str;
2014-11-20 11:29:07 +00:00
default = "hbase";
description = lib.mdDoc ''
2014-11-20 11:29:07 +00:00
User account under which HBase runs.
'';
};
group = mkOption {
type = types.str;
2014-11-20 11:29:07 +00:00
default = "hbase";
description = lib.mdDoc ''
2014-11-20 11:29:07 +00:00
Group account under which HBase runs.
'';
};
dataDir = mkOption {
type = types.path;
default = "/var/lib/hbase";
description = lib.mdDoc ''
2014-11-20 11:29:07 +00:00
Specifies location of HBase database files. This location should be
writable and readable for the user the HBase service runs as
(hbase by default).
'';
};
logDir = mkOption {
type = types.path;
default = "/var/log/hbase";
description = lib.mdDoc ''
2014-11-20 11:29:07 +00:00
Specifies the location of HBase log files.
'';
};
settings = mkOption {
type = with lib.types; attrsOf (oneOf [ str int bool ]);
default = {
"hbase.rootdir" = "file://${cfg.dataDir}/hbase";
"hbase.zookeeper.property.dataDir" = "${cfg.dataDir}/zookeeper";
};
defaultText = literalExpression ''
{
"hbase.rootdir" = "file://''${config.${opt.dataDir}}/hbase";
"hbase.zookeeper.property.dataDir" = "''${config.${opt.dataDir}}/zookeeper";
}
'';
description = lib.mdDoc ''
configurations in hbase-site.xml, see <https://github.com/apache/hbase/blob/master/hbase-server/src/test/resources/hbase-site.xml> for details.
'';
};
2014-11-20 11:29:07 +00:00
};
};
###### implementation
2022-05-07 13:30:04 +01:00
config = mkIf cfg.enable {
2014-11-20 11:29:07 +00:00
systemd.tmpfiles.rules = [
"d '${cfg.dataDir}' - ${cfg.user} ${cfg.group} - -"
"d '${cfg.logDir}' - ${cfg.user} ${cfg.group} - -"
];
2014-11-20 11:29:07 +00:00
systemd.services.hbase = {
description = "HBase Server";
wantedBy = [ "multi-user.target" ];
environment = {
# JRE 15 removed option `UseConcMarkSweepGC` which is needed.
JAVA_HOME = "${pkgs.jre8}";
2014-11-20 11:29:07 +00:00
HBASE_LOG_DIR = cfg.logDir;
};
serviceConfig = {
User = cfg.user;
Group = cfg.group;
ExecStart = "${cfg.package}/bin/hbase --config ${configDir} master start";
2014-11-20 11:29:07 +00:00
};
};
users.users.hbase = {
2014-11-20 11:29:07 +00:00
description = "HBase Server user";
group = "hbase";
uid = config.ids.uids.hbase;
};
users.groups.hbase.gid = config.ids.gids.hbase;
2014-11-20 11:29:07 +00:00
};
}