導語
之前介紹 docker 的時候就說過它的優點之一,就是可以在同一伺服器中建立多個環境,互相隔離。昨天就實際操作下,萬萬沒想到這麼多的坑,比之前從零開始搭建伺服器都花時間。變換了好幾種方案,最後還是解決了,中間的心酸就忽略吧,直接說操作方法。
推薦教學:nginx教學
架構
伺服器中已存在的是laradock 鏡像,可以運行laravel 環境以及其他的PHP,包含了nginx、mysql、redis 等。
我的想法是再增加一個 nginx 容器,用來做反向代理。根據子網域進行分發,可以分發給laradock,也可以給其他任何容器(包括wordpress、python、java)等等
修改lradock
要修改的只有一個地方,就是nginx 監聽的連接埠。
1.進入laradock 目錄
2.修改.env 文件,修改NGINX_HOST_HTTP_PORT 值由80 為8000
#3.停止nginx,docker-compose stop nginx
4.重裝nginx,docker-compose build nginx
#5.啟動docker-compose up -d nginx
這時候在瀏覽器中是不能存取成功的,因為nginx 已經不再監聽80 埠。
新增 nginx 容器
新新增一個 nginx 容器用來做反向代理。在安裝 laradock 的時候,已經有了 nginx:alpine 的鏡像,可以直接產生容器。當然你也可以重新 pull 一個新的鏡像。 (推薦使用alpine版本)
1.查看nginx 映像ID,docker iamges
2.產生新的ngixn 容器,docker run --name proxy_nginx -p 80:80 -d [nginx image id]。也可以添加-v 參數來映射配置文件,我的環境較少變動就不需要了
3.此時在瀏覽器中訪問,應該是nginx 的默認頁面,說明啟動成功
4.進入到生成的容器中docker exec -it proxy_nginx sh
#5.安裝vim,apk add vim
6.查看宿主機ip,/sbin/ip route| awk '/default/ { print $3 }'
7.在/etc/nginx/conf.d/目錄下新增設定檔laradock.conf,內容如下
server { listen 80; server_name you_site; location / { proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://[宿主机IP]:8000; } }
1.退出容器,然後重啟docker restart proxy_nginx
2.打開8000 端口,參考這裡
結語
這個時候訪問的話,就可以代理到laradock中的nginx 了。後續想要新增其他的容器,只要在 proxy_nginx 中新增的代理規則就可以了。
以上是使用 nginx 反向代理多個 docker 容器的詳細內容。更多資訊請關注PHP中文網其他相關文章!

NGINXUnit優於ApacheTomcat、Gunicorn和Node.js內置HTTP服務器,適用於多語言項目和動態配置需求。 1)支持多種編程語言,2)提供動態配置重載,3)內置負載均衡功能,適合需要高擴展性和可靠性的項目。

NGINXUnit通過其模塊化架構和動態重配置功能提高了應用的性能和可管理性。 1)模塊化設計包括主控進程、路由器和應用進程,支持高效管理和擴展。 2)動態重配置允許在運行時無縫更新配置,適用於CI/CD環境。 3)多語言支持通過動態加載語言運行時實現,提升了開發靈活性。 4)高性能通過事件驅動模型和異步I/O實現,即使在高並發下也保持高效。 5)安全性通過隔離應用進程提高,減少應用間相互影響。

NGINXUnit可用於部署和管理多種語言的應用。 1)安裝NGINXUnit。 2)配置它以運行不同類型的應用,如Python和PHP。 3)利用其動態配置功能進行應用管理。通過這些步驟,你可以高效地部署和管理應用,提升項目效率。

NGINX更适合处理高并发连接,而Apache更适合需要复杂配置和模块扩展的场景。1.NGINX以高性能和低资源消耗著称,适合高并发。2.Apache以稳定性和丰富的模块扩展闻名,适合复杂配置需求。

NGINXUnit通過其動態配置和高性能架構提升應用的靈活性和性能。 1.動態配置允許在不重啟服務器的情況下調整應用配置。 2.高性能體現在事件驅動和非阻塞架構以及多進程模型上,能夠高效處理並發連接和利用多核CPU。

NGINX和Apache都是強大的Web服務器,各自在性能、可擴展性和效率上有獨特的優勢和不足。 1)NGINX在處理靜態內容和反向代理時表現出色,適合高並發場景。 2)Apache在處理動態內容時表現更好,適合需要豐富模塊支持的項目。選擇服務器應根據項目需求和場景來決定。

NGINX適合處理高並發請求,Apache適合需要復雜配置和功能擴展的場景。 1.NGINX採用事件驅動、非阻塞架構,適用於高並發環境。 2.Apache採用進程或線程模型,提供豐富的模塊生態系統,適合複雜配置需求。

NGINX可用於提升網站性能、安全性和可擴展性。 1)作為反向代理和負載均衡器,NGINX可優化後端服務和分擔流量。 2)通過事件驅動和異步架構,NGINX高效處理高並發連接。 3)配置文件允許靈活定義規則,如靜態文件服務和負載均衡。 4)優化建議包括啟用Gzip壓縮、使用緩存和調整worker進程。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版
好用的JavaScript開發工具

記事本++7.3.1
好用且免費的程式碼編輯器

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中