如何在 Ubuntu 14.04 上配置 Nginx 使用自定义错误页面

简介: 如何在 Ubuntu 14.04 上配置 Nginx 使用自定义错误页面

介绍

Nginx 是一个高性能的 Web 服务器,能够以灵活和强大的方式提供内容。在设计网页时,通常有必要定制用户将看到的每一部分内容,包括当他们请求不可用内容时的错误页面。在本指南中,我们将演示如何在 Ubuntu 14.04 上配置 Nginx 使用自定义错误页面。

先决条件

要开始使用本指南,您需要一个具有 sudo 权限的非根用户。您可以通过按照我们的 Ubuntu 14.04 初始设置指南来设置此类型的用户。

您还需要在系统上安装 Nginx。学习如何设置可以按照本指南进行操作。

完成上述步骤后,继续进行本指南。

创建自定义错误页面

我们将为演示目的创建一些自定义错误页面,但您的自定义页面显然会有所不同。

我们将把我们的自定义错误页面放在 /usr/share/nginx/html 目录中,这是 Ubuntu 的 Nginx 设置其默认文档根目录的位置。我们将创建一个名为 custom_404.html 的 404 错误页面和一个名为 custom_50x.html 的通用 500 级错误页面。如果您只是在测试,可以使用以下行。否则,请在这些位置放入您自己的内容:

echo "<h1 style='color:red'>Error 404: Not found :-(</h1>" | sudo tee /usr/share/nginx/html/custom_404.html
echo "<p>I have no idea where that file is, sorry.  Are you sure you typed in the correct URL?</p>" | sudo tee -a /usr/share/nginx/html/custom_404.html
echo "<h1>Oops! Something went wrong...</h1>" | sudo tee /usr/share/nginx/html/custom_50x.html
echo "<p>We seem to be having some technical difficulties. Hang tight.</p>" | sudo tee -a /usr/share/nginx/html/custom_50x.html

现在我们有了两个自定义错误页面,可以在客户端请求导致不同错误时提供服务。

配置 Nginx 使用您的错误页面

现在,我们只需要告诉 Nginx,在发生正确的错误条件时应该使用这些页面。打开 /etc/nginx/sites-enabled 目录中的服务器块文件,您希望配置的文件。我们将使用名为 default 的默认服务器块文件,但如果您使用非默认文件,则应调整自己的服务器块:

sudo nano /etc/nginx/sites-enabled/default

现在,我们可以将 Nginx 指向我们的自定义错误页面。

将 404 错误直接定向到自定义 404 页面

使用 error_page 指令,以便当发生 404 错误(请求的文件未找到时)时,提供您创建的自定义页面。我们将为文件创建一个位置块,在该位置块中,我们可以确保根与我们的文件系统位置匹配,并且该文件只能通过内部 Nginx 重定向访问(不能直接由客户端请求):

server {
        listen 80 default_server;
        listen [::]:80 default_server ipv6only=on;
        . . .
        error_page 404 /custom_404.html;
        location = /custom_404.html {
                root /usr/share/nginx/html;
                internal;
        }
}

通常情况下,我们不必在新的位置块中设置 root,因为它与服务器块中的根匹配。但是,我们在这里明确说明,以便我们的错误页面即使在将常规网页内容和相关文档根移动到不同位置时也能提供服务。

将 500 级错误直接定向到自定义 50x 页面

接下来,我们可以添加指令,以确保当 Nginx 遇到 500 级错误(与服务器相关的问题)时,它将提供我们制作的另一个自定义页面。这将遵循上一节中使用的完全相同的公式。这次,我们设置多个 500 级错误都使用 custom_50x.html 页面:

server {
        listen 80 default_server;
        listen [::]:80 default_server ipv6only=on;
        . . .
        error_page 404 /custom_404.html;
        location = /custom_404.html {
                root /usr/share/nginx/html;
                internal;
        }
        error_page 500 502 503 504 /custom_50x.html;
        location = /custom_50x.html {
                root /usr/share/nginx/html;
                internal;
        }
        location /testing {
                fastcgi_pass unix:/does/not/exist;
        }
}

最后,我们还添加了一个虚拟的 FastCGI 传递,以便我们可以测试我们的 500 级错误页面。由于后端不存在,这将无法正常工作。在这里请求页面将允许我们测试 500 级错误是否提供我们的自定义页面。

完成后保存并关闭文件。

重新启动 Nginx 并测试你的页面

通过以下命令测试你的配置文件语法:

sudo nginx -t

如果报告了任何错误,请在继续之前进行修复。当没有语法错误返回时,通过以下命令重新启动 Nginx:

sudo service nginx restart

现在,当你访问服务器的域名或 IP 地址并请求一个不存在的文件时,你应该会看到我们设置的 404 页面:

http://server_domain_or_IP/thiswillerror

!nginx custom 404

当你访问我们设置的 FastCGI pass 位置时,你将收到一个带有我们自定义的 500 级页面的 502 Bad Gateway 错误:

http://server_domain_or_IP/testing

!nginx custom 50x

现在,你可以返回并从 Nginx 配置中删除虚假的 FastCGI pass 位置。

结论

你现在应该为你的站点提供了自定义错误页面。这是个个性化用户体验的简单方法,即使他们遇到问题。对于这些页面的一个建议是包含指向可以获取帮助或更多信息的位置的链接。如果这样做,请确保即使发生相关错误,链接目的地也是可访问的。


目录
相关文章
|
23天前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
30天前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
247 0
|
3天前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
15天前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
nginx配置反向代理404问题
|
8天前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
22 2
|
10天前
|
应用服务中间件 网络安全 PHP
八个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
Nginx 是一个高效的 HTTP 服务器和反向代理,擅长处理静态资源、负载均衡和网关代理等任务。其配置主要通过 `nginx.conf` 文件完成,但复杂设置可能导致错误。本文介绍了几个开源的 Nginx 可视化配置系统,如 Nginx UI、VeryNginx、OpenPanel、Ajenti、Schenkd nginx-ui、EasyEngine、CapRover 和 NGINX Agent,帮助简化和安全地管理 Nginx 实例。
|
20天前
|
缓存 负载均衡 应用服务中间件
Nginx配置
【10月更文挑战第22天】在实际配置 Nginx 时,需要根据具体的需求和环境进行调整和优化。同时,还需要注意配置文件的语法正确性和安全性。
35 7
|
29天前
|
前端开发 JavaScript 应用服务中间件
终极 Nginx 配置指南
本文介绍了Nginx的基本配置及其优化方法。首先,通过删除注释简化了Nginx的默认配置文件,使其更易于理解。接着,文章将Nginx配置文件分为全局块、events块和http块三部分进行详细解释。此外,还提供了如何快速上线网站、解决前端history模式404问题、配置反向代理、开启gzip压缩、设置维护页面、在同一IP上部署多个网站以及实现动静分离的具体配置示例。最后,附上了Nginx的基础命令,包括安装、启动、重启和关闭等操作。
|
1月前
|
缓存 前端开发 JavaScript
一、nginx配置
一、nginx配置
150 1
|
30天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
137 0