rpcbind can save state in a file to allow restart without forgetting about running services. The default location is currently "/tmp" which is an over-used directory that isn't really suitable for system files. The modern preferences would be a subdirectory of "/run", which can be selected with a ./configure option. That subdirectory would still need to be created by something. It is trivial for rpcbind to create the directory itself, and harmless to try if it already exists, so: - add a "mkdir" when saving state data - change the default to /run/rpcbind (currently used by Debian) - remove the default settign in the code, just use the one in configure.ac Signed-off-by: NeilBrown <neilb@xxxxxxxx> --- configure.ac | 4 ++-- src/warmstart.c | 5 +---- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/configure.ac b/configure.ac index f84921eb27fb..fe7d0b068439 100644 --- a/configure.ac +++ b/configure.ac @@ -22,8 +22,8 @@ AC_ARG_ENABLE([warmstarts], AM_CONDITIONAL(WARMSTART, test x$enable_warmstarts = xyes) AC_ARG_WITH([statedir], - AS_HELP_STRING([--with-statedir=ARG], [use ARG as state dir @<:@default=/tmp@:>@]) - ,, [with_statedir=/tmp]) + AS_HELP_STRING([--with-statedir=ARG], [use ARG as state dir @<:@default=/run/rpcbind@:>@]) + ,, [with_statedir=/run/rpcbind]) AC_SUBST([statedir], [$with_statedir]) AC_ARG_WITH([rpcuser], diff --git a/src/warmstart.c b/src/warmstart.c index 122a058b7954..3896027e62ba 100644 --- a/src/warmstart.c +++ b/src/warmstart.c @@ -48,10 +48,6 @@ #include "rpcbind.h" -#ifndef RPCBIND_STATEDIR -#define RPCBIND_STATEDIR "/tmp" -#endif - /* These files keep the pmap_list and rpcb_list in XDR format */ #define RPCBFILE RPCBIND_STATEDIR "/rpcbind.xdr" #ifdef PORTMAP @@ -141,6 +137,7 @@ error: void write_warmstart() { + (void) mkdir(RPCBIND_STATEDIR, 0770); (void) write_struct(RPCBFILE, (xdrproc_t)xdr_rpcblist_ptr, &list_rbl); #ifdef PORTMAP (void) write_struct(PMAPFILE, (xdrproc_t)xdr_pmaplist_ptr, &list_pml); -- 2.10.2
Attachment:
signature.asc
Description: PGP signature