Nginx怎么高效的在一臺服務器部署多個站點

今天小編給大家分享一下Nginx怎么高效的在一臺服務器部署多個站點的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

成都創新互聯公司專注于豐滿企業網站建設,響應式網站建設,成都商城網站開發。豐滿網站建設公司,為豐滿等地區提供建站服務。全流程按需策劃,專業設計,全程項目跟蹤,成都創新互聯公司專業和態度為您提供的服務

下來看一下我們的需求,我這里有三個網站項目工程需要部署(依次對應著三個域名),提供一臺linux服務器,要實現訪問對應的域名跳轉到對應的網站。

下來我們看一下為了解決這個問題,我所設計的體系架構圖:

Nginx怎么高效的在一臺服務器部署多個站點

這里我們假定圖中linux服務器公網ip為192.168.2.100,然后假定要在這臺服務器搭建這么三個站點:www.nginxtest.net、admin.nginxtest.net、app.nginxtest.net。

好了,下來我們具體配置一下:

1.配置nginx反向代理

我們還是先連接ssh,然后進行下面操作(一般不建議修改默認主配置文件nginx.conf,所以我們新建負載均衡配置文件fxdl.conf,保證服務器安全,如下):

$ ssh root@192.168.2.100             //ssh連接
# cd /usr/local/nginx/conf
# touch fxdl.conf                 //創建代理配置文件
# vi fxdl.conf                  //用vi編輯器打開文件,然后按鍵盤的i

注意:vi編輯器中,鍵盤按 i 進入 insert 狀態,按 esc 退出 insert 狀態。

然后輸入以下配置代碼(域名部分自定義更改成你們自己的域名,注釋部分則按需開啟):

#設置低權限用戶,為了安全而設置的
user nobody;

#工作衍生進程數
worker_processes 4;

#設置錯誤文件存放路徑
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;

#設置pid存放路徑(pid是控制系統中重要文件)
#pid logs/nginx.pid;

#設置最大連接數
events{
  worker_connections 1024;
}

http {
  #用來設置日志格式
  log_format main '$remote_addr - $remote_user [$time_local] "$request" '
           '$status $body_bytes_sent "$http_referer" '
           '"$http_user_agent" "$http_x_forwarded_for"';
  #用來指定日志文件的存放路徑
  access_log /data/wwwlogs/access_nginx.log main;

  #開啟高效文件傳輸模式
  sendfile      on;
  #防止網絡阻塞
  tcp_nopush     on;
  #防止網絡阻塞
  tcp_nodelay     on;
  #長連接超時時間,單位是秒
  keepalive_timeout  65;
  #散列表的沖突率,默認1024,越大則內存消耗更多,但散列key的沖突率會降低,檢索速度就更快
  types_hash_max_size 2048;

  #文件擴展名與文件類型映射表
  include       /usr/local/nginx/conf/mime.types;
  #默認文件類型
  default_type    application/octet-stream;

  #include /etc/nginx/conf.d/*.conf;

  #主要是用于設置一組可以在proxy_pass和fastcgi_pass指令中使用額代理服務器,默認負載均衡方式為輪詢
  upstream tomcat_client {
    server localhost:8080;
  }

  #開啟gzip壓縮,開啟后,訪問網頁會自動壓縮
  #gzip on;

  #指定服務器的名稱和參數
  server {
    listen 80;
    server_name app.nginxtest.net;
    location / {
      proxy_pass http://tomcat_client;
      proxy_redirect default;
      #設置代理
      proxy_set_header host $host;
      proxy_set_header x-real-ip $remote_addr;
    }
  }
  server {
    listen 80;
    server_name admin.nginxtest.net;
    location / {
      proxy_pass http://tomcat_client;
      proxy_redirect default;
      proxy_set_header host $host;
      proxy_set_header x-real-ip $remote_addr;
    }
  }
  server {
    listen 80;
    server_name www.nginxtest.net;
    location / {
      proxy_pass http://tomcat_client;
      proxy_redirect default;
      proxy_set_header host $host;
      proxy_set_header x-real-ip $remote_addr;
    }
    location = / {
      #判斷是否為手機移動端
      if ($http_user_agent ~* '(iphone|ipod|ipad|android|windows phone|mobile|nokia)') {
        rewrite . http://www.nginxtest.net/phone break;
      }
      rewrite . http://www.nginxtest.net/pc break;
    }
  }
}

好了就是這么簡單,nginx反向代理配置完畢。下來配置tomcat:

2.配置tomcat部署多個站點

$ ssh root@192.168.2.100             //ssh連接
# cd /usr/local/tomcat
# cp /usr/local/tomcat/conf/server.xml /usr/local/tomcat/conf/server.xml_bk //備份server.xml原文件
# vi server.xml                  //用vi編輯器打開文件,然后按鍵盤的i

我們編輯server.xml,engine節點下添加以下host節點(節點中的域名和站點工程目錄需要自定義修改為你們自己的):

<host name="www.nginxtest.net" unpackwars="true" autodeploy="true"
      xmlvalidation="false" xmlnamespaceaware="false">
  <context path="/" docbase="/data/wwwroot/www.nginxtest.net/webcontent" reloadable="true"/>
</host>
<host name="admin.nginxtest.net" unpackwars="true" autodeploy="true"
      xmlvalidation="false" xmlnamespaceaware="false">
  <context path="/" docbase="/data/wwwroot/admin.nginxtest.net/webcontent" reloadable="true"/>
</host>
<host name="app.nginxtest.net" unpackwars="true" autodeploy="true"
      xmlvalidation="false" xmlnamespaceaware="false">
  <context path="/" docbase="/data/wwwroot/app.nginxtest.net/webcontent" reloadable="true"/>
</host>

注意:如果你想要實現直接訪問公網ip無網頁效果,刪除engine節點下的

<host name="localhost" ..>..</host>

即可。

輸入完成后按下esc,然后輸入:

:wq!

就可以保存并退出配置文件了。到此,tomcat也配置完畢了。

接下來我們就可以將我們的多個站點工程代碼放在 /data/wwwroot/ 下了。然后啟動nginx和tomcat。

現在可以試一下,分別訪問每個站點的二級域名www.nginxtest.net、admin.nginxtest.net、app.nginxtest.net,我們發現已經可以跳轉到對應的站點了(和每個站點分別部署一臺服務器,看到的效果是一樣的)。

以上就是“Nginx怎么高效的在一臺服務器部署多個站點”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注創新互聯行業資訊頻道。

當前標題:Nginx怎么高效的在一臺服務器部署多個站點
本文來源:http://www.kartarina.com/article42/ijpehc.html

成都網站建設公司_創新互聯,為您提供、動態網站、關鍵詞優化、面包屑導航、企業網站制作、外貿建站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站托管運營
主站蜘蛛池模板: 无码人妻精品内射一二三AV| 曰产无码久久久久久精品| 中文字幕无码久久久| 无码日韩精品一区二区免费暖暖| 人妻中文字系列无码专区| 亚洲AV无码AV吞精久久| 亚洲AV区无码字幕中文色| 国产午夜鲁丝片AV无码| 无码人妻精品一区二区三区蜜桃 | 亚洲成av人片不卡无码| 精品亚洲成α人无码成α在线观看| 亚洲国产精品无码中文字| 国产丰满乱子伦无码专| 亚洲日韩乱码中文无码蜜桃| 亚洲va中文字幕无码久久| 国产亚洲精品无码拍拍拍色欲| 亚洲精品无码成人片久久不卡| 久久久久无码国产精品一区| 熟妇人妻中文a∨无码| 亚洲中文字幕无码专区| 久久久久亚洲AV无码去区首 | 亚洲AV无码成人网站久久精品大| 日韩乱码人妻无码中文字幕视频| 亚洲精品无码久久久久久久| 无码137片内射在线影院| 中文字幕乱偷无码AV先锋| h无码动漫在线观看| 国产精品无码素人福利| 日韩视频无码日韩视频又2021| 特级小箩利无码毛片| 国产精品无码免费播放 | 无码欧精品亚洲日韩一区夜夜嗨| 亚洲AV成人无码天堂| 亚洲日韩精品无码专区| 亚洲一区AV无码少妇电影| 久久亚洲AV成人无码国产电影 | 精品无码人妻一区二区三区不卡| 国产高清不卡无码视频| 久久亚洲AV永久无码精品| 人妻无码aⅴ不卡中文字幕| 久久久久亚洲精品无码网址 |