目錄
- Compose介紹
- 一、前置條件
- 二、使用方法
- 三、測(cè)試
Compose介紹
Docker Compose是一個(gè)用來(lái)定義和運(yùn)行復(fù)雜應(yīng)用的Docker工具。一個(gè)使用Docker容器的應(yīng)用,通常由多個(gè)容器組成。使用Docker Compose不再需要使用shell腳本來(lái)啟動(dòng)容器。
Compose 通過(guò)一個(gè)配置文件來(lái)管理多個(gè)Docker容器,在配置文件中,所有的容器通過(guò)services來(lái)定義,然后使用docker-compose腳本來(lái)啟動(dòng),停止和重啟應(yīng)用,和應(yīng)用中的服務(wù)以及所有依賴(lài)服務(wù)的容器,非常適合組合使用多個(gè)容器進(jìn)行開(kāi)發(fā)的場(chǎng)景。
一、前置條件
1.安裝 docker-compose ,可以參考這篇文章 https://www.jb51.net/article/203802.htm
二、使用方法
1.目錄結(jié)構(gòu)
|--mysite # 根目錄 |----docker-compose.yml # 用于部署上線 |----Dockerfile # 用于打包鏡像 |----server.py # 測(cè)試服務(wù)
2.創(chuàng)建測(cè)試服務(wù)【server.py】
from fastapi import FastAPI
# 創(chuàng)建服務(wù)對(duì)象
app = FastAPI()
# get --------------------------------
@app.get("/")
async def hello():
return "hello docker-compose"
# ------------------------------------
if __name__ == '__main__':
import uvicorn
uvicorn.run(app="server:app", host="0.0.0.0", port=2333, reload=True)
ps:一個(gè)fastapi服務(wù),訪問(wèn) ip:2333 會(huì)返回 “hello docker-compose”
3.創(chuàng)建 docker 打包文件【Dockerfile】
FROM python:3.7 MAINTAINER ps WORKDIR /mysite ADD . /mysite EXPOSE 2333 RUN python -m pip install -U pip RUN pip config set global.index-url https://mirrors.aliyun.com/pypi/simple/ RUN pip install uvicorn fastapi CMD python server.py
ps:
- FROM :基礎(chǔ)鏡像
- MAINTAINER :指明作者
- WORKDIR /mysite :指明工作目錄為容器中的 /mysite 目錄
- ADD . /mysite :當(dāng)前路徑所有文件復(fù)制到容器的 /mysite 目錄下
- EXPOSE 2333 :指明容器中暴露的端口為 2333【此處可省,后面在docker-compose.yml配置了】
- RUN :run的三行分別是更新pip、換源、安裝 fastapi 依賴(lài)包
- CMD :服務(wù)啟動(dòng)命令
4.創(chuàng)建 compose 部署文件【docker-compose.yml】
version: '3.5'
services:
mysite:
image: mysite_image:0.0.1
container_name: mysite_container
build: ./
restart: always
ports:
- "2333:2333"
ps:
- version: ‘3.5’ :指定當(dāng)前的 compose 版本【compose 版本可以通過(guò) docker-compose –version 命令查看】
- services :指定部署哪些服務(wù)
- mysite :如果不指定下面的 image 參數(shù)的話,打包后的鏡像名會(huì)以 當(dāng)前文件夾名+下劃線+你配置的名稱(chēng) 組合,作為你的鏡像名【比如:此處我如果沒(méi)指定下面的 image 參數(shù)的話,我的鏡像名就是 文件夾名+下劃線+配置名 == mysite_mysite】如果指定了 image 參數(shù)的話,那么這里的名字可以隨便寫(xiě),相當(dāng)于站位符,沒(méi)啥用了
- image: mysite_image:0.0.1 :指定鏡像名為 mysite_image 版本號(hào)為 0.0.1
- container_name: mysite-container :指定啟動(dòng)后的容器名為 mysite-container
- build ./ :在當(dāng)前路徑下找 Dockerfile 文件
- restart: always :開(kāi)機(jī)自啟
- ports :端口映射
5.啟動(dòng)容器
docker-compose up -d
ps:
- -d :后臺(tái)運(yùn)行
- 首次執(zhí)行時(shí)會(huì)先打包鏡像,在從該鏡像啟動(dòng)容器,后續(xù)運(yùn)行則會(huì)直接從已存在的鏡像啟動(dòng)
6.查看容器
1.docker ps 查看,如果找不到的話可能啟動(dòng)失敗了,試試 docker ps -a 查看全部容器【包括啟動(dòng)成功和失敗的所有容器】
三、測(cè)試
訪問(wèn) ip:2333







