如何在Ubuntu 18.04上安装Nginx

如何在Ubuntu 18.04上安装Nginx
如何在Ubuntu 18.04上安装Nginx

简介

Nginx是世界上最受欢迎的Web服务器之一,很多有规模的高并发的网站使用Nginx部署网站。在大多数情况下,它比Apache占用资源更少,运行效率更高,并且可以用作反向代理。

在本指南中,我们将介绍如何在Ubuntu 18.04服务器上安装Nginx。

第一步 – 安装 Nginx

Nginx已经在Ubuntu的默认软件库列表中,因此可以直接使用apt工具安装Nginx 。

首先更新系统软件包列表,然后使用 apt 安装Nginx:

sudo apt update
sudo apt install nginx

执行完成后,apt就将Nginx和所依赖的软件成功安装到了服务器。

第二步 – 调整防火墙

安装Nginx之后,我们需要配置防火墙,以允许访问Nginx服务。在安装时,Nginx已经在ufw注册,所以我们可以直接允许访问Nginx。

执行下面的命令,ufw会从 /etc/ufw/applications.d. 中读取应用程序列表:

sudo ufw app list

会返回如下的应用程序列表:

Output
Available 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上的流量。

执行以下命令,在防火墙中开放“Nginx HTTP”端口:

sudo ufw allow 'Nginx HTTP'

可以通过执行以下命令,来验证更改是否生效:

sudo ufw status

从输出的内容可以看到,防火墙已经开放HTTP流量请求:

Output
Status: active

To                         Action      From
--                         ------      ----
OpenSSH                    ALLOW       Anywhere                  
Nginx HTTP                 ALLOW       Anywhere                  
OpenSSH (v6)               ALLOW       Anywhere (v6)             
Nginx HTTP (v6)            ALLOW       Anywhere (v6)

第三步 – 检查网络服务器

在Nginx安装结束后,系统将自动启动Nginx。执行下面的命令,查看Nginx的运行状态:

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的运行状态,我们看到Nginx正在运行。但是我们最好进一步验证是否能够正常访问网页。

在浏览器中访问服务器的IP地址,查看是否可以正常访问Nginx。如果不知道服务器的IP是多少,执行如下的命令来查询:

ip addr show eth0 | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'

执行上述命令后,可以在系统返回的内容中,来查找服务器的IP地址。然后通过浏览器访问服务器的IP地址。

另外,我们也可以通过执行如下命令,来查询服务器的IP地址,然后通过浏览器访问IP地址:

curl -4 icanhazip.com
http://your_server_ip

我们将看到Nginx的欢迎页面,这说明我们的Nginx在正常工作。

Nginx default page

第四步 – 管理Nginx进程

安装了Nginx后,我们经常需要对Nginx进行进行管理,以执行启动、关闭、重启等操作。

关闭Nginx,请执行:

sudo systemctl stop nginx

启动Nginx,请执行:

sudo systemctl start nginx

重启Nginx,请执行:

sudo systemctl restart nginx

有时在我们更改配置后,只需要重新加载Nginx,就可以使配置生效:

sudo systemctl reload nginx

默认情况下,Nginx被配置为在服务器启动时自动启动。如果不想这样,可以执行下面的命令:

sudo systemctl disable nginx

要重新设置Nginx随系统启动而启动,执行下面的命令:

sudo systemctl enable nginx

创建如下目录,作为“example.com”网站的根目录:

sudo mkdir -p /var/www/example.com/html

接下来,授予Nginx服务器相应的管理权限:

sudo chown -R $USER:$USER /var/www/example.com/html

将目录权限设置为 755:

sudo chmod -R 755 /var/www/example.com

接下来,在根目录下创建一个index.html 文件,用于测试配置正常工作:

nano /var/www/example.com/html/index.html

在文件中,添加以下HTML代码:

/var/www/example.com/html/index.html

<html>
    <head>
        <title>Welcome to Example.com!</title>
    </head>
    <body>
        <h1>Success!  The example.com server block is working!</h1>
    </body>
</html>

完成后保存并关闭文件。

然后,我们创建一个Nginx虚拟主机配置文件:

sudo nano /etc/nginx/sites-available/example.com

粘贴以下配置代码,对example.com网站进行配置:

/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;
        }
}

通过该配置文件,我们配置了example.com网站的根目录,并通过 server_name 指向我们的域名:

接下来,我们创建指向sites-enabled目录的符号链接,来启用配置文件:

sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/

现在,我们启用了default和example.com两个nginx配置文件:

  • example.com:将响应来自example.comwww.example.com的访问请求。
  • default:除了example.com之外,default响应其余对80端口的访问请求。

如果服务器上部署了多个域名的网站,或者网站的域名过长的时候,我们要调整/etc/nginx/nginx.conf文件中server_names_hash_bucket_size 值的大小。打开文件:

sudo nano /etc/nginx/nginx.conf

找到server_names_hash_bucket_size ,删除前面的#号取消注释该行:

/etc/nginx/nginx.conf

...
http {
    ...
    server_names_hash_bucket_size 64;
    ...
}
...

完成后保存并关闭文件。

接下来,测试Nginx文件中有没有语法错误:

sudo nginx -t

如果没有任何问题,重新启动Nginx使配置生效:

sudo systemctl restart nginx

现在已经完成了Nginx的配置,我们可以通过浏览器来访问域名。

Nginx first server block

第六步 – Nginx 的配置文件和目录

目录

/var/www/html:Nginx默认的网站根目录为/var/www/html,为了配置多个网站,我们可以通过Nginx的配置文件来更改网站的根目录。

服务器配置

  • /etc/nginx:Nginx的配置目录。所有Nginx配置文件都位于此处。
  • /etc/nginx/nginx.conf:主要的Nginx配置文件。可以对其进行修改以更改Nginx全局配置。
  • /etc/nginx/sites-available/:可以存储每个网站的配置文件。Nginx不会直接使用此目录中的配置文件,通过建立一个sites-enabled目录软链接使配置生效。通常,所有服务器块配置都在此目录中完成,然后通过软链接到sites-enabled目录来启用配置。
  • /etc/nginx/sites-enabled/:存储已启用的每个网站的服务器配置文件。通常,通过创建到该目录的软链接,来启用不同网站的配置文件。
  • /etc/nginx/snippets:此目录包含一些经常重复使用的配置文件,通过在Nginx配置文件中include到其他位置。

服务器日志

  • /var/log/nginx/access.log: Every request to your web server is recorded in this log file unless Nginx is configured to do otherwise.
  • /var/log/nginx/error.log: Any Nginx errors will be recorded in this log.
  • /var/log/nginx/access.log:对Web服务器的每个请求都记录在此日志文件中。
  • /var/log/nginx/error.log:任何Nginx错误都将记录在此日志中。

原创文章,作者:牛奇网,如若转载,请注明出处:https://www.niuqi360.com/lamp-config/install-nginx-in-ubuntu-18-04/

发表评论

登录后才能评论