介绍
Nginx 是世界上最受欢迎的 Web 服务器之一,负责托管互联网上一些最大和流量最高的站点。在大多数情况下,它比 Apache 更资源友好,并且可以用作 Web 服务器或反向代理。
在本指南中,我们将讨论如何在 Ubuntu 18.04 服务器上安装 Nginx。
先决条件
在您开始本指南之前,您应该拥有一个在您的服务器上配置了 sudo 权限的普通非 root 用户。您可以按照我们的 Ubuntu 18.04 初始服务器设置指南了解如何配置常规用户帐户。
当您有可用的帐户时,请以非 root 用户身份登录以开始。
第 1 步 – 安装 Nginx
因为 Nginx 在 Ubuntu 的默认存储库中可用,所以可以使用apt
打包系统从这些存储库安装它。
由于这是我们apt
在本次会议中与包装系统的第一次交互,我们将更新我们的本地包裹索引,以便我们可以访问最新的包裹列表。之后,我们可以安装nginx
:
- sudo apt update
- sudo apt install nginx
接受程序后,apt
将安装 Nginx 和任何所需的依赖项到您的服务器。
步骤 2 – 调整防火墙
在测试 Nginx 之前,需要调整防火墙软件以允许访问该服务。Nginxufw
在安装时将自己注册为一个服务,这使得允许 Nginx 访问变得简单。
ufw
通过键入以下内容列出知道如何使用的应用程序配置:
- sudo ufw app list
您应该获得应用程序配置文件的列表:
OutputAvailable applications:
Nginx Full
Nginx HTTP
Nginx HTTPS
OpenSSH
如您所见,Nginx 有三个可用的配置文件:
- Nginx Full:此配置文件同时打开端口 80(正常、未加密的网络流量)和端口 443(TLS/SSL 加密流量)
- Nginx HTTP:此配置文件仅打开端口 80(正常、未加密的网络流量)
- Nginx HTTPS:此配置文件仅打开端口 443(TLS/SSL 加密流量)
建议您启用仍然允许您配置的流量的最严格的配置文件。由于我们尚未在本指南中为我们的服务器配置 SSL,因此我们只需要允许端口 80 上的流量。
您可以通过键入以下内容启用此功能:
- sudo ufw allow 'Nginx HTTP'
您可以通过键入以下内容来验证更改:
- sudo ufw status
您应该会在显示的输出中看到允许的 HTTP 流量:
OutputStatus: active
To Action From
-- ------ ----
OpenSSH ALLOW Anywhere
Nginx HTTP ALLOW Anywhere
OpenSSH (v6) ALLOW Anywhere (v6)
Nginx HTTP (v6) ALLOW Anywhere (v6)
第 3 步 – 检查您的 Web 服务器
在安装过程结束时,Ubuntu 18.04 启动 Nginx。Web 服务器应该已经启动并正在运行。
我们可以systemd
通过输入以下命令检查init 系统以确保服务正在运行:
- systemctl status nginx
Output● nginx.service - A high performance web server and a reverse proxy server
Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2018-04-20 16:08:19 UTC; 3 days ago
Docs: man:nginx(8)
Main PID: 2369 (nginx)
Tasks: 2 (limit: 1153)
CGroup: /system.slice/nginx.service
├─2369 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
└─2380 nginx: worker process
如您所见,该服务似乎已成功启动。然而,最好的测试方法是从 Nginx 实际请求一个页面。
您可以通过导航到您服务器的 IP 地址来访问默认的 Nginx 登录页面,以确认该软件是否正常运行。如果您不知道服务器的 IP 地址,可以通过几种不同的方式获取。
尝试在服务器的命令提示符下输入:
- ip addr show eth0 | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'
你会得到几行。您可以在 Web 浏览器中尝试每种方法,看看它们是否有效。
另一种方法是输入此内容,它应该会为您提供从 Internet 上的另一个位置看到的公共 IP 地址:
- curl -4 icanhazip.com
获得服务器的 IP 地址后,将其输入到浏览器的地址栏中:
http://your_server_ip
您应该会看到默认的 Nginx 登录页面:
此页面包含在 Nginx 中,用于向您显示服务器正在正确运行。
第 4 步 – 管理 Nginx 进程
现在您已经启动并运行了 Web 服务器,让我们回顾一些基本的管理命令。
要停止您的 Web 服务器,请键入:
- sudo systemctl stop nginx
要在停止时启动 Web 服务器,请键入:
- sudo systemctl start nginx
要停止然后再次启动该服务,请键入:
- sudo systemctl restart nginx
如果您只是进行配置更改,Nginx 通常可以重新加载而不会断开连接。为此,请键入:
- sudo systemctl reload nginx
默认情况下,Nginx 配置为在服务器启动时自动启动。如果这不是您想要的,您可以通过键入以下内容禁用此行为:
- sudo systemctl disable nginx
要重新启用服务以在启动时启动,您可以键入:
- sudo systemctl enable nginx
步骤 5 – 设置服务器块(推荐)
使用 Nginx Web 服务器时,服务器块(类似于 Apache 中的虚拟主机)可用于封装配置详细信息并从单个服务器托管多个域。我们将设置一个名为example.com的域,但您应该将其替换为您自己的域名。要了解有关使用 DigitalOcean 设置域名的更多信息,请参阅我们的DigitalOcean DNS 简介。
Ubuntu 18.04 上的 Nginx 默认启用了一个服务器块,该块被配置为从/var/www/html
. 虽然这适用于单个站点,但如果您托管多个站点,它可能会变得笨拙。/var/www/html
让/var/www
我们为example.com站点创建一个目录结构,而不是修改,/var/www/html
如果客户端请求与任何其他站点不匹配,则将其保留为要提供服务的默认目录。
如下为example.com创建目录,使用该-p
标志创建任何必要的父目录:
- sudo mkdir -p /var/www/example.com/html
接下来,使用$USER
环境变量分配目录的所有权:
- sudo chown -R $USER:$USER /var/www/example.com/html
如果您没有修改您的umask
值,您的网络根目录的权限应该是正确的,但您可以通过键入以下内容来确保:
- sudo chmod -R 755 /var/www/example.com
接下来,index.html
使用nano
您最喜欢的编辑器创建一个示例页面:
- nano /var/www/example.com/html/index.html
在里面,添加以下示例 HTML:
<html>
<head>
<title>Welcome to Example.com!</title>
</head>
<body>
<h1>Success! The example.com server block is working!</h1>
</body>
</html>
完成后保存并关闭文件。
为了让 Nginx 提供这些内容,有必要使用正确的指令创建一个服务器块。与其直接修改默认配置文件,不如在 处新建一个:/etc/nginx/sites-available/example.com
- sudo nano /etc/nginx/sites-available/example.com
粘贴以下配置块,它与默认配置块类似,但针对我们的新目录和域名进行了更新:
server {
listen 80;
listen [::]:80;
root /var/www/example.com/html;
index index.html index.htm index.nginx-debian.html;
server_name example.com www.example.com;
location / {
try_files $uri $uri/ =404;
}
}
请注意,我们已将root
配置更新到新目录和server_name
域名。
接下来,让我们通过创建从它到sites-enabled
目录的链接来启用该文件,Nginx 在启动期间读取该目录:
- sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/
现在启用并配置了两个服务器块,以根据它们的listen
和server_name
指令响应请求(您可以在此处阅读有关 Nginx 如何处理这些指令的更多信息):
example.com
:将满足要求作出回应example.com
和www.example.com
。default
: 将响应端口 80 上与其他两个块不匹配的任何请求。
为避免因添加其他服务器名称而可能出现的散列存储区内存问题,有必要调整/etc/nginx/nginx.conf
文件中的单个值。打开文件:
- sudo nano /etc/nginx/nginx.conf
找到server_names_hash_bucket_size
指令并删除#
符号以取消注释该行:
...
http {
...
server_names_hash_bucket_size 64;
...
}
...
完成后保存并关闭文件。
接下来,测试以确保您的任何 Nginx 文件中没有语法错误:
- sudo nginx -t
如果没有任何问题,请重新启动 Nginx 以启用您的更改:
- sudo systemctl restart nginx
Nginx 现在应该为您的域名提供服务。您可以通过导航到 进行测试,您应该在其中看到如下内容:http://example.com
第 6 步 – 熟悉重要的 Nginx 文件和目录
现在您已经知道如何管理 Nginx 服务本身,您应该花几分钟时间熟悉一些重要的目录和文件。
内容
/var/www/html
:实际的 Web 内容,默认情况下仅包含您之前看到的默认 Nginx 页面,在/var/www/html
目录之外提供。这可以通过更改 Nginx 配置文件来更改。
服务器配置
/etc/nginx
: Nginx 配置目录。所有 Nginx 配置文件都驻留在此处。/etc/nginx/nginx.conf
: 主要的 Nginx 配置文件。可以修改它以更改 Nginx 全局配置。/etc/nginx/sites-available/
:可以存储每个站点服务器块的目录。Nginx 不会使用在此目录中找到的配置文件,除非它们链接到该sites-enabled
目录。通常,所有服务器块配置都在此目录中完成,然后通过链接到另一个目录启用。/etc/nginx/sites-enabled/
:存储启用的每个站点服务器块的目录。通常,这些是通过链接到sites-available
目录中的配置文件来创建的。/etc/nginx/snippets
: 该目录包含可以包含在 Nginx 配置中的其他地方的配置片段。潜在可重复的配置段是重构为片段的良好候选者。
服务器日志
/var/log/nginx/access.log
:除非将 Nginx 配置为其他方式,否则对您的 Web 服务器的每个请求都会记录在此日志文件中。/var/log/nginx/error.log
: 任何 Nginx 错误都会记录在此日志中。
结论
现在您已经安装了 Web 服务器,您可以选择要提供的内容类型以及要使用的技术来创建更丰富的体验。
如果您想构建更完整的应用程序堆栈,请查看有关如何在 Ubuntu 18.04 上配置 LEMP 堆栈的文章。