# sm-notify(8) - man - phpMan

[SM-NOTIFY(8)](https://www.chedong.com/phpMan.php/man/SM-NOTIFY/8/markdown)                           System Manager's Manual                          [SM-NOTIFY(8)](https://www.chedong.com/phpMan.php/man/SM-NOTIFY/8/markdown)



## NAME
       sm-notify - send reboot notifications to NFS peers

## SYNOPSIS
       **/usr/sbin/sm-notify** **[-dfn]** **[-m** _minutes_**]** **[-v** _name_**]** **[-p** _notify-port_**]** **[-P** _path_**]**

## DESCRIPTION
       File locks are not part of persistent file system state.  Lock state is thus lost when a host
       reboots.

       Network file systems must also detect when lock state is lost because a remote host  has  re‐
       booted.   After  an NFS client reboots, an NFS server must release all file locks held by ap‐
       plications that were running on that client.  After a server reboots, a  client  must  remind
       the server of file locks held by applications running on that client.

       For  NFS  version  2 and version 3, the _Network_ _Status_ _Monitor_ protocol (or NSM for short) is
       used to notify NFS peers of reboots.  On Linux, two separate user-space components constitute
       the NSM service:

### sm-notify
              A helper program that notifies NFS peers after the local system reboots

### rpc.statd
              A  daemon that listens for reboot notifications from other hosts, and manages the list
              of hosts to be notified when the local system reboots

       The local NFS lock manager alerts its local **rpc.statd** of each remote peer that should be mon‐
       itored.   When  the  local  system reboots, the **sm-notify** command notifies the NSM service on
       monitored peers of the  reboot.   When  a  remote  reboots,  that  peer  notifies  the  local
       **rpc.statd**, which in turn passes the reboot notification back to the local NFS lock manager.

## NSM OPERATION IN DETAIL
       The  first file locking interaction between an NFS client and server causes the NFS lock man‐
       agers on both peers to contact their local NSM service to store information about  the  oppo‐
       site peer.  On Linux, the local lock manager contacts **rpc.statd**.

       **rpc.statd**  records information about each monitored NFS peer on persistent storage.  This in‐
       formation describes how to contact a remote peer in case the local  system  reboots,  how  to
       recognize  which  monitored peer is reporting a reboot, and how to notify the local lock man‐
       ager when a monitored peer indicates it has rebooted.

       An NFS client sends a hostname, known as the client's _caller_name_, in each file lock request.
       An  NFS  server can use this hostname to send asynchronous GRANT calls to a client, or to no‐
       tify the client it has rebooted.

       The Linux NFS server can provide the client's _caller_name_ or the client's network address  to
       **rpc.statd**.   For the purposes of the NSM protocol, this name or address is known as the moni‐
       tored peer's _mon_name_.  In addition, the local lock manager tells **rpc.statd**  what  it  thinks
       its  own  hostname  is.   For  the  purposes  of  the NSM protocol, this hostname is known as
       _my_name_.

       There is no equivalent interaction between an NFS server and a client to inform the client of
       the  server's  _caller_name_.   Therefore NFS clients do not actually know what _mon_name_ an NFS
       server might use in an SM_NOTIFY request.  The Linux NFS client records the server's hostname
       used on the mount command to identify rebooting NFS servers.

### Reboot notification
       When  the  local system reboots, the **sm-notify** command reads the list of monitored peers from
       persistent storage and sends an SM_NOTIFY request to the NSM service on  each  listed  remote
       peer.   It uses the _mon_name_ string as the destination.  To identify which host has rebooted,
       the **sm-notify** command normally sends _my_name_ string recorded when that remote was  monitored.
       The  remote  **rpc.statd** matches incoming SM_NOTIFY requests using this string, or the caller's
       network address, to one or more peers on its own monitor list.

       If **rpc.statd** does not find a peer on its monitor list that matches an incoming SM_NOTIFY  re‐
       quest,  the  notification is not forwarded to the local lock manager.  In addition, each peer
       has its own _NSM_ _state_ _number_, a 32-bit integer that is bumped after each reboot by the **sm-no**‐‐
       **tify**  command.  **rpc.statd** uses this number to distinguish between actual reboots and replayed
       notifications.

       Part of NFS lock recovery is rediscovering which peers need to be monitored again.   The  **sm-**
       **notify** command clears the monitor list on persistent storage after each reboot.

## OPTIONS
### -d
              that notification progress may be monitored directly.

### -f

### -m
              Specifies the length of time, in minutes, to continue retrying notifications to  unre‐
              sponsive hosts.  If this option is not specified, **sm-notify** attempts to send notifica‐
              tions for 15 minutes.  Specifying a value of 0 causes **sm-notify**  to  continue  sending
              notifications to unresponsive peers until it is manually killed.

              Notifications  are retried if sending fails, the remote does not respond, the remote's
              NSM service is not registered, or if there is a DNS failure  which  prevents  the  re‐
              mote's _mon_name_ from being resolved to an address.

              Hosts  are  not  removed  from  the notification list until a valid reply has been re‐
              ceived.  However, the SM_NOTIFY procedure has a void result.  There is no way for  **sm-**
              **notify**  to  tell  if the remote recognized the sender and has started appropriate lock
              recovery.

### -n

### -p
              Specifies the source port number **sm-notify** should use when  sending  reboot  notifica‐
              tions.  If this option is not specified, a randomly chosen ephemeral port is used.

              This option can be used to traverse a firewall between client and server.

### -P, --state-directory-path
              Specifies  the  pathname  of the parent directory where NSM state information resides.
              If this option is not specified, **sm-notify** uses _/var/lib/nfs_ by default.

              After starting, **sm-notify** attempts to set its effective UID and GID to the  owner  and
              group of the subdirectory **sm** of this directory.  After changing the effective ids, **sm-**
              **notify** only needs to access files in **sm** and **sm.bak** within the state-directory-path.

### -v
              Specifies the network address  from  which  to  send  reboot  notifications,  and  the
              _mon_name_ argument to use when sending SM_NOTIFY requests.  If this option is not spec‐
              ified, **sm-notify** uses a wildcard address as the transport bind address, and  uses  the
              _my_name_  recorded  when the remote was monitored as the _mon_name_ argument when sending
              SM_NOTIFY requests.

              The _ipaddr_ form can be expressed as either an IPv4 or an  IPv6  presentation  address.
              If  the _ipaddr_ form is used, the **sm-notify** command converts this address to a hostname
              for use as the _mon_name_ argument when sending SM_NOTIFY requests.

              This option can be useful in multi-homed configurations where the remote requires  no‐
              tification from a specific network address.

## CONFIGURATION FILE
       Many of the options that can be set on the command line can also be controlled through values
       set in the **[sm-notify]** or, in one case, the **[statd]** section of the  _/etc/nfs.conf_  configura‐
       tion file.

       Values  recognized  in the **[sm-notify]** section include: **retry-time**, **outgoing-port**, and **outgo**‐‐
       **ing-addr**.  These have the same effect as the command line options **m**, **p**, and **v** respectively.

       An additional value recognized in the **[sm-notify]** section is **lift-grace**.  By default,  **sm-no**‐‐
       **tify** will lift lockd's grace period early if it has no hosts to notify.  Some high availabil‐
       ity configurations will run one **sm-notify** per floating IP address.  In these  configurations,
       lifting the grace period early may prevent clients from reclaiming locks.  Setting **lift-grace**
       to **n** will prevent **sm-notify** from ending the grace period early.   **lift-grace**  has  no  corre‐
       sponding command line option.

       The value recognized in the **[statd]** section is **state-directory-path**.


## SECURITY
       The  **sm-notify**  command  must  be  started as root to acquire privileges needed to access the
       state information database.  It drops root privileges as soon as it starts up to  reduce  the
       risk of a privilege escalation attack.

       During  normal  operation,  the effective user ID it chooses is the owner of the state direc‐
       tory.  This allows it to continue to access files in that directory after it has dropped  its
       root  privileges.  To control which user ID **rpc.statd** chooses, simply use [**chown**(1)](https://www.chedong.com/phpMan.php/man/chown/1/markdown) to set the
       owner of the state directory.

## ADDITIONAL NOTES
       Lock recovery after a reboot is critical to maintaining data integrity and preventing  unnec‐
       essary application hangs.

       To help **rpc.statd** match SM_NOTIFY requests to NLM requests, a number of best practices should
       be observed, including:

              The UTS nodename of your systems should match the DNS names that NFS peers use to con‐
              tact them

              The UTS nodenames of your systems should always be fully qualified domain names

              The forward and reverse DNS mapping of the UTS nodenames should be consistent

              The hostname the client uses to mount the server should match the server's _mon_name_ in
              SM_NOTIFY requests it sends

       Unmounting an NFS file system does not necessarily stop either the NFS client or server  from
       monitoring each other.  Both may continue monitoring each other for a time in case subsequent
       NFS traffic between the two results in fresh mounts and additional file locking.

       On Linux, if the **lockd** kernel module is unloaded during  normal  operation,  all  remote  NFS
       peers  are unmonitored.  This can happen on an NFS client, for example, if an automounter re‐
       moves all NFS mount points due to inactivity.

### IPv6 and TI-RPC support
       TI-RPC is a pre-requisite for supporting NFS on IPv6.  If TI-RPC support is  built  into  the
       **sm-notify**  command ,it will choose an appropriate IPv4 or IPv6 transport based on the network
       address returned by DNS for each remote peer.  It should be fully compatible with remote sys‐
       tems that do not support TI-RPC or IPv6.

       Currently,  the  **sm-notify**  command supports sending notification only via datagram transport
       protocols.

## FILES
       _/var/lib/nfs/sm_          directory containing monitor list

       _/var/lib/nfs/sm.bak_      directory containing notify list

       _/var/lib/nfs/state_       NSM state number for this host

       _/proc/sys/fs/nfs/nsm_local_state_
                                kernel's copy of the NSM state number

## SEE ALSO
       [**rpc.statd**(8)](https://www.chedong.com/phpMan.php/man/rpc.statd/8/markdown), [**nfs**(5)](https://www.chedong.com/phpMan.php/man/nfs/5/markdown), [**uname**(2)](https://www.chedong.com/phpMan.php/man/uname/2/markdown), [**hostname**(7)](https://www.chedong.com/phpMan.php/man/hostname/7/markdown)

       RFC 1094 - "NFS: Network File System Protocol Specification"
       RFC 1813 - "NFS Version 3 Protocol Specification"
       OpenGroup Protocols for Interworking: XNFS, Version 3W - Chapter 11

## AUTHORS
       Olaf Kirch <<okir@suse.de>>
       Chuck Lever <<chuck.lever@oracle.com>>



                                           1 November 2009                              [SM-NOTIFY(8)](https://www.chedong.com/phpMan.php/man/SM-NOTIFY/8/markdown)
