1. 程式人生 > >在Nginx上配置多個站點

在Nginx上配置多個站點

有時候你想在一臺伺服器上為不同的域名執行不同的站點。比如www.siteA.com作為部落格,www.siteB.com作為論壇。你可以把兩個域名的IP都解析到你的伺服器上,但是沒法在Nginx的根目錄裡同時執行兩個不同的網站。這時候,你就需要使用虛擬目錄了。假設你把部落格放在”/home/user/www/blog”下,論壇放在”/home/user/www/forum”下。下面我們就開始配置了:

  • 在Nginx配置目錄下,建立一個”vhost”目錄。本例假設Nginx是預設安裝,配置目錄在”/etc/nginx”
$ sudo mkdir /etc/nginx/vhost
  • 建立siteA的配置檔案
$ sudo vi /etc/nginx/vhost/vhost_siteA.conf
  • 輸入以下配置資訊
複製程式碼
server {
    listen       80;                        # 監聽埠
    server_name www.siteA.com siteA.com;    # 站點域名
    root  /home/user/www/blog;              # 站點根目錄
    index index.html index.htm index.php;   # 預設導航頁
 
    location 
/ { # WordPress固定連結URL重寫 if (!-e $request_filename) { rewrite (.*) /index.php; } } # PHP配置 location ~ \.php$ { fastcgi_pass unix:/var/run/php5-fpm.sock; fastcgi_index index.php; include fastcgi_params; } }
複製程式碼
  • 同siteA一樣建立siteB的配置檔案,兩者僅有的不同是”server_name”和”root”目錄
$ sudo vi /etc/nginx/vhost/vhost_siteB.conf
複製程式碼
server {
    ...
    server_name www.siteB.com siteB.com;    # 站點域名
    root  /home/user/www/forum;             # 站點根目錄
    ...
}
複製程式碼
  • 開啟nginx.conf檔案
sudo vi /etc/nginx/nginx.conf
  • 將虛擬目錄的配置檔案加入到”http {}”部分的末尾
http {
    ...
    include /etc/nginx/vhost/*.conf;
}
  • 重啟Nginx服務
$ sudo service nginx restart

禁止訪問小技巧

假如你的Nginx根目錄設在”/home/user/www”,你想阻止別人通過”http://IP地址/blog”或”http://IP地址/forum”來訪問你的站點,最簡單的方法就是禁止IP地址訪問。方法如下:

  1. 開啟Nginx網站預設配置檔案,記得先備份
$ sudo cp /etc/nginx/sites-available/default /etc/nginx/sites-available/default_bak
$ sudo vi /etc/nginx/sites-available/default
  1. 將所有內容刪除,只留以下配置
server {
    listen 80 default_server;
    server_name _;
    return 404;
}
  1. 重啟Nginx後,別人將無法通過IP地址訪問網站了

如果你不想禁止IP地址訪問整個目錄,只是要防止別人通過IP訪問你的部落格和論壇。那就需要禁止”/blog”和”/forum”的目錄訪問。

  1. 開啟Nginx網站預設配置檔案,同上面一樣,記得先備份
  1. 在”server{ }”部分加上以下配置
複製程式碼
location ^~ /blog/ {
    deny all;
}
location ^~ /forum/ {
    deny all;
}
複製程式碼
  1. 重啟Nginx即可
雲伺服器、雲資料庫方案、網路安全防護優選