 
rpcdebug Command in Linux
The rpcdebug command in Linux is a powerful tool used to set and clear the NFS (Network File System) and RPC (Remote Procedure Call) kernel debug flags. This command is essential for system administrators and network engineers who need to debug NFS and RPC-related issues.
By enabling the debug flags, the kernel emits detailed messages to the system log, which can be invaluable for diagnosing and resolving problems.
Table of Contents
Here is a comprehensive guide to the options available with the rpcdebug command −
- Understanding rpcdebug Command
- Syntax of rpcdebug Command
- rpcdebug Command Options
- Examples of rpcdebug Command in Linux
- Advanced Usage of rpcdebug Command
Understanding rpcdebug Command
The command supports various modules, including nfs, nfsd, nlm, and rpc, each with its own set of debug flags. For example, using rpcdebug -m nfs -s all enables all debug flags for the NFS client module, providing comprehensive logging information.
Conversely, rpcdebug -m nfs -c all clears all debug flags, stopping the detailed logging. This flexibility makes rpcdebug an essential tool for maintaining and debugging NFS and RPC services in Linux environments.
Letâs install it −
sudo apt install nfs-common
 
The rpcdebug command allows administrators to control the verbosity of the kernel's logging for NFS and RPC operations.
Syntax of rpcdebug Command
The basic syntax of the rpcdebug command is as follows −
rpcdebug [options] [module] [flags]
Here,
- options − Various options to control the behavior of the command.
- module − The specific module for which to set or clear debug flags.
- flags − The debug flags to set or clear.
rpcdebug Command Options
Here are some commonly used options with the rpcdebug command −
| Options | Description | 
|---|---|
| -c | Clear the given debug flags. | 
| -h | Print a help message and exit. When combined with the -v option, it also prints the available debug flags. | 
| -m module | Specify which module's flags to set or clear. Available modules include nfsd, nfs, nlm, and rpc. | 
| -s | Set the given debug flags. | 
| -v | Increase the verbosity of rpcdebug's output. | 
Available Modules and Flags
The rpcdebug command supports several modules, each with its own set of debug flags −
- nfs − The NFS server module.
- nfsd − The NFS client module.
- nlm − The Network Lock Manager module, used in both NFS clients and servers.
- rpc − The Remote Procedure Call module, used in both NFS clients and servers.
Each module has a set of valid flags that can be set or cleared. Here are some examples −
- rpc − xprt, call, debug
- nfs − vfs, dircache, lookupcache, pagecache, proc, xdr, file, root, callback, client, mount, fscache, pnfs, pnfs_ld, state
- nfsd − sock, fh, export, svc, proc, fileop, auth, repcache, xdr, lockd
- nlm − svc, client, clntlock, svclock, monitor, clntsubs, svcsubs, hostcache, xdr
Examples of rpcdebug Command in Linux
The rpcdebug command in Linux is a valuable tool for setting and clearing debug flags for NFS (Network File System) and RPC (Remote Procedure Call) kernel modules. By enabling these debug flags, administrators can obtain detailed logging information about NFS and RPC operations, which is crucial for diagnosing and troubleshooting issues.
Let's explore some examples of using the rpcdebug command with detailed explanations.
- Display Help Message
- Display Available Debug Flags
- Set Debug Flags for NFS Client
- Set Specific Debug Flags for NFS Server
- Clear Debug Flags for NFS Client
- Clear Specific Debug Flags for RPC Module
Display Help Message
To display the help message and list available options, use the -h option −
rpcdebug -h
 
This command prints a help message and exits. When combined with the -v option, it also prints the available debug flags for each module.
Display Available Debug Flags
To display the available debug flags for a specific module, use the -m option with the -v option −
rpcdebug -m nfs -v
 
This command lists all available debug flags for the NFS client module.
Set Debug Flags for NFS Client
To enable all debug flags for the NFS client module, use the -m option with the -s option −
sudo rpcdebug -m nfs -s all
 
This command sets all debug flags for the NFS client module, causing the kernel to emit detailed messages to the system log for NFS client operations.
Set Specific Debug Flags for NFS Server
To enable specific debug flags for the NFS server module, use the -m option with the -s option and specify the flags −
sudo rpcdebug -m nfsd -s lockd
 
This command sets the lockd debug flag for the NFS server module, enabling detailed logging for the NFS server's lock manager operations.
Clear Debug Flags for NFS Client
To clear all debug flags for the NFS client module, use the -m option with the -c option −
sudo rpcdebug -m nfs -c all
 
This command clears all debug flags for the NFS client module, stopping the kernel from emitting detailed messages for NFS client operations.
Clear Specific Debug Flags for RPC Module
To clear specific debug flags for the RPC module, use the -m option with the -c option and specify the flags −
sudo rpcdebug -m rpc -c call
 
This command clears the call debug flag for the RPC module, stopping the kernel from emitting detailed messages for RPC call operations.
Advanced Usage of rpcdebug Command
Combining rpcdebug with grep
You can combine the rpcdebug command with grep to filter the output and find specific information. For example, to find all debug flags related to the NFS client module, you can use −
rpcdebug -m nfs -v | grep nfs
 
This command filters the output to show only debug flags related to the NFS client module.
Automating rpcdebug with Scripts
You can automate the use of rpcdebug in shell scripts to enable or disable debug flags based on specific conditions. For example, you can create a script to enable debug flags for the NFS client module during peak usage hours and disable them during off-peak hours.
#!/bin/
# Enable NFS client debug flags during peak hours
if [ "$(date +%H)" -ge 9 ] && [ "$(date +%H)" -le 17 ]; then
    rpcdebug -m nfs -s all
else
    rpcdebug -m nfs -c all
fi
This script enables all debug flags for the NFS client module between 9 AM and 5 PM and clears them outside of these hours.
Conclusion
The rpcdebug command is a versatile and powerful tool for setting and clearing NFS and RPC kernel debug flags in Linux. By understanding its various options and how to use them, you can effectively debug NFS and RPC-related issues and maintain a reliable and efficient network environment.
Whether you're a system administrator or a network engineer, mastering the rpcdebug command will enhance your ability to diagnose and resolve problems with NFS and RPC services.