從零開始學習docker(六)部署一個稍微負載一點的應用
阿新 • • 發佈:2019-06-30
我們之前講過部署一個簡單的Python程式。
這一節我們將這個Python程式進行一個擴充套件,連線redis資料庫,並對redis進行一些操作,
新建App.py,內容如下:
from flask import Flask from redis import Redis import os import socket app = 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,內容如下:
FROM python:2.7
LABEL maintainer="vincent"
COPY . /app
WORKDIR /app
RUN pip install flask redis
EXPOSE 5000
CMD [ "python", "app.py" ]
建立image:
docker build -t vincent/flask-redis .
我們既然要使用redis,但是我們並沒有在Dockerfile中安裝redis,只是在引入了一個Python redis依賴庫,如何使用redis服務?
當我們build一個複雜的App的時候,我們需要把App的元件分成不同的容器去部署。我們把redis作為一個單獨的App進行部署,flask作為一個單獨的App進行部署,flask要去訪問redis。 我們先建立一個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
但是我們現在的redis的埠是6379。但是我們在建立容器的時候,並沒有指定-p 6379:6379 引數。
問什麼呢?因為我們這裡的redis不是提供給外面的人訪問的,他是供我們App內部訪問的,因此我們沒必要把6379暴露到外面去(這樣不安全)。
此外我們的App.py並不知道redis的IP地址,因此把地址用環境變數的方式獲取(os.environ.get('REDIS_HOST', '127.0.0.1'))。
我們可以使用link引數,通過訪問redis的容器名字來訪問。
建立flask-redis的container:
docker run -d --link redis --name flask-redis -e REDIS_HOST=redis vincent/flask-redis
-e REDIS_HOST 表示在當前容器vincent/flask-redis中設定一個環境變數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
可以看到裡面有一個環境變數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