2014-11-20 03:29:07 -08:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.hbase;
|
|
|
|
|
2014-11-20 07:22:07 -08:00
|
|
|
configFile = pkgs.writeText "hbase-site.xml" ''
|
|
|
|
<configuration>
|
|
|
|
<property>
|
|
|
|
<name>hbase.rootdir</name>
|
|
|
|
<value>file://${cfg.dataDir}/hbase</value>
|
|
|
|
</property>
|
|
|
|
<property>
|
|
|
|
<name>hbase.zookeeper.property.dataDir</name>
|
|
|
|
<value>${cfg.dataDir}/zookeeper</value>
|
|
|
|
</property>
|
|
|
|
</configuration>
|
|
|
|
'';
|
|
|
|
|
|
|
|
configDir = pkgs.runCommand "hbase-config-dir" {} ''
|
|
|
|
mkdir -p $out
|
|
|
|
cp ${cfg.package}/conf/* $out/
|
|
|
|
rm $out/hbase-site.xml
|
|
|
|
ln -s ${configFile} $out/hbase-site.xml
|
|
|
|
'' ;
|
|
|
|
|
2014-11-20 03:29:07 -08:00
|
|
|
in {
|
|
|
|
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
services.hbase = {
|
|
|
|
|
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
Whether to run HBase.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
package = mkOption {
|
|
|
|
type = types.package;
|
|
|
|
default = pkgs.hbase;
|
|
|
|
example = literalExample "pkgs.hbase";
|
|
|
|
description = ''
|
|
|
|
HBase package to use.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
user = mkOption {
|
|
|
|
type = types.string;
|
|
|
|
default = "hbase";
|
|
|
|
description = ''
|
|
|
|
User account under which HBase runs.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
group = mkOption {
|
|
|
|
type = types.string;
|
|
|
|
default = "hbase";
|
|
|
|
description = ''
|
|
|
|
Group account under which HBase runs.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
dataDir = mkOption {
|
|
|
|
type = types.path;
|
|
|
|
default = "/var/lib/hbase";
|
|
|
|
description = ''
|
|
|
|
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 = ''
|
|
|
|
Specifies the location of HBase log files.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
|
|
|
config = mkIf config.services.hbase.enable {
|
|
|
|
|
|
|
|
systemd.services.hbase = {
|
|
|
|
description = "HBase Server";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
|
|
|
|
environment = {
|
|
|
|
JAVA_HOME = "${pkgs.jre}";
|
|
|
|
HBASE_LOG_DIR = cfg.logDir;
|
|
|
|
};
|
|
|
|
|
2014-11-20 07:22:07 -08:00
|
|
|
preStart =
|
|
|
|
''
|
|
|
|
mkdir -p ${cfg.dataDir};
|
|
|
|
mkdir -p ${cfg.logDir};
|
|
|
|
|
|
|
|
if [ "$(id -u)" = 0 ]; then
|
|
|
|
chown ${cfg.user}:${cfg.group} ${cfg.dataDir}
|
|
|
|
chown ${cfg.user}:${cfg.group} ${cfg.logDir}
|
|
|
|
fi
|
|
|
|
'';
|
|
|
|
|
2014-11-20 03:29:07 -08:00
|
|
|
serviceConfig = {
|
|
|
|
PermissionsStartOnly = true;
|
|
|
|
User = cfg.user;
|
|
|
|
Group = cfg.group;
|
2014-11-20 07:22:07 -08:00
|
|
|
ExecStart = "${cfg.package}/bin/hbase --config ${configDir} master start";
|
2014-11-20 03:29:07 -08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
users.extraUsers.hbase = {
|
|
|
|
description = "HBase Server user";
|
|
|
|
group = "hbase";
|
|
|
|
uid = config.ids.uids.hbase;
|
|
|
|
};
|
|
|
|
|
|
|
|
users.extraGroups.hbase.gid = config.ids.gids.hbase;
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|