您好,登錄后才能下訂單哦!
今天小編給大家分享一下Nginx怎么高效的在一臺服務器部署多個站點的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
下來看一下我們的需求,我這里有三個網站項目工程需要部署(依次對應著三個域名),提供一臺linux服務器,要實現訪問對應的域名跳轉到對應的網站。
下來我們看一下為了解決這個問題,我所設計的體系架構圖:
這里我們假定圖中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怎么高效的在一臺服務器部署多個站點”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。