使用nginx在一台伺服器部署多個Web Server

不言
發布: 2023-04-02 20:36:01
原創
8326 人瀏覽過

這篇文章主要介紹了關於使用nginx在一台伺服器部署多個Web Server,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

最近搗鼓了不少時間,一開始想到要弄這個就是因為node 直接起server 的方式有點暴力,因為佔用了80 埠就是真的佔用了,很難在用一個80 埠掛多個WebServer。你只能掛載在多個端口上,訪問起來後面還得加個端口,太醜了,所以摸索了一下,用 Nginx 配置了一個多服務結構。這樣就能透過不同的子網域來存取不同的應用程式了!

大致的結構

使用nginx在一台伺服器部署多個Web Server

#本質上就是nginx 負責轉送進來的請求,那麼轉送的依據就是判斷不同的子網域

STEP 1 Install Nginx

第一步當然是安裝nginx,各個平台不太一樣,也沒辦法分享了。我自己的ubuntu 的環境

apt-get isntall nginx

STEP 2 Set DNS AND PORT

去你的網域管理商那裡分配你想要的子域名,當然都是A 記錄並全部解析到你的VPS 公網IP 上.

另外一個準備就是修改你所有的NodeWebServer 的端口,可以按你的愛好設置,但是不要佔用80 以及443 端口

STEP 3 nginx config Node.js

#切換到你的nginx 設定目錄

我的目錄位置

/etc/ nginx/

這裡要說明nginx 是擁有Include 機制的,他會自動載入conf.d 目錄下的所有_.conf_(預設設定下) ,所以我們並不需要修改nginx.conf 檔案。我們接下來需要在conf.d 目錄下建立一系列的設定文件,檔案名稱請使用你對應的工程名,例如project1.conf

如果沒有請手動加入

        include /etc/nginx/conf.d/*.conf;
        # include /etc/nginx/sites-enabled/*; // 最好给他注释了 默认页面没啥用
登入後複製

開始寫專案設定

cd conf.d

touch project1.conf

vim project1.conf

##讓我們寫詳細的轉發規則

// 这是一个NODE Web Server
// 我已经将这个服务的端口改成了8000端口
// 当nginx捕获到访问域名为api.yinode.tech的时候
// 就会转发到本地的8000端口
server{
    server_name api.yinode.tech;
    listen 80;
    location / {
        # proxy_http_version 1.1;
        proxy_set_header Connection "";
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header X-NginX-Proxy true;
        proxy_pass http://127.0.0.1:8000$request_uri;
        proxy_redirect off;
    }
}
登入後複製
如果你需要轉送HTTPS,請複製一份上面的內容貼到下面,修改監聽埠為443,轉送埠就是你監聽的https 埠!

STEP 4 nginx config PHP

php 的轉送設定會稍微不同,(預設你已經安裝好了PHP)

server {
  listen 80;
  root /var/www/longqiyoutian/wordpress; // 你的根目录
  index index.php;
  server_name dragon.yinode.tech;
  error_page 404 /404.html;
  location ~ \.php$ {
    try_files $uri = 404;
    fastcgi_pass unix:/var/run/php/php7.0-fpm.sock; // 你的fpm地址
    fastcgi_index index.php;
    include fastcgi_params;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name; // 必须填写,注意顺序
  }
}
登入後複製
逐一解,首先我們的Root目錄會變的重要,Nginx 會把這個目錄轉寄給FPM 來跑PHP 程式碼,所以不要寫錯了,第二是後面的轉寄必須加上

fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;這能引導fpm 進行正確的位址拼接

TIPS:提醒
nginx 和FPM 的預設啟動使用者都是www-data,所以你的網站根目錄請務必修改所屬者為www-data ,並且不要將這個目錄放置到/root/ 下,會出現權限問題,最好複製到/var/www 目錄下,並設定所屬者!

STEP 5 Repeat

重複3 4 步驟,建立所有你需要的專案設定

STEP 6 Restart nginx

service nginx restart
如果出現報錯,仔細查看訊息,去網路找,通常都是因為設定檔格式錯誤。

STEP 7 Run

打開你的網站吧,應該可以正常運作了!以後新增 Server 其實也只要增加一個對應的 conf 檔案,可以很方便的橫向擴展,整個網站存取起來也會比較美觀!

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

Nginx 設定未綁定網域禁止存取

以上是使用nginx在一台伺服器部署多個Web Server的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!