在Nginx中配置虛擬主機(Virtual Host)可以讓你在同一臺服務器上托管多個網站。以下是一個基本的步驟指南,幫助你配置Nginx虛擬主機。
首先,確保你已經在服務器上安裝了Nginx。你可以使用以下命令來安裝:
sudo apt update
sudo apt install nginx
為每個網站創建一個目錄,用于存放網站的文件。例如:
sudo mkdir -p /var/www/site1.com/html
sudo mkdir -p /var/www/site2.com/html
編輯Nginx的配置文件來設置虛擬主機。你可以編輯默認的配置文件,或者為每個網站創建一個新的配置文件。
打開默認的Nginx配置文件:
sudo nano /etc/nginx/sites-available/default
在server
塊中添加虛擬主機的配置。例如:
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;
}
}
對于第二個網站,你可以添加另一個server
塊:
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;
}
}
創建符號鏈接將配置文件鏈接到sites-enabled
目錄:
sudo ln -s /etc/nginx/sites-available/site1.com /etc/nginx/sites-enabled/
sudo ln -s /etc/nginx/sites-available/site2.com /etc/nginx/sites-enabled/
在重新加載Nginx之前,測試配置文件是否有語法錯誤:
sudo nginx -t
如果配置文件沒有問題,重新加載Nginx以應用更改:
sudo systemctl reload nginx
確保你的域名(例如site1.com
和site2.com
)的DNS記錄指向你的服務器IP地址。
如果你的服務器啟用了防火墻,確保開放HTTP(80)和HTTPS(443)端口:
sudo ufw allow 'Nginx Full'
如果你想為你的網站啟用HTTPS,可以使用Let’s Encrypt免費獲取SSL證書,并配置Nginx使用這些證書。
安裝Certbot:
sudo apt install certbot python3-certbot-nginx
運行Certbot來獲取并配置SSL證書:
sudo certbot --nginx -d site1.com -d www.site1.com
sudo certbot --nginx -d site2.com -d www.site2.com
按照提示完成配置。
通過以上步驟,你應該能夠在同一臺服務器上成功配置多個Nginx虛擬主機。