介绍
Nginx是世界上最受欢迎的Web服务器之一,负责托管Internet上一些最大和流量最高的网站。在大多数情况下,它比Apache更友好地使用资源,并且可以用作Web服务器或反向代理。
在本指南中,我们将讨论如何在Ubuntu 18.04服务器上安装Nginx。
先决条件
在开始本指南之前,您应该在服务器上配置具有sudo特权的常规非root用户。您可以参考另一个教程。
如果您有可用的帐户,请以非root用户身份登录以开始(root也随便,莽就对了)。
步骤1 –安装Nginx
由于Nginx在Ubuntu的默认存储库中可用,因此可以使用apt
打包系统从这些存储库中安装Nginx 。
由于这是我们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/\/.*$//'
或者输入如下命令找
ifconfig
您将返回几行。您可以尝试在网络浏览器中查看它们是否正常工作。
一种替代方法是键入此内容,它应该为您提供公共IP地址,如从Internet上的其他位置看到的那样:
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文件和目录
既然您知道如何管理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服务器,对于要提供的内容类型以及要用来创建更丰富体验的技术,有了许多选择。