Ubuntu 18.04
搭建Nginx服务
安装
Ubuntu可以从源直接安装nginx
1sudo apt-get update
2sudo apt-get install nginx
调整防火墙,以免出现各种问题
1sudo ufw app list
获得应用程序配置文件的列表:
1可用应用程序:
2CUPS
3Nginx Full
4Nginx HTTP
5Nginx HTTPS
6OpenSSH
正如你所看到的,Nginx有三个配置文件可用:Nginx Full
、Nginx HTTP
、Nginx HTTPS
Nginx Full
:此配置文件打开端口80(正常,未加密的网络流量)和端口443(TLS / SSL加密流量)Nginx HTTP
:此配置文件仅打开端口80(正常,未加密的网络流量)Nginx HTTPS
:此配置文件仅打开端口443(TLS / SSL加密流量)
1sudo ufw allow 'Nginx HTTP'
2sudo ufw allow 'Nginx HTTPS'
输入以下命令以启动防火墙,据知有部分用户是没有启动防火墙的,还是建议开启
1sudo ufw enable
输入以下命令以查看防火墙状态:
1sudo ufw status
检查您的Web服务器是否在运行
1sudo systemctl status nginx
检查是否可以访问默认网页,在浏览器输入:
1http://本地IP地址
管理nginx进程
1sudo systemctl stop nginx
2sudo systemctl start nginx
3sudo systemctl restart nginx
4# 如果您只是简单地进行配置更改,Nginx通常可以重新加载而不会丢失连接。
5sudo systemctl reload nginx
6# 默认情况下,Nginx配置为在服务器引导时自动启动。 如果这不是您想要的,可以通过输入以下命令来禁用此行为:
7sudo systemctl disable nginx
8# 要重新启用服务以在启动时启动,您可以键入:sudo systemctl enable nginx
设置服务器块
Ubuntu 18.04上的Nginx
默认启用了一个服务器模块,该模块被配置为在 /var/www/html
目录下提供文档。 虽然这适用于单个站点,但如果您托管多个站点,它可能会变得很笨重。 我们不必修改/var/www/html
,而是在/var/www
为我们的example.com
网站创建一个目录结构,并将/var/www/html
保留为默认目录,如果客户端请求没有匹配任何其他网站。
按如下所示为example.com
创建目录,使用-p标志创建任何必需的父目录:
1sudo mkdir -p /var/www/example.com/html
接下来,使用$USER环境变量分配目录的所有权:
1sudo chown -R $USER:$USER /var/www/example.com/html/
如果你没有修改你的umask值,你的web根目录的权限应该是正确的,但是你可以通过输入:
1sudo chmod -R 755 /var/www/example.com/
接下来,使用Vim或您最喜欢的编辑器创建一个index.html页面示例:
1vim /var/www/example.com/html/index.html
在里面,添加下面的示例HTML:
1<html>
2 <head>
3 <title>Welcome to Example.com!</title>
4 </head>
5 <body>
6 <h1>Success! The example.com server block is working!</h1>
7 </body>
8</html>
为了让Nginx
提供这些内容,有必要创建一个具有正确指令的服务器块。 我们不要直接修改默认配置文件,而是在/etc/nginx/sites-available/example.com
上创建一个新文件:
1sudo vim /etc/nginx/sites-available/example.com
粘贴到以下配置块中,该块类似于默认值,但已更新为我们的新目录和域名:
1server {
2 listen 80;
3 listen [::]:80;
4
5 root /var/www/example.com/html;
6 index index.html index.htm index.nginx-debian.html;
7
8 server_name example.com www.example.com;
9
10 location / {
11 try_files $uri $uri/ =404;
12 }
13}
请注意,我们已将root配置更新到我们的新目录,并将server_name
为我们的域名。
接下来,让我们通过创建一个链接到启动sites-enabled目录来启用该文件,该目录是Nginx在启动过程中读取的:
1sudo 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
文件中的单个值。
1sudo vim /etc/nginx/nginx.conf
找到server_names_hash_bucket_size
指令并删除#符号以取消注释该行:
1...
2http {
3 ...
4 server_names_hash_bucket_size 64;
5 ...
6}
7...
接下来,测试以确保您的Nginx文件中没有语法错误:
1sudo nginx -t
2
3nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
4nginx: configuration file /etc/nginx/nginx.conf test is successful
如果没有任何问题,请重新启动Nginx以启用您的更改:
1sudo systemctl restart nginx
Nginx现在应该为您的域名提供服务。 你可以通过导航到http://example.com
来测试它
重要的Nginx文件和目录
nginx服务器配置文件:
1/etc/nginx # Nginx配置目录。 所有的Nginx配置文件都驻留在这里。
2/etc/nginx/nginx.conf # 主要的Nginx配置文件。 这可以修改,以更改Nginx全局配置。
3/etc/nginx/sites-available/ # 可存储每个站点服务器块的目录。 除非将Nginx链接到sites-enabled了sites-enabled目录,否则Nginx不会使用此目录中的配置文件。 通常,所有服务器块配置都在此目录中完成,然后通过链接到其他目录启用。
4/etc/nginx/sites-enabled/ # 存储启用的每个站点服务器块的目录。 通常,这些是通过链接到sites-available目录中的配置文件创建的。
5/etc/nginx/snippets # 这个目录包含可以包含在Nginx配置其他地方的配置片段。 可重复配置的片段可以重构为片段。
6# nginx服务器日志文件:
7/var/log/nginx/access.log # 除非Nginx配置为其他方式,否则每个对您的Web服务器的请求都会记录在此日志文件中。
8/var/log/nginx/error.log # 任何Nginx错误都会记录在这个日志中。
除另有声明外,本博客文章均采用 知识共享 (Creative Commons) 署名 4.0 国际许可协议 进行许可。转载请注明原作者与文章出处。