How to Configure Nginx to Serve A PDF File?

16 minutes read

To configure Nginx to serve a PDF file, you need to make changes to the Nginx configuration file. Here are the steps:

  1. Open the Nginx configuration file using a text editor. The default location is usually /etc/nginx/nginx.conf or /etc/nginx/conf.d/default.conf.
  2. Inside the configuration file, locate the server block that corresponds to the domain or IP address serving the PDF file. This block is typically enclosed within curly braces {}.
  3. Add the following location block inside the server block:
1
2
3
4
5
6
location /path/to/file.pdf {
    root /path/to/directory;
    try_files $uri =404;
    expires 30d;
    }


Replace /path/to/file.pdf with the actual path and filename of your PDF file. Also, replace /path/to/directory with the directory path where the PDF file is located on your server.

  1. Save the changes to the configuration file and exit the text editor.
  2. Restart or reload the Nginx service to apply the configuration changes. The command to restart Nginx varies depending on your system. It can be one of the following:
  • sudo service nginx restart
  • sudo systemctl restart nginx
  • sudo /etc/init.d/nginx restart


After completing these steps, Nginx will be configured to serve the specified PDF file. You can access the file by navigating to http://your-domain.com/path/to/file.pdf in your web browser, replacing your-domain.com with your actual domain, and /path/to/file.pdf with the configured path for the PDF file.

Best Nginx Books to Read in January 2025

1
NGINX Cookbook: Over 70 recipes for real-world configuration, deployment, and performance

Rating is 5 out of 5

NGINX Cookbook: Over 70 recipes for real-world configuration, deployment, and performance

2
Nginx HTTP Server: Harness the power of Nginx to make the most of your infrastructure and serve pages faster than ever before, 4th Edition

Rating is 4.9 out of 5

Nginx HTTP Server: Harness the power of Nginx to make the most of your infrastructure and serve pages faster than ever before, 4th Edition

3
NGINX Unit Cookbook: Recipes for Using a Versatile Open Source Server

Rating is 4.8 out of 5

NGINX Unit Cookbook: Recipes for Using a Versatile Open Source Server

4
NGINX Cookbook: Advanced Recipes for High-Performance Load Balancing

Rating is 4.7 out of 5

NGINX Cookbook: Advanced Recipes for High-Performance Load Balancing

5
Nginx Troubleshooting

Rating is 4.6 out of 5

Nginx Troubleshooting

6
Nginx HTTP Server - Third Edition

Rating is 4.5 out of 5

Nginx HTTP Server - Third Edition

7
Nginx Simplified: Practical Guide to Web Server Configuration and Optimization

Rating is 4.4 out of 5

Nginx Simplified: Practical Guide to Web Server Configuration and Optimization

8
Mastering NGINX - Second Edition

Rating is 4.3 out of 5

Mastering NGINX - Second Edition


What are some common troubleshooting steps for serving PDF files with Nginx?

Here are some common troubleshooting steps for serving PDF files with Nginx:

  1. Verify the file path: Ensure that the PDF file exists in the specified location on your server. Check for any typos or incorrect file paths in your Nginx configuration.
  2. Check Nginx configuration: Examine the Nginx configuration file (usually located at /etc/nginx/nginx.conf or /etc/nginx/conf.d/default.conf) and make sure that the server block has the necessary directives to handle PDF files. These directives should include location and try_files directives specific to PDF file serving.
  3. MIME-Type: Confirm that the MIME type for PDF files is correctly set in the Nginx configuration. This can be done by checking the types block in the configuration file. It should include an entry for application/pdf as shown below:
1
2
3
4
5
types {
    ...
    application/pdf pdf;
    ...
}


  1. Test MIME-Type: Verify that Nginx is set to serve PDF files with the correct MIME type by sending a request to a PDF file and inspecting the response headers. You can use tools like cURL or browser developer tools to check the Content-Type header of the response.
  2. Permission issues: Ensure that Nginx has the necessary permissions to access and serve the PDF files. Verify that the user running the Nginx process has read permissions on the directory and file.
  3. File ownership and SELinux: If your server is running SELinux, check the file ownership and SELinux context of the PDF file. Use the ls command with the -Z option to view the SELinux context. If necessary, adjust the ownership or SELinux context using the chown and chcon commands.
  4. Restart Nginx: After making any changes to the Nginx configuration, it is important to restart the Nginx service to apply the changes. Use the appropriate command for your system, such as sudo systemctl restart nginx or sudo service nginx restart.
  5. Review error logs: Check the Nginx error logs (usually located in /var/log/nginx/error.log) for any specific error messages related to serving PDF files. This can provide valuable information to troubleshoot the issue further.


By following these troubleshooting steps, you can identify and resolve common issues encountered when serving PDF files with Nginx.


How do I restrict access to specific IP addresses?

To restrict access to specific IP addresses, you can follow these steps:

  1. Determine which web server or firewall you are using as the method to restrict access may vary depending on the system you have.
  2. Identify the IP addresses you want to allow or block. Ensure that you have the IP addresses you want to restrict access to or allow access from.
  3. Check if your web server or firewall provides a built-in access control feature. Many servers and firewalls have their own configuration settings for IP access control.
  4. If your server or firewall does not have built-in IP access control, you can make use of the .htaccess file if you are using Apache server. Open the .htaccess file in a text editor and add the following code:
1
2
3
4
order allow,deny
allow from <IP address 1>
allow from <IP address 2>
deny from all


Replace <IP address 1> and <IP address 2> with the IP addresses you want to allow. This code will allow access only to the specified IP addresses and block access from all other IP addresses.


Note: The above code will work only if your server is running Apache and has the mod_authz_host module enabled.

  1. Save the .htaccess file and upload it to the root directory of your website.
  2. Test the access restriction by trying to access your website from a different IP address. You should see a "403 Forbidden" error if the access is restricted.


Remember to regularly verify and update the list of allowed or blocked IP addresses to ensure effective access control.


How do I configure custom error pages in Nginx?

To configure custom error pages in Nginx, you need to modify the server configuration file. Here's a step-by-step process:

  1. Open the Nginx configuration file using a text editor. The default location is /etc/nginx/nginx.conf or /etc/nginx/conf.d/default.conf, depending on your Nginx setup.
  2. Locate the server block where you want to configure custom error pages. Typically, this block is inside the http block.
  3. Add the error_page directive within the server block for each error code you want to customize. The format is as follows: error_page ; Replace with the specific HTTP error code (e.g., 404, 500), and with the path to the custom error page file. For example, to configure a custom error page for a 404 error: error_page 404 /404.html;
  4. Save the configuration file and exit the text editor.
  5. Test the configuration file for syntax errors by running the following command: nginx -t
  6. If the configuration is valid, reload Nginx to apply the changes: systemctl reload nginx Alternatively, use the appropriate command for your system.


Make sure the specified error page files exist and are accessible by the Nginx process. You can place them in a specific directory or use an absolute path in the error_page directive.


Note: It's also possible to define a default error page for all errors by using the error_page directive without specifying an error code (e.g., error_page /error.html;).

Best Web Hosting Providers in 2025

1
AWS

Rating is 5 out of 5

AWS

2
DigitalOcean

Rating is 4.9 out of 5

DigitalOcean

3
Vultr

Rating is 4.8 out of 5

Vultr

4
Cloudways

Rating is 4.7 out of 5

Cloudways


What is a PDF file?

A PDF (Portable Document Format) file is a file format used to present and exchange documents reliably, independent of software, hardware, or operating system. It captures all the elements of a printed document in an electronic image that can be viewed, printed, or transmitted securely. PDF files maintain the original formatting of various document types, including text documents, images, forms, and multimedia. They are typically used for sharing documents that need to be preserved in their original layout, regardless of the devices or software used to access them.


What is Nginx?

Nginx is a popular open-source web server software that can also be used as a reverse proxy, load balancer, and HTTP cache. It is known for its high performance, scalability, and ability to handle a large number of concurrent connections. Nginx is often used to serve static content, handle SSL/TLS encryption, and efficiently distribute incoming traffic across multiple servers or applications. It is widely used by many popular websites and web applications as a reliable and efficient server software.


How do I configure Nginx to use SSL for serving the PDF file?

To configure Nginx to use SSL for serving a PDF file, follow these steps:

  1. Generate or obtain an SSL certificate and private key. You can either obtain a certificate from a trusted Certificate Authority (CA) or generate a self-signed certificate for testing purposes.
  2. Copy the SSL certificate file (e.g., certificate.crt) and the private key file (e.g., private.key) to a secure location on your server. For example, you can store them in the /etc/nginx/ssl directory.
  3. Open your Nginx configuration file for the site where you want to serve the PDF file. This file is typically located at /etc/nginx/sites-available/example.com.conf.
  4. Inside the server block, add the following lines to enable SSL: listen 443 ssl; ssl_certificate /etc/nginx/ssl/certificate.crt; ssl_certificate_key /etc/nginx/ssl/private.key; Replace /etc/nginx/ssl/certificate.crt and /etc/nginx/ssl/private.key with the paths to your SSL certificate and private key files respectively.
  5. Optionally, you can add some additional SSL configuration settings to enhance security and configure other SSL aspects, such as ciphers, protocols, and session caching. Here's an example: ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers HIGH:!aNULL:!MD5:!kRSA; ssl_prefer_server_ciphers on; ssl_session_cache shared:SSL:10m; Feel free to adjust these settings according to your requirements.
  6. Save the configuration file and exit the text editor.
  7. Test your Nginx configuration to make sure there are no syntax errors: sudo nginx -t
  8. If the test is successful, reload the Nginx configuration to apply the changes: sudo systemctl reload nginx
  9. Ensure that the PDF file is located in a directory accessible by Nginx. By default, Nginx serves files from the /var/www/html directory. You can place the PDF file there or customize the document root in your Nginx configuration file.
  10. Access the PDF file using a web browser with HTTPS (e.g., https://yourdomain.com/yourfile.pdf). Nginx will now serve the PDF file over SSL.


Remember to keep your SSL certificate and private key secure and up to date.


What is the root directive in Nginx configuration?

The root directive in Nginx configuration specifies the document root directory for a given server or location block. It defines the location where Nginx should look for files to serve in response to client requests.


What is the default configuration file for Nginx?

The default configuration file for Nginx is named nginx.conf. The location of this file can vary depending on the installation. Typically, it can be found in one of the following paths:

  • /etc/nginx/nginx.conf
  • /usr/local/nginx/conf/nginx.conf
  • /usr/local/etc/nginx/nginx.conf


How do I do a permanent redirect in Nginx?

To perform a permanent redirect in Nginx, you can use the return directive in your server block. Here's how you can do it:

  1. Open your Nginx configuration file. The default path for Nginx configuration is usually /etc/nginx/nginx.conf or /etc/nginx/conf.d/default.conf.
  2. Locate the server block where you want to set up the redirect. This block will typically be wrapped in curly braces {} and may already contain other server directives.
  3. Inside the server block, add the following line to perform a permanent redirect:
1
return 301 https://www.newdomain.com$request_uri;


Replace https://www.newdomain.com with the URL to which you want to redirect. $request_uri will append the original request URI to the new URL.

  1. Save and exit the file.
  2. Test the Nginx configuration to validate the syntax:
1
sudo nginx -t


If there are no errors, proceed to the next step. Otherwise, fix any syntax issues and retest.

  1. Restart or reload Nginx for the changes to take effect:
1
sudo service nginx restart


or

1
sudo systemctl reload nginx


After following these steps, any requests to the specified server block will be permanently redirected to the new URL.

Facebook Twitter LinkedIn Telegram Whatsapp Pocket

Related Posts:

To configure multiple React projects using Nginx, you can follow these steps:Install Nginx: Start by installing Nginx on your server or local machine. You can refer to the Nginx website for installation instructions specific to your operating system. Configure...
To build a proxy using Nginx, you need to follow these steps:Install Nginx: Start by installing Nginx on your server or local machine. You can download it from the official Nginx website or use package managers like apt or yum. Configure Nginx as a Reverse Pro...
To override the location directive in Nginx, you can modify the Nginx configuration file (usually located at /etc/nginx/nginx.conf, /etc/nginx/conf.d/*.conf, or /etc/nginx/sites-available/*) or create a new custom configuration file in conf.d or sites-availabl...