Commands

Tail Command on Linux with Examples

Tail Command on Linux

The Linux ecosystem offers a rich set of command-line tools that empower users to interact efficiently with their systems. Among these tools, the tail command stands as an indispensable utility for system administrators and regular Linux users alike. This versatile command allows you to view the end portions of files, monitor real-time changes, and troubleshoot system issues with remarkable efficiency. Whether you’re tracking log files for errors, monitoring system performance, or simply examining the latest entries in a file, understanding the tail command is essential for effective Linux administration.

Table of Contents

What is the Linux Tail Command?

The tail command is a fundamental utility in the GNU Core Utilities (Coreutils) package that displays the last part of files. By default, it outputs the final 10 lines of a specified file or files to standard output. This functionality complements other text-viewing commands in Linux, such as head (which shows the beginning of files), cat (which displays entire files), and less (which offers interactive navigation).

System administrators regularly use the tail command when troubleshooting issues because new information is typically appended to the end of log files. The ability to quickly access these latest entries without scrolling through potentially massive log files saves considerable time during critical situations.

The command is particularly valuable because it:

  • Provides instant access to the most recent file data
  • Works seamlessly with pipes and other Linux commands
  • Supports real-time monitoring of file changes
  • Can process multiple files simultaneously
  • Offers flexible output customization options

When no file is specified, tail reads from standard input, making it versatile for use in command chains and scripts.

Tail Command Syntax

Understanding the basic syntax of the tail command is crucial for effective usage. The fundamental structure follows this pattern:

tail [options] [file]

Where:

  • [options] represents various flags that modify the command’s behavior
  • [file] specifies the target file(s) to process

When executed without any options, tail simply displays the last 10 lines of the specified file. However, its true power emerges when combined with various options that customize its behavior for specific needs.

The command adheres to Unix philosophy principles by focusing on a single task—showing file endings—and doing it exceptionally well. This simplicity enables tail to work effectively as part of more complex command pipelines.

It’s important to note that the tail command is case-sensitive, like most Linux commands. Additionally, when no file is specified, tail reads from standard input, allowing you to pipe output from other commands directly into tail for processing.

Essential Tail Command Options

The tail command supports numerous options that extend its functionality beyond the basic display of file endings. Here’s a comprehensive breakdown of the most important options:

-n or –lines
This option controls the number of lines displayed from the end of the file. For example:

tail -n 20 error.log

This displays the last 20 lines instead of the default 10.

You can also use a shorthand notation by directly specifying the number after the hyphen:

tail -20 error.log

Additionally, using a plus sign with a number displays all content starting from that line number to the end:

tail -n +10 syslog

This shows all lines from line 10 to the end of the file.

-c or –bytes
Similar to the -n option, this displays the last specified number of bytes rather than lines:

tail -c 100 /var/log/syslog

This command outputs the last 100 bytes of the syslog file.

-f or –follow=name
One of the most powerful options, -f monitors file changes in real-time, continuously updating the output as new data is appended. This is invaluable for tracking log files as they’re being written to:

tail -f /var/log/apache2/access.log

-F
This option combines follow mode (-f) with automatic retry, making it ideal for monitoring logs that may be rotated or recreated. It will keep trying to reopen the file if it becomes inaccessible.

-q or –quiet
When monitoring multiple files, this option suppresses headers that indicate which file each output section comes from.

-v or –verbose
The opposite of -q, this option always displays file headers, even when only one file is being monitored.

–pid=PID
When used with -f, this option causes tail to terminate after the specified process ID dies.

-s or –sleep-interval
Sets the time interval (in seconds) between checks when following files:

tail -f -s 2 /var/log/auth.log

–retry
Continues trying to open a file even if it’s inaccessible, which is useful for monitoring files that may not exist yet or could be temporarily unavailable.

–help
Displays a summary of available options and their usage.

–version
Shows the installed version of the tail command.

Basic Tail Command Examples

Let’s explore some fundamental applications of the tail command that demonstrate its everyday utility in Linux environments.

Displaying the Default Last 10 Lines

The most basic usage of tail requires only specifying a file name:

tail error.log

This command outputs the last 10 lines of the error.log file. The output appears in descending order, with the most recent entries at the bottom.

Showing a Specific Number of Lines

To view a different number of lines than the default 10, use the -n option followed by the desired number:

tail -n 15 mynote.txt

This displays the last 15 lines of the mynote.txt file. You can also use the shortened form:

tail -15 mynote.txt

Outputting Content from a Specific Line Forward

To display all content starting from a particular line number to the end of the file, use the -n option with a plus sign:

tail -n +19 syslog

This command outputs all lines from line 19 to the end of the file.

Processing Multiple Files Simultaneously

Tail can handle multiple files in a single command:

tail file1.txt file2.txt

When processing multiple files, tail automatically adds headers showing which file each section of output comes from. This feature helps maintain clarity when examining several files at once.

Displaying the Last n Bytes

Instead of working with lines, you can specify the number of bytes to display from the end of a file:

tail -c 100 /var/log/syslog

This command outputs the last 100 bytes of the syslog file, which is useful when working with files that might contain very long lines or binary data.

Controlling Header Display

When working with multiple files, you can control whether file headers appear in the output:

tail -q file1.txt file2.txt

The -q option suppresses headers, while the -v option enforces them:

tail -v file1.txt

Using -v ensures headers appear even with a single file, which can be helpful for scripts or when piping output to other commands.

Real-time File Monitoring

One of the most powerful features of the tail command is its ability to monitor files in real-time, making it an invaluable tool for system administrators who need to track log files as they’re being written.

Using the -f Option for Continuous Monitoring

The -f (or –follow) option enables tail to continuously update its output as new lines are added to a file:

tail -f /var/log/syslog

This command initially displays the last 10 lines of the syslog file and then continues to show new entries as they appear. The terminal remains active, with new lines appearing in real-time as they’re written to the file.

To stop the monitoring, press Ctrl+C to terminate the command.

Differences Between -f and -F Follow Modes

While both -f and -F enable continuous monitoring, they behave differently when files are renamed or rotated:

  • The -f option follows the descriptor, continuing to show content from the same file even if it’s renamed.
  • The -F option follows the name, automatically detecting when a file is rotated and switching to the new file with the same name.

For log files that undergo regular rotation, the -F option is often more appropriate:

tail -F /var/log/apache2/access.log

Setting Up Monitoring with Sleep Intervals

When monitoring busy log files, you can control how frequently tail checks for updates using the -s option:

tail -f -s 2 /var/log/auth.log

This command sets a 2-second interval between checks, which can help reduce system resource usage when monitoring high-traffic logs.

Monitoring Multiple Log Files in Real-time

Tail can simultaneously monitor multiple files, updating the output as any of them change:

tail -f /var/log/syslog /var/log/auth.log

This command displays updates from both files in real-time, with headers indicating the source of each new entry.

Limiting Unchanged Output

For files that may contain repeated content, you can use the –max-unchanged-stats option to limit redundant output:

tail -f --max-unchanged-stats=5 error.log

This command hides identical lines after they appear five times, helping to keep the output clean and focused on unique entries.

Terminating Monitoring Based on Process ID

When monitoring logs associated with a specific process, you can configure tail to stop automatically when that process ends:

tail -f --pid=1234 /var/log/syslog

This command monitors the syslog file but terminates when process ID 1234 exits, making it useful for tracking logs tied to specific applications or services.

Advanced Usage with Other Commands

The true power of the tail command emerges when combined with other Linux utilities. These command chains create sophisticated monitoring and analysis solutions tailored to specific needs.

Combining Tail with Grep for Filtering

One of the most common combinations is using grep to filter tail output for specific patterns:

tail -f /var/log/syslog | grep "ERROR"

This command displays only the lines containing “ERROR” as they’re added to the syslog file. This technique is invaluable when troubleshooting specific issues in busy log files.

You can refine the filter with more complex patterns:

tail -f /var/log/syslog | grep -E "ERROR|WARNING"

This shows lines containing either “ERROR” or “WARNING.”

Using Tail with Sort for Organized Output

To organize the last lines of a file in a specific order:

tail -n 15 /var/log/syslog | sort

This command takes the last 15 lines of the syslog file and alphabetically sorts them, which can be helpful when looking for patterns or grouping similar entries.

Extracting Specific Fields with Awk

For more advanced filtering that requires field extraction:

tail -n 10 /var/log/syslog | awk '{print $2}'

This command displays only the second field (typically the date or time) from the last 10 lines of the syslog file.

Creating Complex Command Chains

For sophisticated log analysis, you can create multi-stage command pipelines:

tail -f /var/log/apache2/access.log | grep "404" | awk '{print $1}' | sort | uniq -c

This complex command:

  1. Monitors the Apache access log in real-time
  2. Filters for 404 error responses
  3. Extracts the IP addresses (first field)
  4. Sorts them
  5. Counts unique occurrences

The result is a real-time count of IP addresses generating 404 errors.

Combining Tail and Head for Specific Sections

To extract a specific section from the end of a file:

tail -n 50 /var/log/syslog | head -n 10

This command displays lines 41-50 of the syslog file by taking the last 50 lines and then extracting just the first 10 of those.

Using Tail with Less for Interactive Viewing

For more flexibility in viewing real-time updates:

tail -f /var/log/syslog | less +F

This command provides real-time updates within the less pager, allowing you to pause the updates (by pressing Ctrl+C) and scroll through the content, then resume real-time monitoring (by pressing F).

Practical Applications for System Administration

System administrators rely heavily on the tail command for various monitoring and troubleshooting tasks. Here are some practical applications that demonstrate its utility in real-world scenarios.

Monitoring Web Server Logs

Web server logs provide crucial information about visitor activity, error conditions, and potential security issues:

sudo tail -f /var/log/apache2/access.log

This command displays real-time visitor activity on an Apache web server.

For Nginx servers, use:

sudo tail -f /var/log/nginx/access.log

To focus on error conditions:

sudo tail -f /var/log/apache2/error.log | grep "PHP Fatal error"

This filters the output to show only PHP fatal errors as they occur.

Tracking System Logs

System logs contain valuable information about hardware, kernel, and service operations:

sudo tail -f /var/log/syslog

For security-related events:

sudo tail -f /var/log/auth.log

This command shows authentication attempts and user privilege operations in real-time.

Debugging Application Issues

When troubleshooting application problems, monitoring application-specific logs can provide insights:

tail -f /var/log/myapp/error.log | grep -i "exception"

This command filters application logs for exception messages, helping identify the source of problems quickly.

Monitoring Database Logs

Database logs can reveal performance issues, query problems, and security concerns:

sudo tail -f /var/log/mysql/error.log

This displays MySQL error logs in real-time, helping identify database issues as they occur.

Security Monitoring

For security monitoring, tail can help detect intrusion attempts:

sudo tail -f /var/log/auth.log | grep "Failed password"

This command shows failed login attempts as they happen, potentially revealing brute force attacks.

Working with Multiple Files

Managing output from multiple files requires specific techniques to maintain clarity and focus on relevant information.

Monitoring Multiple Log Files Simultaneously

To track several logs at once:

tail -f /var/log/syslog /var/log/auth.log /var/log/apache2/error.log

This command outputs updates from all three files in real-time, with headers indicating the source file.

Using Wildcard Patterns for File Selection

Wildcards can help monitor groups of related files:

tail -f /var/log/apache2/*.log

This monitors all log files in the Apache2 directory simultaneously.

Differentiating Between Files in Output

When monitoring multiple files, ensuring clear distinction between sources is important:

tail -v -f /var/log/syslog /var/log/auth.log

The -v option enforces headers for each file, making it easy to identify the source of each entry.

To suppress headers for cleaner output:

tail -q -f /var/log/syslog /var/log/auth.log

Performance Considerations for Multiple Files

Monitoring numerous files simultaneously can impact system performance. To minimize resource usage:

tail -f -s 5 /var/log/*.log

This sets a 5-second interval between checks, reducing CPU usage for multiple file monitoring.

Tail Command for Resource Monitoring

Beyond log files, tail can be combined with system monitoring commands to track resource usage in real-time.

Monitoring CPU Usage

To track CPU usage:

vmstat 1 | tail -f

This command runs vmstat continuously with 1-second intervals and pipes the output to tail, effectively showing ongoing CPU statistics.

Tracking Memory Usage

For memory monitoring:

watch -n 1 "free -m | tail -n 5"

This shows memory usage statistics updated every second.

Monitoring Disk I/O Activity

To track disk activity:

iostat 2 | tail -f

This displays disk I/O statistics updated every 2 seconds.

Network Connection Monitoring

For active network connections:

watch -n 2 "netstat -ant | tail -n 20"

This displays the last 20 active network connections, updated every 2 seconds.

Troubleshooting and Best Practices

Even simple commands like tail can encounter issues. Understanding common problems and best practices ensures efficient usage.

Common Error Messages and Solutions

Permission Denied

tail: cannot open '/var/log/syslog' for reading: Permission denied

Solution: Use sudo for files requiring elevated privileges:

sudo tail /var/log/syslog

No Such File or Directory

tail: cannot open 'non-existent-file' for reading: No such file or directory

Solution: Verify the file path or use –retry if the file might appear later:

tail --retry -f /path/to/log

Performance Considerations

For large files, tail is more efficient than commands like cat or less because it only reads what it needs rather than the entire file.

When monitoring high-traffic logs, use sleep intervals to reduce system load:

tail -f -s 5 /var/log/high-traffic.log

When to Use Alternatives

While tail is powerful, sometimes other tools are more appropriate:

  • Use less when you need to search or navigate within large files
  • Use grep directly when searching for specific patterns in entire files
  • Use specialized log analyzers for complex log analysis

Dealing with File Encoding Challenges

For files with non-standard encodings:

iconv -f utf-16 -t utf-8 file.log | tail

This converts a UTF-16 encoded file to UTF-8 before processing with tail.

Comparing Tail Across Linux Distributions

While tail functions similarly across Linux distributions, there are some differences to be aware of.

Implementation Differences

Most Linux distributions include tail as part of the GNU Coreutils package, providing consistent functionality. However, some specialized distributions may include alternative implementations with slight variations.

Version Variations

Newer versions of tail may support additional options. To check your version:

tail --version

Features like --pid and --retry may not be available in older versions.

Installation Information

On most Linux distributions, tail is pre-installed. If needed:

  • Debian/Ubuntu: sudo apt install coreutils
  • Red Hat/Fedora: sudo dnf install coreutils
  • Arch Linux: sudo pacman -S coreutils

VPS Manage Service Offer
If you don’t have time to do all of this stuff, or if this is not your area of expertise, we offer a service to do “VPS Manage Service Offer”, starting from $10 (Paypal payment). Please contact us to get the best deal!

r00t

r00t is an experienced Linux enthusiast and technical writer with a passion for open-source software. With years of hands-on experience in various Linux distributions, r00t has developed a deep understanding of the Linux ecosystem and its powerful tools. He holds certifications in SCE and has contributed to several open-source projects. r00t is dedicated to sharing her knowledge and expertise through well-researched and informative articles, helping others navigate the world of Linux with confidence.
Back to top button