學習Docker之使用docker-compose編配一整套服務
使用docker compose可以一鍵完成“一整套”服務的搭建也可以完成服務叢集化部署。
這兩天在用python寫一個爬蟲,資料暫時儲存在本地的mongodb資料庫,到部署的時候,發現線上的伺服器沒有python環境和mongodb,這個時候立馬就想到了Docker!
最初的思路就是run一個mongodb容器,然後再把爬蟲程式構建為映象並run起來。準備動手的時候突然腦海裡閃過compose這個東東,之前看docker書的時候正好看到有關compose的這一章,我花了十分鐘簡單的過了一下,發現使用compose可以更加完美的實現一鍵構建、部署與啟動的過程,接下來就以python與mongodb組合為例
先看一下python程式
from flask import Flask
from pymongo import MongoClient
import random
app = Flask(__name__)
client = MongoClient('mongodb')
db=client['datas']
@app.route('/')
def hello():
db.col.insert({"hits":random.random()})
return 'Hello World! I have been seen %s times.' % (db.col.count())
if __name__ == "__main__":
app.run(host="0.0.0.0", debug=True)
使用flask做python的web服務框架,每請求一次就會在mongodb的datas資料庫插入一個文件,然後返回datas下面的總數,非常簡單。
然後需要把python所依賴的模組抽取出來,這裡推薦使用pipreqs
安裝pipreqs
pip install pipreqs
然後執行指令碼
# 我直接在專案的根目錄下執行,當然也可以帶上路徑 如 pipreqs /project/path
pipreqs .
生成的requirements如下
pymongo==3.6 .1
Flask==0.12.2
接下來需要編寫Dockerfile
FROM python:2.7
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python","app.py"]
這裡用的是python 2.7版本
然後定位到code目錄下;
將requirements.txt下依賴的模組一併安裝;
最後執行app.py
緊接著開始docker-compose yml 命令與寫法跟Dockerfile類似,很容易理解,如下:
version: '2'
services:
web:
build: .
ports:
- "5000:5000"
mongodb:
image: mongo
ports:
- "27017:27017"
這裡要注意一下mongodb,就是python中使用的‘域名’
可以這樣理解,web服務和mongodb服務都在同一個區域網,然後mongodb服務的ip對應域名就是“mongodb”
docker-compose 一般需要獨自安裝,我這裡使用的是ubuntu,直接使用apt install docker-compose
,當然也可以按照官網安裝
最終目錄為
.
├── app.py
├── docker-compose.yml
├── Dockerfile
└── requirements.txt
執行命令docker-compose up
到這裡使用docker-compose編配一個web服務和一個數據服務就到此結束了!
使用compose我們可以把一整套的專案包括應用、資料儲存、訊息中介軟體等等的安裝、部署與啟動整合在一個yml配置中,真的可以達到一鍵啟動應用!!!