* Renamed services.nfsKernel to services.nfs. Unfortunately
rename.nix doesn't allow renaming sets of options... * Renamed nfs-kernel.nix to nfsd.nix * Move NFS client stuff from nfsd.nix to filesystems/nfs.nix. svn path=/nixos/trunk/; revision=33174
This commit is contained in:
parent
e963fe2b2c
commit
67a90c6d6f
@ -105,7 +105,7 @@
|
|||||||
./services/monitoring/zabbix-agent.nix
|
./services/monitoring/zabbix-agent.nix
|
||||||
./services/monitoring/zabbix-server.nix
|
./services/monitoring/zabbix-server.nix
|
||||||
./services/network-filesystems/drbd.nix
|
./services/network-filesystems/drbd.nix
|
||||||
./services/network-filesystems/nfs-kernel.nix
|
./services/network-filesystems/nfsd.nix
|
||||||
./services/network-filesystems/openafs-client/default.nix
|
./services/network-filesystems/openafs-client/default.nix
|
||||||
./services/network-filesystems/samba.nix
|
./services/network-filesystems/samba.nix
|
||||||
./services/networking/amuled.nix
|
./services/networking/amuled.nix
|
||||||
|
@ -1,182 +0,0 @@
|
|||||||
{ config, pkgs, ... }:
|
|
||||||
|
|
||||||
with pkgs.lib;
|
|
||||||
|
|
||||||
let
|
|
||||||
|
|
||||||
inherit (pkgs) writeText openssh;
|
|
||||||
|
|
||||||
cfg = config.services.nfsKernel;
|
|
||||||
|
|
||||||
exports = pkgs.writeText "exports" cfg.server.exports;
|
|
||||||
|
|
||||||
in
|
|
||||||
|
|
||||||
{
|
|
||||||
|
|
||||||
###### interface
|
|
||||||
|
|
||||||
options = {
|
|
||||||
|
|
||||||
services.nfsKernel = {
|
|
||||||
|
|
||||||
client.enable = mkOption {
|
|
||||||
default = any (fs: fs.fsType == "nfs" || fs.fsType == "nfs4") config.fileSystems;
|
|
||||||
description = ''
|
|
||||||
Whether to enable the kernel's NFS client daemons.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
server = {
|
|
||||||
enable = mkOption {
|
|
||||||
default = false;
|
|
||||||
description = ''
|
|
||||||
Whether to enable the kernel's NFS server.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
exports = mkOption {
|
|
||||||
default = "";
|
|
||||||
description = ''
|
|
||||||
Contents of the /etc/exports file. See
|
|
||||||
<citerefentry><refentrytitle>exports</refentrytitle>
|
|
||||||
<manvolnum>5</manvolnum></citerefentry> for the format.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
hostName = mkOption {
|
|
||||||
default = null;
|
|
||||||
description = ''
|
|
||||||
Hostname or address on which NFS requests will be accepted.
|
|
||||||
Default is all. See the <option>-H</option> option in
|
|
||||||
<citerefentry><refentrytitle>nfsd</refentrytitle>
|
|
||||||
<manvolnum>8</manvolnum></citerefentry>.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
nproc = mkOption {
|
|
||||||
default = 8;
|
|
||||||
description = ''
|
|
||||||
Number of NFS server threads. Defaults to the recommended value of 8.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
createMountPoints = mkOption {
|
|
||||||
default = false;
|
|
||||||
description = "Whether to create the mount points in the exports file at startup time.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
###### implementation
|
|
||||||
|
|
||||||
config = {
|
|
||||||
|
|
||||||
services.portmap.enable = cfg.client.enable || cfg.server.enable;
|
|
||||||
|
|
||||||
environment.systemPackages = mkIf cfg.server.enable [ pkgs.nfsUtils ];
|
|
||||||
|
|
||||||
environment.etc = mkIf cfg.server.enable (singleton
|
|
||||||
{ source = exports;
|
|
||||||
target = "exports";
|
|
||||||
});
|
|
||||||
|
|
||||||
boot.kernelModules = mkIf cfg.server.enable [ "nfsd" ];
|
|
||||||
|
|
||||||
jobs =
|
|
||||||
optionalAttrs cfg.server.enable
|
|
||||||
{ nfsd =
|
|
||||||
{ description = "Kernel NFS server";
|
|
||||||
|
|
||||||
startOn = "started networking";
|
|
||||||
|
|
||||||
path = [ pkgs.nfsUtils ];
|
|
||||||
|
|
||||||
preStart =
|
|
||||||
''
|
|
||||||
start portmap || true
|
|
||||||
start mountd || true
|
|
||||||
|
|
||||||
# Create a state directory required by NFSv4.
|
|
||||||
mkdir -p /var/lib/nfs/v4recovery
|
|
||||||
|
|
||||||
rpc.nfsd \
|
|
||||||
${if cfg.server.hostName != null then "-H ${cfg.server.hostName}" else ""} \
|
|
||||||
${builtins.toString cfg.server.nproc}
|
|
||||||
'';
|
|
||||||
|
|
||||||
postStop = "rpc.nfsd 0";
|
|
||||||
|
|
||||||
postStart =
|
|
||||||
''
|
|
||||||
start statd || true
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// optionalAttrs cfg.server.enable
|
|
||||||
{ mountd =
|
|
||||||
{ description = "Kernel NFS server - mount daemon";
|
|
||||||
|
|
||||||
path = [ pkgs.nfsUtils pkgs.sysvtools pkgs.utillinux ];
|
|
||||||
|
|
||||||
preStart =
|
|
||||||
''
|
|
||||||
start portmap || true
|
|
||||||
|
|
||||||
mkdir -p /var/lib/nfs
|
|
||||||
touch /var/lib/nfs/rmtab
|
|
||||||
|
|
||||||
mountpoint -q /proc/fs/nfsd || mount -t nfsd none /proc/fs/nfsd
|
|
||||||
|
|
||||||
${optionalString cfg.server.createMountPoints
|
|
||||||
''
|
|
||||||
# create export directories:
|
|
||||||
# skip comments, take first col which may either be a quoted
|
|
||||||
# "foo bar" or just foo (-> man export)
|
|
||||||
sed '/^#.*/d;s/^"\([^"]*\)".*/\1/;t;s/[ ].*//' ${exports} \
|
|
||||||
| xargs -d '\n' mkdir -p
|
|
||||||
''
|
|
||||||
}
|
|
||||||
|
|
||||||
# exports file is ${exports}
|
|
||||||
# keep this comment so that this job is restarted whenever exports changes!
|
|
||||||
exportfs -ra
|
|
||||||
'';
|
|
||||||
|
|
||||||
daemonType = "fork";
|
|
||||||
|
|
||||||
exec = "rpc.mountd -f /etc/exports";
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// optionalAttrs (cfg.client.enable || cfg.server.enable)
|
|
||||||
{ statd =
|
|
||||||
{ description = "Kernel NFS server - Network Status Monitor";
|
|
||||||
|
|
||||||
path = [ pkgs.nfsUtils pkgs.sysvtools pkgs.utillinux ];
|
|
||||||
|
|
||||||
stopOn = "never"; # needed during shutdown
|
|
||||||
|
|
||||||
preStart =
|
|
||||||
''
|
|
||||||
start portmap || true
|
|
||||||
mkdir -p /var/lib/nfs
|
|
||||||
mkdir -p /var/lib/nfs/sm
|
|
||||||
mkdir -p /var/lib/nfs/sm.bak
|
|
||||||
sm-notify -d
|
|
||||||
'';
|
|
||||||
|
|
||||||
daemonType = "fork";
|
|
||||||
|
|
||||||
exec = "rpc.statd --no-notify";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
147
modules/services/network-filesystems/nfsd.nix
Normal file
147
modules/services/network-filesystems/nfsd.nix
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
|
||||||
|
cfg = config.services.nfs.server;
|
||||||
|
|
||||||
|
exports = pkgs.writeText "exports" cfg.exports;
|
||||||
|
|
||||||
|
in
|
||||||
|
|
||||||
|
{
|
||||||
|
|
||||||
|
###### interface
|
||||||
|
|
||||||
|
options = {
|
||||||
|
|
||||||
|
services.nfs = {
|
||||||
|
|
||||||
|
server = {
|
||||||
|
enable = mkOption {
|
||||||
|
default = false;
|
||||||
|
description = ''
|
||||||
|
Whether to enable the kernel's NFS server.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
exports = mkOption {
|
||||||
|
default = "";
|
||||||
|
description = ''
|
||||||
|
Contents of the /etc/exports file. See
|
||||||
|
<citerefentry><refentrytitle>exports</refentrytitle>
|
||||||
|
<manvolnum>5</manvolnum></citerefentry> for the format.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
hostName = mkOption {
|
||||||
|
default = null;
|
||||||
|
description = ''
|
||||||
|
Hostname or address on which NFS requests will be accepted.
|
||||||
|
Default is all. See the <option>-H</option> option in
|
||||||
|
<citerefentry><refentrytitle>nfsd</refentrytitle>
|
||||||
|
<manvolnum>8</manvolnum></citerefentry>.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
nproc = mkOption {
|
||||||
|
default = 8;
|
||||||
|
description = ''
|
||||||
|
Number of NFS server threads. Defaults to the recommended value of 8.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
createMountPoints = mkOption {
|
||||||
|
default = false;
|
||||||
|
description = "Whether to create the mount points in the exports file at startup time.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
###### implementation
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
|
||||||
|
services.portmap.enable = true;
|
||||||
|
|
||||||
|
services.nfs.client.enable = true; # needed for statd
|
||||||
|
|
||||||
|
environment.systemPackages = [ pkgs.nfsUtils ];
|
||||||
|
|
||||||
|
environment.etc = singleton
|
||||||
|
{ source = exports;
|
||||||
|
target = "exports";
|
||||||
|
};
|
||||||
|
|
||||||
|
boot.kernelModules = [ "nfsd" ];
|
||||||
|
|
||||||
|
jobs.nfsd =
|
||||||
|
{ description = "Kernel NFS server";
|
||||||
|
|
||||||
|
startOn = "started networking";
|
||||||
|
|
||||||
|
path = [ pkgs.nfsUtils ];
|
||||||
|
|
||||||
|
preStart =
|
||||||
|
''
|
||||||
|
start portmap || true
|
||||||
|
start mountd || true
|
||||||
|
|
||||||
|
# Create a state directory required by NFSv4.
|
||||||
|
mkdir -p /var/lib/nfs/v4recovery
|
||||||
|
|
||||||
|
rpc.nfsd \
|
||||||
|
${if cfg.hostName != null then "-H ${cfg.hostName}" else ""} \
|
||||||
|
${builtins.toString cfg.nproc}
|
||||||
|
'';
|
||||||
|
|
||||||
|
postStop = "rpc.nfsd 0";
|
||||||
|
|
||||||
|
postStart =
|
||||||
|
''
|
||||||
|
start statd || true
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
jobs.mountd =
|
||||||
|
{ description = "Kernel NFS server - mount daemon";
|
||||||
|
|
||||||
|
path = [ pkgs.nfsUtils pkgs.sysvtools pkgs.utillinux ];
|
||||||
|
|
||||||
|
preStart =
|
||||||
|
''
|
||||||
|
start portmap || true
|
||||||
|
|
||||||
|
mkdir -p /var/lib/nfs
|
||||||
|
touch /var/lib/nfs/rmtab
|
||||||
|
|
||||||
|
mountpoint -q /proc/fs/nfsd || mount -t nfsd none /proc/fs/nfsd
|
||||||
|
|
||||||
|
${optionalString cfg.createMountPoints
|
||||||
|
''
|
||||||
|
# create export directories:
|
||||||
|
# skip comments, take first col which may either be a quoted
|
||||||
|
# "foo bar" or just foo (-> man export)
|
||||||
|
sed '/^#.*/d;s/^"\([^"]*\)".*/\1/;t;s/[ ].*//' ${exports} \
|
||||||
|
| xargs -d '\n' mkdir -p
|
||||||
|
''
|
||||||
|
}
|
||||||
|
|
||||||
|
# exports file is ${exports}
|
||||||
|
# keep this comment so that this job is restarted whenever exports changes!
|
||||||
|
exportfs -ra
|
||||||
|
'';
|
||||||
|
|
||||||
|
daemonType = "fork";
|
||||||
|
|
||||||
|
exec = "rpc.mountd -f /etc/exports";
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
@ -183,7 +183,7 @@ in
|
|||||||
# Ensure that this job is restarted when fstab changed:
|
# Ensure that this job is restarted when fstab changed:
|
||||||
# ${fstab}
|
# ${fstab}
|
||||||
|
|
||||||
${optionalString config.services.nfsKernel.client.enable ''
|
${optionalString config.services.nfs.client.enable ''
|
||||||
start statd || true
|
start statd || true
|
||||||
''}
|
''}
|
||||||
|
|
||||||
@ -196,9 +196,8 @@ in
|
|||||||
# The `mount-failed' event is emitted synchronously, but we don't
|
# The `mount-failed' event is emitted synchronously, but we don't
|
||||||
# want `mountall' to wait for the emergency shell. So use this
|
# want `mountall' to wait for the emergency shell. So use this
|
||||||
# intermediate job to make the event asynchronous.
|
# intermediate job to make the event asynchronous.
|
||||||
jobs.mount_failed =
|
jobs."mount-failed" =
|
||||||
{ name = "mount-failed";
|
{ task = true;
|
||||||
task = true;
|
|
||||||
startOn = "mount-failed";
|
startOn = "mount-failed";
|
||||||
script =
|
script =
|
||||||
''
|
''
|
||||||
@ -210,9 +209,8 @@ in
|
|||||||
|
|
||||||
# On an `ip-up' event, notify mountall so that it retries mounting
|
# On an `ip-up' event, notify mountall so that it retries mounting
|
||||||
# remote filesystems.
|
# remote filesystems.
|
||||||
jobs.mountall_ip_up =
|
jobs."mountall-ip-up" =
|
||||||
{
|
{
|
||||||
name = "mountall-ip-up";
|
|
||||||
task = true;
|
task = true;
|
||||||
startOn = "ip-up";
|
startOn = "ip-up";
|
||||||
script =
|
script =
|
||||||
@ -221,10 +219,8 @@ in
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
jobs.emergency_shell =
|
jobs."emergency-shell" =
|
||||||
{ name = "emergency-shell";
|
{ task = true;
|
||||||
|
|
||||||
task = true;
|
|
||||||
|
|
||||||
extraConfig = "console owner";
|
extraConfig = "console owner";
|
||||||
|
|
||||||
|
@ -9,7 +9,26 @@ let
|
|||||||
in
|
in
|
||||||
|
|
||||||
{
|
{
|
||||||
config = {
|
|
||||||
|
###### interface
|
||||||
|
|
||||||
|
options = {
|
||||||
|
|
||||||
|
services.nfs.client.enable = mkOption {
|
||||||
|
default = any (fs: fs.fsType == "nfs" || fs.fsType == "nfs4") config.fileSystems;
|
||||||
|
description = ''
|
||||||
|
Whether to enable support for mounting NFS filesystems.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
###### implementation
|
||||||
|
|
||||||
|
config = mkIf config.services.nfs.client.enable {
|
||||||
|
|
||||||
|
services.portmap.enable = true;
|
||||||
|
|
||||||
system.fsPackages = [ pkgs.nfsUtils ];
|
system.fsPackages = [ pkgs.nfsUtils ];
|
||||||
|
|
||||||
@ -21,5 +40,26 @@ in
|
|||||||
cp -v ${pkgs.klibc}/lib/klibc/bin.static/nfsmount $out/bin
|
cp -v ${pkgs.klibc}/lib/klibc/bin.static/nfsmount $out/bin
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
jobs.statd =
|
||||||
|
{ description = "Kernel NFS server - Network Status Monitor";
|
||||||
|
|
||||||
|
path = [ pkgs.nfsUtils pkgs.sysvtools pkgs.utillinux ];
|
||||||
|
|
||||||
|
stopOn = "never"; # needed during shutdown
|
||||||
|
|
||||||
|
preStart =
|
||||||
|
''
|
||||||
|
start portmap || true
|
||||||
|
mkdir -p /var/lib/nfs
|
||||||
|
mkdir -p /var/lib/nfs/sm
|
||||||
|
mkdir -p /var/lib/nfs/sm.bak
|
||||||
|
sm-notify -d
|
||||||
|
'';
|
||||||
|
|
||||||
|
daemonType = "fork";
|
||||||
|
|
||||||
|
exec = "rpc.statd --no-notify";
|
||||||
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -8,14 +8,12 @@ with import ../lib/build-vms.nix { inherit nixos nixpkgs system; };
|
|||||||
rec {
|
rec {
|
||||||
nodes = {
|
nodes = {
|
||||||
share = {pkgs, config, ...}: {
|
share = {pkgs, config, ...}: {
|
||||||
services.portmap.enable = true;
|
services.nfs.server.enable = true;
|
||||||
services.nfsKernel.client.enable = true;
|
services.nfs.server.exports = ''
|
||||||
services.nfsKernel.server.enable = true;
|
|
||||||
services.nfsKernel.server.exports = ''
|
|
||||||
/repos1 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
/repos1 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
||||||
/repos2 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
/repos2 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
||||||
'';
|
'';
|
||||||
services.nfsKernel.server.createMountPoints = true;
|
services.nfs.server.createMountPoints = true;
|
||||||
|
|
||||||
jobs.checkable = {
|
jobs.checkable = {
|
||||||
startOn = [
|
startOn = [
|
||||||
@ -27,22 +25,20 @@ rec {
|
|||||||
};
|
};
|
||||||
|
|
||||||
fsCheck = {pkgs, config, ...}: {
|
fsCheck = {pkgs, config, ...}: {
|
||||||
# enable nfs import
|
|
||||||
services.portmap.enable = true;
|
|
||||||
services.nfsKernel.client.enable = true;
|
|
||||||
|
|
||||||
fileSystems =
|
fileSystems =
|
||||||
let
|
let
|
||||||
repos1 = {
|
repos1 = {
|
||||||
mountPoint = "/repos1";
|
mountPoint = "/repos1";
|
||||||
autocreate = true;
|
autocreate = true;
|
||||||
device = "share:/repos1";
|
device = "share:/repos1";
|
||||||
|
fsType = "nfs";
|
||||||
};
|
};
|
||||||
|
|
||||||
repos2 = {
|
repos2 = {
|
||||||
mountPoint = "/repos2";
|
mountPoint = "/repos2";
|
||||||
autocreate = true;
|
autocreate = true;
|
||||||
device = "share:/repos2";
|
device = "share:/repos2";
|
||||||
|
fsType = "nfs";
|
||||||
};
|
};
|
||||||
in pkgs.lib.mkOverrideTemplate 50 {} [
|
in pkgs.lib.mkOverrideTemplate 50 {} [
|
||||||
repos1
|
repos1
|
||||||
|
@ -23,12 +23,12 @@ in
|
|||||||
|
|
||||||
server =
|
server =
|
||||||
{ config, pkgs, ... }:
|
{ config, pkgs, ... }:
|
||||||
{ services.nfsKernel.server.enable = true;
|
{ services.nfs.server.enable = true;
|
||||||
services.nfsKernel.server.exports =
|
services.nfs.server.exports =
|
||||||
''
|
''
|
||||||
/data 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
/data 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
||||||
'';
|
'';
|
||||||
services.nfsKernel.server.createMountPoints = true;
|
services.nfs.server.createMountPoints = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -5,12 +5,11 @@
|
|||||||
storage =
|
storage =
|
||||||
{pkgs, config, ...}:
|
{pkgs, config, ...}:
|
||||||
{
|
{
|
||||||
services.portmap.enable = true;
|
services.nfs.server.enable = true;
|
||||||
services.nfsKernel.server.enable = true;
|
services.nfs.server.exports = ''
|
||||||
services.nfsKernel.server.exports = ''
|
|
||||||
/repos 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
/repos 192.168.1.0/255.255.255.0(rw,no_root_squash)
|
||||||
'';
|
'';
|
||||||
services.nfsKernel.server.createMountPoints = true;
|
services.nfs.server.createMountPoints = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
postgresql =
|
postgresql =
|
||||||
@ -35,11 +34,10 @@
|
|||||||
[ { mountPoint = "/repos";
|
[ { mountPoint = "/repos";
|
||||||
device = "storage:/repos";
|
device = "storage:/repos";
|
||||||
fsType = "nfs";
|
fsType = "nfs";
|
||||||
options = "bootwait"; }
|
options = "bootwait";
|
||||||
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
services.portmap.enable = true;
|
|
||||||
services.nfsKernel.client.enable = true;
|
|
||||||
services.httpd.enable = true;
|
services.httpd.enable = true;
|
||||||
services.httpd.adminAddr = "root@localhost";
|
services.httpd.adminAddr = "root@localhost";
|
||||||
services.httpd.extraSubservices = [ { serviceType = "trac"; } ];
|
services.httpd.extraSubservices = [ { serviceType = "trac"; } ];
|
||||||
|
Loading…
x
Reference in New Issue
Block a user