您好,登錄后才能下訂單哦!
這篇文章主要介紹“怎么使用Docker Compose構建復雜的多容器App”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“怎么使用Docker Compose構建復雜的多容器App”文章能幫助大家解決問題。
在構建容器過程中,一般需要重復運行一些命令, 如 docker build
,docker run
等等,這些命令有時冗長而復雜,逐個重復運行這些命令十分繁瑣,對于多容器的復雜應用尤其如此。使用 Docker Compose 工具能極大地簡化容器的創建、管理和維護。
Docker Compose 工具相當于 C/C++ 的 make
工具,使用 make
需要 Makefile
,所有的編譯鏈接設置都在Makefile
中指定,不需要為了運行程序而每次都在終端手動輸入長串的指令。
Docker Compose 同樣也需要一個配置文件: docker-compose.yaml
(文件擴展名也可以是 yml
).
YAML 是一種人類可讀的數據序列化語言,通常用于配置文件和存儲或傳輸數據的應用程序,YAML 使用 python 那樣的縮進以指示嵌套關系。縮進通常使用兩個空格,但是實際上沒有限制,同 python,使用 #
表示注釋。
如下是一個 Mern Stack App 項目結構:
docker-compose.yaml
文件內容如下:
# docker compose 規范的版本,下面的網站可查 # https://docs.docker.com/compose/compose-file/compose-versioning/ version: "3.8" # 此 mern 將創建3個容器,下面的3個服務 # mongodb, backend, frontend 將自動被翻譯成3個容器 services: mongodb: # 從 hub.docker.com 獲取官方image image: "mongo" # 命名卷: 持久化保存數據庫數據 volumes: - data:/data/db # 環境變量,在文件 ./env/mongo.env 里保存 env_file: - ./env/mongo.env backend: build: ./backend ports: - "80:80" volumes: # 命名卷 - logs:/app/logs # 綁定掛載,不同于命令,此文件中可以使用相對路徑, # 手動運行命令則需絕對路徑 - ./backend:/app # 匿名卷 - /app/node_modules env_file: - ./env/backend.env depends_on: - mongodb frontend: build: ./frontend ports: - "3000:3000" volumes: - ./frontend/src:/app/src # stdin_open 和 tty 對應手動執行命令時的 -it stdin_open: true tty: true # 僅僅在容器 backend 運行后,才會運行此 frontend depends_on: - backend - # 這里是整個 App 的命名卷 # 匿名卷和 bind-mounts 不能在這里指定 volumes: data: logs:
docker-compose up
docker-compose up
默認以附加模式運行,如果需要以分離模式運行則在命令后加 -d
:
docker-compose up -d
也因為此原因,docker-compose.yaml
里沒有設置 -d
的選項。
docker-compose down
使用 Docker Compose, Dockerfile
文件仍然必不可少。 Docker Compose創建一個默認網絡并將所有容器添加到該網絡,故 docker-compose.yaml
里不需要指定網絡。
docker-compose down 將停止并刪除容器,因此 docker-compose.yaml 沒有選項 --rm
不管是單容器還是多容器,使用 Docker Compose 能極大簡化容器的創建、管理和維護,由此可見,Docker Compose 是一個強大的非常有用的工具。
關于“怎么使用Docker Compose構建復雜的多容器App”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。