The issue with its inclusion in the manual has been side-stepped by matching on the platforms in supports.
		
			
				
	
	
		
			157 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{ config, lib, pkgs, ... }:
 | 
						|
 | 
						|
with lib;
 | 
						|
 | 
						|
let
 | 
						|
 | 
						|
  cfg = config.services.aerospike;
 | 
						|
 | 
						|
  aerospikeConf = pkgs.writeText "aerospike.conf" ''
 | 
						|
    # This stanza must come first.
 | 
						|
    service {
 | 
						|
      user aerospike
 | 
						|
      group aerospike
 | 
						|
      paxos-single-replica-limit 1 # Number of nodes where the replica count is automatically reduced to 1.
 | 
						|
      proto-fd-max 15000
 | 
						|
      work-directory ${cfg.workDir}
 | 
						|
    }
 | 
						|
    logging {
 | 
						|
      console {
 | 
						|
        context any info
 | 
						|
      }
 | 
						|
    }
 | 
						|
    mod-lua {
 | 
						|
      system-path ${cfg.package}/share/udf/lua
 | 
						|
      user-path ${cfg.workDir}/udf/lua
 | 
						|
    }
 | 
						|
    network {
 | 
						|
      ${cfg.networkConfig}
 | 
						|
    }
 | 
						|
    ${cfg.extraConfig}
 | 
						|
  '';
 | 
						|
 | 
						|
in
 | 
						|
 | 
						|
{
 | 
						|
 | 
						|
  ###### interface
 | 
						|
 | 
						|
  options = {
 | 
						|
 | 
						|
    services.aerospike = {
 | 
						|
      enable = mkEnableOption "Aerospike server";
 | 
						|
 | 
						|
      package = mkOption {
 | 
						|
        default = pkgs.aerospike;
 | 
						|
        defaultText = "pkgs.aerospike";
 | 
						|
        type = types.package;
 | 
						|
        description = "Which Aerospike derivation to use";
 | 
						|
      };
 | 
						|
 | 
						|
      workDir = mkOption {
 | 
						|
        type = types.str;
 | 
						|
        default = "/var/lib/aerospike";
 | 
						|
        description = "Location where Aerospike stores its files";
 | 
						|
      };
 | 
						|
 | 
						|
      networkConfig = mkOption {
 | 
						|
        type = types.lines;
 | 
						|
        default = ''
 | 
						|
          service {
 | 
						|
            address any
 | 
						|
            port 3000
 | 
						|
          }
 | 
						|
 | 
						|
          heartbeat {
 | 
						|
            address any
 | 
						|
            mode mesh
 | 
						|
            port 3002
 | 
						|
            interval 150
 | 
						|
            timeout 10
 | 
						|
          }
 | 
						|
 | 
						|
          fabric {
 | 
						|
            address any
 | 
						|
            port 3001
 | 
						|
          }
 | 
						|
 | 
						|
          info {
 | 
						|
            address any
 | 
						|
            port 3003
 | 
						|
          }
 | 
						|
        '';
 | 
						|
        description = "network section of configuration file";
 | 
						|
      };
 | 
						|
 | 
						|
      extraConfig = mkOption {
 | 
						|
        type = types.lines;
 | 
						|
        default = "";
 | 
						|
        example = ''
 | 
						|
          namespace test {
 | 
						|
            replication-factor 2
 | 
						|
            memory-size 4G
 | 
						|
            default-ttl 30d
 | 
						|
            storage-engine memory
 | 
						|
          }
 | 
						|
        '';
 | 
						|
        description = "Extra configuration";
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
  };
 | 
						|
 | 
						|
 | 
						|
  ###### implementation
 | 
						|
 | 
						|
  config = mkIf config.services.aerospike.enable {
 | 
						|
 | 
						|
    users.users.aerospike = {
 | 
						|
      name = "aerospike";
 | 
						|
      group = "aerospike";
 | 
						|
      uid = config.ids.uids.aerospike;
 | 
						|
      description = "Aerospike server user";
 | 
						|
    };
 | 
						|
    users.groups.aerospike.gid = config.ids.gids.aerospike;
 | 
						|
 | 
						|
    systemd.services.aerospike = rec {
 | 
						|
      description = "Aerospike server";
 | 
						|
 | 
						|
      wantedBy = [ "multi-user.target" ];
 | 
						|
      after = [ "network.target" ];
 | 
						|
 | 
						|
      serviceConfig = {
 | 
						|
        ExecStart = "${cfg.package}/bin/asd --fgdaemon --config-file ${aerospikeConf}";
 | 
						|
        User = "aerospike";
 | 
						|
        Group = "aerospike";
 | 
						|
        LimitNOFILE = 100000;
 | 
						|
        PermissionsStartOnly = true;
 | 
						|
      };
 | 
						|
 | 
						|
      preStart = ''
 | 
						|
        if [ $(echo "$(${pkgs.procps}/bin/sysctl -n kernel.shmall) < 4294967296" | ${pkgs.bc}/bin/bc) == "1"  ]; then
 | 
						|
          echo "kernel.shmall too low, setting to 4G pages"
 | 
						|
          ${pkgs.procps}/bin/sysctl -w kernel.shmall=4294967296
 | 
						|
        fi
 | 
						|
        if [ $(echo "$(${pkgs.procps}/bin/sysctl -n kernel.shmmax) < 1073741824" | ${pkgs.bc}/bin/bc) == "1"  ]; then
 | 
						|
          echo "kernel.shmmax too low, setting to 1GB"
 | 
						|
          ${pkgs.procps}/bin/sysctl -w kernel.shmmax=1073741824
 | 
						|
        fi
 | 
						|
        if [ $(echo "$(cat /proc/sys/net/core/rmem_max) < 15728640" | ${pkgs.bc}/bin/bc) == "1" ]; then
 | 
						|
          echo "increasing socket buffer limit (/proc/sys/net/core/rmem_max): $(cat /proc/sys/net/core/rmem_max) -> 15728640"
 | 
						|
          echo 15728640 > /proc/sys/net/core/rmem_max
 | 
						|
        fi
 | 
						|
        if [ $(echo "$(cat /proc/sys/net/core/wmem_max) <  5242880" | ${pkgs.bc}/bin/bc) == "1"  ]; then
 | 
						|
          echo "increasing socket buffer limit (/proc/sys/net/core/wmem_max): $(cat /proc/sys/net/core/wmem_max) -> 5242880"
 | 
						|
          echo  5242880 > /proc/sys/net/core/wmem_max
 | 
						|
        fi
 | 
						|
        install -d -m0700 -o ${serviceConfig.User} -g ${serviceConfig.Group} "${cfg.workDir}"
 | 
						|
        install -d -m0700 -o ${serviceConfig.User} -g ${serviceConfig.Group} "${cfg.workDir}/smd"
 | 
						|
        install -d -m0700 -o ${serviceConfig.User} -g ${serviceConfig.Group} "${cfg.workDir}/udf"
 | 
						|
        install -d -m0700 -o ${serviceConfig.User} -g ${serviceConfig.Group} "${cfg.workDir}/udf/lua"
 | 
						|
      '';
 | 
						|
    };
 | 
						|
 | 
						|
  };
 | 
						|
 | 
						|
}
 |