在CentOS上配置Nginx以支持多个站点共存是一个常见的需求。以下是一个基本的步骤指南,帮助你在CentOS上设置多个Nginx站点。
首先,确保你已经安装了Nginx。如果没有安装,可以使用以下命令进行安装:
sudo yum install epel-release
sudo yum install nginx
安装完成后,启动Nginx服务并设置开机自启动:
sudo systemctl start nginx
sudo systemctl enable nginx
Nginx的站点配置文件通常位于 /etc/nginx/conf.d/ 或 /etc/nginx/sites-available/ 目录下。你可以在这两个目录中创建新的配置文件来定义不同的站点。
站点1:example1.com
sudo vi /etc/nginx/conf.d/example1.conf
server {
listen 80;
server_name example1.com www.example1.com;
root /var/www/example1;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
error_page 404 /404.html;
location = /404.html {
root /var/www/example1;
}
}
站点2:example2.com
sudo vi /etc/nginx/conf.d/example2.conf
server {
listen 80;
server_name example2.com www.example2.com;
root /var/www/example2;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
error_page 404 /404.html;
location = /404.html {
root /var/www/example2;
}
}
为每个站点创建相应的目录和文件:
sudo mkdir -p /var/www/example1
sudo mkdir -p /var/www/example2
echo "Welcome to Example 1" | sudo tee /var/www/example1/index.html
echo "Welcome to Example 2" | sudo tee /var/www/example2/index.html
在重新加载Nginx之前,测试配置文件是否有语法错误:
sudo nginx -t
如果没有错误,重新加载Nginx以应用更改:
sudo systemctl reload nginx
确保你的域名(例如 example1.com 和 example2.com)指向你的服务器IP地址。你可以在你的DNS提供商的管理界面中进行配置。
如果你的服务器启用了防火墙,确保开放HTTP(80)和HTTPS(443)端口:
sudo firewall-cmd --permanent --zone=public --add-service=http
sudo firewall-cmd --permanent --zone=public --add-service=https
sudo firewall-cmd --reload
为了提高安全性,你可以为你的站点配置SSL证书。可以使用Let’s Encrypt免费获取SSL证书,并使用Certbot进行配置。
sudo yum install certbot python2-certbot-nginx
sudo certbot --nginx -d example1.com -d www.example1.com
sudo certbot --nginx -d example2.com -d www.example2.com
按照提示完成SSL证书的安装和配置。
通过以上步骤,你就可以在CentOS上成功配置Nginx以支持多个站点共存。