在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以支持多个站点共存。