从零开始学习docker(六)部署一个稍微复杂一点的应用
?
?我們之前講過部署一個簡單的Python程序。?
這一節(jié)我們將這個Python程序進行一個擴展,連接redis數(shù)據(jù)庫,并對redis進行一些操作,
新建App.py,內(nèi)容如下:
from flask import Flask from redis import Redis import os import socketapp = Flask(__name__) redis = Redis(host=os.environ.get('REDIS_HOST', '127.0.0.1'), port=6379)@app.route('/') def hello():redis.incr('hits')return 'Hello Container World! I have bean seen %s times and my hostname is %s. \n' % (redis.get('hits'), socket.gethostname())if __name__ == "__main__":app.run(host="0.0.0.0", port=5000, debug=True)新建Dockerfile,內(nèi)容如下:?
FROM python:2.7 LABEL maintainer="vincent" COPY . /app WORKDIR /app RUN pip install flask redis EXPOSE 5000 CMD [ "python", "app.py" ]創(chuàng)建image:
docker build -t vincent/flask-redis .我們既然要使用redis,但是我們并沒有在Dockerfile中安裝redis,只是在引入了一個Python redis依賴庫,如何使用redis服務(wù)?
當我們build一個復(fù)雜的App的時候,我們需要把App的組件分成不同的容器去部署。我們把redis作為一個單獨的App進行部署,flask作為一個單獨的App進行部署,flask要去訪問redis。我們先創(chuàng)建一個redis的一個容器。
docker run -d --name redis redis docker container ls CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 1fb5745864cd redis "docker-entrypoint.s…" 23 seconds ago Up 22 seconds 6379/tcp redis但是我們現(xiàn)在的redis的端口是6379。但是我們在創(chuàng)建容器的時候,并沒有指定-p 6379:6379 參數(shù)。
問什么呢?因為我們這里的redis不是提供給外面的人訪問的,他是供我們App內(nèi)部訪問的,因此我們沒必要把6379暴露到外面去(這樣不安全)。
此外我們的App.py并不知道redis的IP地址,因此把地址用環(huán)境變量的方式獲取(os.environ.get('REDIS_HOST', '127.0.0.1'))。
我們可以使用link參數(shù),通過訪問redis的容器名字來訪問。
創(chuàng)建flask-redis的container:
docker run -d --link redis --name flask-redis -e REDIS_HOST=redis vincent/flask-redis-e REDIS_HOST 表示在當前容器vincent/flask-redis中設(shè)置一個環(huán)境變量REDIS_HOST=redis
我們進入到容器中查看env:
docker exec -it flask-redis /bin/bash root@45977ae3cbed:/app# env REDIS_PORT_6379_TCP_PROTO=tcp REDIS_PORT=tcp://172.17.0.2:6379 REDIS_NAME=/flask-redis/redis LANG=C.UTF-8 HOSTNAME=45977ae3cbed REDIS_PORT_6379_TCP_ADDR=172.17.0.2 REDIS_PORT_6379_TCP=tcp://172.17.0.2:6379 GPG_KEY=C01E1CAD5EA2C4F0B8E3571504C367C218ADD4FF PYTHONIOENCODING=UTF-8 REDIS_ENV_REDIS_DOWNLOAD_URL=http://download.redis.io/releases/redis-5.0.5.tar.gz REDIS_HOST=redis PWD=/app HOME=/root REDIS_PORT_6379_TCP_PORT=6379 TERM=xterm REDIS_ENV_REDIS_DOWNLOAD_SHA=2139009799d21d8ff94fc40b7f36ac46699b9e1254086299f8d3b223ca54a375 REDIS_ENV_GOSU_VERSION=1.10 PYTHON_VERSION=2.7.16 SHLVL=1 PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin REDIS_ENV_REDIS_VERSION=5.0.5 PYTHON_PIP_VERSION=19.1.1 _=/usr/bin/env可以看到里面有一個環(huán)境變量REDIS_HOST=redis
通過name來ping通:
root@45977ae3cbed:/app# ping redis PING redis (172.17.0.2) 56(84) bytes of data. 64 bytes from redis (172.17.0.2): icmp_seq=1 ttl=64 time=1.16 ms 64 bytes from redis (172.17.0.2): icmp_seq=2 ttl=64 time=0.105 ms 64 bytes from redis (172.17.0.2): icmp_seq=3 ttl=64 time=0.215 ms可以在容器內(nèi)發(fā)送請求:
root@e9361b832e36:/app# curl 127.0.0.1:5000 Hello Container World! I have bean seen 3 times and my hostname is e9361b832e36. root@e9361b832e36:/app# curl 127.0.0.1:5000 Hello Container World! I have bean seen 4 times and my hostname is e9361b832e36. root@e9361b832e36:/app# curl 127.0.0.1:5000 Hello Container World! I have bean seen 5 times and my hostname is e9361b832e36.但是這時候在宿主機中還是無法訪問。
我們重新啟動flask-redis服務(wù),并指定端口:
docker run -d -p 5000:5000 --link redis --name flask-redis -e REDIS_HOST=redis vincent/flask-redis docker container ls CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 835a7fb5a689 vincent/flask-redis "python app.py" 2 minutes ago Up 4 seconds 0.0.0.0:5000->5000/tcp flask-redis 1fb5745864cd redis "docker-entrypoint.s…" 15 hours ago Up 40 seconds 6379/tcp redis在宿主機中訪問:
curl 127.0.0.1:5000 Hello Container World! I have bean seen 8 times and my hostname is 835a7fb5a689.本節(jié)的架構(gòu)圖如下所示:
目前我們的兩個container是在同一臺機器上的,通過docker0可以相互通信。那么如果有兩臺Linux服務(wù)器,分別部署一個docker,那么如何通信呢?
我們將在后面介紹
總結(jié)
以上是生活随笔為你收集整理的从零开始学习docker(六)部署一个稍微复杂一点的应用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Dockerfile----ubuntu
- 下一篇: 从零开始学习docker(七)docke