docker啟動Nginx的兩種方式小結
Nginx鏡像的獲取
- 直接從Docker Hub拉取Nginx鏡像
- 通過Dockerfile構建Nginx鏡像后拉取
二者區(qū)別
主要區(qū)別在于定制化程度和構建過程的控制:
直接拉取Nginx鏡像:
- 簡便性:直接使用docker pull nginx命令可以快速拉取官方的Nginx鏡像。這個過程非常簡單,適合快速部署標準的Nginx服務。
- 標準化:拉取的是Nginx官方維護的鏡像,保證了環(huán)境的一致性和可靠性。這個鏡像經過了官方的優(yōu)化和安全更新。
- 限制:官方鏡像提供了Nginx的標準安裝,可能不包含特定的模塊或配置。如果需要特殊配置或額外的模塊,可能需要在容器啟動后手動進行調整。
通過Dockerfile構建Nginx鏡像:
- 定制化:通過編寫Dockerfile,可以在構建過程中定制Nginx的安裝,包括添加特定的模塊、配置文件、環(huán)境變量等。這為滿足特定需求提供了靈活性。
- 自動化:構建過程可以自動化執(zhí)行,包括從基礎鏡像安裝Nginx、應用配置文件、復制網站內容等。這使得整個部署過程可重復、可追蹤。
- 維護:如果需要更新配置或添加功能,可以直接修改Dockerfile和相關文件,然后重新構建鏡像。這簡化了更新和維護過程。
- 構建時間:根據(jù)Dockerfile的復雜度,構建鏡像可能需要一些時間。對于頻繁的構建和測試,這可能會稍微增加開發(fā)周期。
總結,直接拉取Nginx鏡像適合快速部署和標準使用場景,而通過Dockerfile構建Nginx鏡像適合需要特定配置、模塊或自動化部署流程的場景。選擇哪種方式取決于項目的具體需求和開發(fā)流程。
Nginx關鍵目錄
配置目錄 (/etc/nginx/): 存放Nginx的主配置文件nginx.conf以及其他配置文件。這個目錄通常包括:
- nginx.conf:主配置文件
- sites-available/:存放每個站點的配置文件,這些文件需要被鏈接到sites-enabled/才能被Nginx讀取。
- sites-enabled/:存放鏈接到sites-available/中站點配置文件的符號鏈接,Nginx會讀取這里的配置來啟動網站。
- conf.d/:用于存放其他額外的配置文件,Nginx會自動加載這個目錄下的配置文件。
- default.conf : 默認服務器配置文件
- *.conf:額外的配置文件 - 日志目錄 (/var/log/nginx/): 存放訪問日志和錯誤日志。
- access.log:默認的訪問日志文件,記錄所有請求的詳細信息。
- error.log:默認的錯誤日志文件,記錄啟動、運行錯誤以及請求處理的問題。
- 網站內容目錄 (/usr/share/nginx/html): 默認的網站根目錄,存放網站的靜態(tài)文件,如HTML、CSS、JavaScript等。
- 可執(zhí)行文件目錄 (/usr/sbin/nginx): 存放Nginx的可執(zhí)行文件。
- 客戶端臨時文件目錄 (/var/cache/nginx/): 存放客戶端請求的臨時文件,比如用于緩存的文件。
- SSL證書目錄: 存放SSL證書和私鑰的目錄,通常這個目錄不是固定的,需要在Nginx的SSL配置中指定證書和私鑰文件的路徑。
直接從Docker Hub拉取Nginx鏡像
拉取最新的Nginx官方鏡像:
docker pull nginx
如果你想要拉取特定版本的Nginx鏡像,可以通過指定標簽來完成。例如,要拉取Nginx 1.19版本的鏡像,可以使用:
docker pull nginx:1.19
查看已下載的鏡像
docker images
配置Nginx
通常所有配置都應該通過Docker卷(volumes)或綁定掛載(bind mounts)來管理,以便于配置的持久化和更新。
所以先在宿主機上創(chuàng)建配置文件 ,再將其掛載到nginx
/home/nginx/nginx.conf
worker_processes 1; # 工作進程數(shù)量,通常設置為CPU核心數(shù) events { worker_connections 1024; # 每個工作進程的最大連接數(shù) } http { include /etc/nginx/mime.types; # 包含MIME類型定義 default_type application/octet-stream; # 默認文件類型 sendfile on; # 啟用高效文件傳輸模式 keepalive_timeout 65; # 保持連接的超時時間 server { listen 80; # 監(jiān)聽的端口 server_name localhost; # 處理以/開頭的請求 location / { root /usr/share/nginx/html; # 定義網站靜態(tài)資源根目錄 index index.html index.htm; # 默認文件(從root目錄下找) } # 處理以/api/開頭的請求,并將它們轉發(fā)到后端服務器 location /api/ { # 指令用于修改或添加傳遞給后端服務器的請求頭。 proxy_set_header Host $http_host; # 請求頭中的Host字段的值 proxy_set_header X-Real-IP $remote_addr; # 發(fā)起請求的客戶端的IP地址 proxy_set_header REMOTE-HOST $remote_addr; # 在代理請求時構建X-Forwarded-For頭(用于追蹤請求的原始IP地址,可包含多個) proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass 代理轉發(fā)請求的目標地址; # 后端地址 } error_page 500 502 503 504 /50x.html; # 錯誤頁面 location = /50x.html { root /usr/share/nginx/html; # 錯誤頁面的根目錄 } } }
/home/nginx/html/index.html
<html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-inline' 'unsafe-eval';" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>my nginx test</title> </head> <body> <div>hello nginx html</div> <h1>edit html</h1> </body> </html>
啟動Nginx
docker run --name my-nginx-test3 -p 80:80 -v /home/nginx/nginx.conf:/etc/nginx/nginx.conf -v /home/nginx/html:/usr/share/nginx/html -d nginx
啟動容器:docker run
–name: 為容器指定一個唯一的名稱,可以通過名稱來引用容器,而不是使用容器的ID
-p:映射端口,[宿主機端口(訪問端口)]:[nginx容器內listen的端口]
-v :綁定掛載配置 [宿主機路徑]:[容器內路徑]
-d:后臺運行,返回運行成功的鏡像id
查看運行的容器
docker ps
運行后修改配置文件重啟生效
重載Nginx配置:
docker exec <容器name> nginx -s reload
- 重啟Nginx容器:
docker restart nginx
瀏覽器輸入ip:端口
通過Dockerfile構建Nginx鏡像后拉取
注意執(zhí)行上下文路徑
創(chuàng)建Dockerfile:創(chuàng)建一個Dockerfile來構建您的Nginx鏡像。
# 使用Nginx官方鏡像作為基礎鏡像 FROM nginx:alpine # 將dist目錄(包含index.html和其他靜態(tài)文件)復制到Nginx容器的靜態(tài)文件目錄 # ./dist相對執(zhí)行構建上下文的路徑 COPY ./dist/ /usr/share/nginx/html/ # 將自定義的Nginx配置文件復制到Nginx容器(此步驟將修改nginx完整的主配置文件) COPY nginx/nginx.conf /etc/nginx/nginx.conf
- 準備Nginx配置文件(nginx.conf):創(chuàng)建一個Nginx配置文件來定義如何服務您的靜態(tài)文件。
同上面的 /home/nginx/nginx.conf 文件 - 準備dist/index.html文件
<html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-inline' 'unsafe-eval';" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>dockerfile nginx test</title> </head> <body> <div>hello use dockerfile nginx html</div> </body> </html>
構建和運行Docker容器:使用Dockerfile和Nginx配置文件構建Docker鏡像,并運行容器。
構建Docker鏡像
docker build -t my-dockerfile-nginx -f Dockerfile .
-t: 選項用于指定鏡像的名稱和標簽
. :最后的點號表示當前目錄是構建上下文
-f:指定dockerfile所在位置,若在當前執(zhí)行目錄可不用指定
運行Docker容器,開放9999端口訪問
docker run --name dockerfile-nginx -p 9999:80 -d my-dockerfile-nginx
瀏覽器輸入ip:端口
到此這篇關于docker啟動Nginx的兩種方式小結的文章就介紹到這了,更多相關docker啟動Nginx內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解Windows?利用?WSL2?安裝?Docker?的2種方式
這篇文章主要介紹了Windows?利用?WSL2?安裝?Docker?的2種方式,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-10-10Docker搭建服務器監(jiān)控面板的實現(xiàn)示例
Docker服務器監(jiān)控面板是一種用于監(jiān)控容器運行情況的工具,本文主要介紹了Docker搭建服務器監(jiān)控面板的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下2024-01-01Docker中數(shù)據(jù)卷(volume)管理的兩種方式
數(shù)據(jù)卷有兩種形式,一種是容器中的某個目錄,它可以被別的容器引用,只要有一個容器引用了這個數(shù)據(jù)卷,數(shù)據(jù)就不會被刪除;另一種數(shù)據(jù)卷是將容器中的數(shù)據(jù)卷和宿主機的目錄進行掛載。 數(shù)據(jù)卷可以在多個容器之間共享,修改數(shù)據(jù)卷不會影響鏡像2021-07-07docker連接spring boot和mysql容器方法介紹
這篇文章主要介紹了docker連接spring boot和mysql容器方法介紹,具有一定參考價值,需要的朋友可以了解下。2017-10-10