如何在Ubuntu 18.04上设置Nginx服务器块
Nginx服务器块使我们可以在一台机器上运行多个。
使用服务器块,我们可以指定站点文档根目录(包含文件的目录),为每个站点创建单独的安全策略,为每个站点使用不同的SSL证书等等。
在本文中,我们将提供有关如何在Ubuntu 18.04上设置Nginx服务器块(类似于Apache虚拟主机)的分步说明。
准备工作
在继续学习本教程之前,请确保我们已满足以下准备工作:
- 我们有一个指向公共服务器IP的域名。我们将使用'example.com'。
- 请按照以下说明安装Nginx。
- 我们以具有sudo特权的用户身份登录。
在某些文档中,我们会看到“服务器块”被称为“虚拟主机”。
虚拟主机是Apache的术语。
创建目录结构
文档根目录是用于存储域名文件并响应请求的目录。
我们可以将文档根目录设置为所需的任何位置。
我们将使用以下目录结构:
/var/www/ ├── domain1.com │ └── public_html ├── domain2.com │ └── public_html ├── domain3.com │ └── public_html
基本上,我们将为要托管在服务器上的每个域创建一个单独的目录,位于/var/www目录中。
在每个目录中,我们将创建一个“ public_html”目录,该目录将存储域文件。
让我们为我们的域“ example.com”创建根目录:
sudo mkdir -p /var/www/example.com/public_html
为了进行测试,我们将在域的文档根目录内创建一个“ index.html”文件。
打开编辑器并创建演示文件:
/var/www/example.com/public_html/index.html
<!DOCTYPE html> <html lang="en" dir="ltr"> <head> <meta charset="utf-8"> <title>Welcome to example.com</title> </head> <body> <h1>Success! example.com home page!</h1> </body> </html>
在此示例中,我们以sudo用户身份运行命令,而新创建的文件和目录归root用户所有。
为了避免任何权限问题,请将域文档根目录的所有权更改为Nginx用户('www-data'):
sudo chown -R www-data: /var/www/example.com
创建一个服务器块
在Ubuntu系统上,默认情况下,Nginx服务器块配置文件存储在“/etc/nginx/sites-available”目录中,该文件通过指向“/etc/nginx/sites-enabled /”目录的符号链接启用。
打开我们选择的编辑器并创建以下服务器块文件:
/etc/nginx/sites-available/example.com
server { listen 80; listen [::]:80; root /var/www/example.com/public_html; index index.html; server_name example.com www.example.com; access_log /var/log/nginx/example.com.access.log; error_log /var/log/nginx/example.com.error.log; location/{ try_files $uri $uri/=404; } }
我们可以根据需要命名配置文件,但是通常最好使用域名。
要启用新的服务器阻止文件,请创建一个从文件到'sites-enabled'目录的符号链接,Nginx在启动过程中会读取该链接:
sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/
测试Nginx配置的语法是否正确:
sudo nginx -t
如果没有错误,输出将如下所示:
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful
重新启动Nginx服务,以使更改生效:
sudo systemctl restart nginx
最后,要验证服务器块是否按预期工作,请在我们选择的浏览器中打开“ http://example.com”