在CentOS上配置Nginx多站點主要涉及以下幾個步驟:
首先,確保你已經安裝了Nginx。如果沒有安裝,可以使用以下命令進行安裝:
sudo yum install epel-release
sudo yum install nginx
確保防火墻允許HTTP和HTTPS流量:
sudo firewall-cmd --permanent --zone=public --add-service=http
sudo firewall-cmd --permanent --zone=public --add-service=https
sudo firewall-cmd --reload
為每個站點創建一個目錄,并將網站文件放在這些目錄中。例如:
sudo mkdir -p /var/www/site1.com/html
sudo mkdir -p /var/www/site2.com/html
編輯Nginx配置文件,通常位于/etc/nginx/nginx.conf
或/etc/nginx/conf.d/default.conf
。你可以為每個站點創建一個單獨的配置文件。
創建一個名為site1.com.conf
的文件:
sudo nano /etc/nginx/conf.d/site1.com.conf
添加以下內容:
server {
listen 80;
server_name site1.com www.site1.com;
root /var/www/site1.com/html;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
創建一個名為site2.com.conf
的文件:
sudo nano /etc/nginx/conf.d/site2.com.conf
添加以下內容:
server {
listen 80;
server_name site2.com www.site2.com;
root /var/www/site2.com/html;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
在重新加載Nginx之前,測試配置文件是否有語法錯誤:
sudo nginx -t
如果配置文件沒有問題,重新加載Nginx以應用更改:
sudo systemctl reload nginx
確保你的域名(例如site1.com
和site2.com
)指向你的服務器IP地址。你可以在你的DNS提供商的管理界面中進行配置。
如果你希望為站點啟用HTTPS,可以使用Let’s Encrypt免費獲取SSL證書,并配置Nginx使用這些證書。
sudo yum install certbot python2-certbot-nginx
sudo certbot --nginx -d site1.com -d www.site1.com
sudo certbot --nginx -d site2.com -d www.site2.com
按照提示完成證書的獲取和安裝過程。
訪問你的站點,確保它們正常工作,并且SSL證書已正確安裝。
通過以上步驟,你可以在CentOS上成功配置Nginx多站點。