forked from mirrors/nixpkgs
ac724e7bbc
Resource management system for submitting and controlling jobs on supercomputers, clusters, and grids http://www.adaptivecomputing.com/products/open-source/torque
64 lines
1.3 KiB
Nix
64 lines
1.3 KiB
Nix
{ config, pkgs, lib, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
|
|
cfg = config.services.torque.mom;
|
|
torque = pkgs.torque;
|
|
|
|
momConfig = pkgs.writeText "torque-mom-config" ''
|
|
$pbsserver ${cfg.serverNode}
|
|
$logevent 225
|
|
'';
|
|
|
|
in
|
|
{
|
|
options = {
|
|
|
|
services.torque.mom = {
|
|
enable = mkEnableOption "torque computing node";
|
|
|
|
serverNode = mkOption {
|
|
type = types.str;
|
|
description = "Hostname running pbs server.";
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
environment.systemPackages = [ pkgs.torque ];
|
|
|
|
systemd.services.torque-mom-init = {
|
|
path = with pkgs; [ torque utillinux procps inetutils ];
|
|
|
|
script = ''
|
|
pbs_mkdirs -v aux
|
|
pbs_mkdirs -v mom
|
|
hostname > /var/spool/torque/server_name
|
|
cp -v ${momConfig} /var/spool/torque/mom_priv/config
|
|
'';
|
|
|
|
serviceConfig.Type = "oneshot";
|
|
unitConfig.ConditionPathExists = "!/var/spool/torque";
|
|
};
|
|
|
|
systemd.services.torque-mom = {
|
|
path = [ torque ];
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
requires = [ "torque-mom-init.service" ];
|
|
after = [ "torque-mom-init.service" "network.target" ];
|
|
|
|
serviceConfig = {
|
|
Type = "forking";
|
|
ExecStart = "${torque}/bin/pbs_mom";
|
|
PIDFile = "/var/spool/torque/mom_priv/mom.lock";
|
|
};
|
|
};
|
|
|
|
};
|
|
}
|