咱们以前讲过部署一个简单的Python程序。python
这一节咱们将这个Python程序进行一个扩展,链接redis数据库,并对redis进行一些操做,redis
新建App.py,内容以下:docker
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:flask
docker build -t vincent/flask-redis .
咱们既然要使用redis,可是咱们并无在Dockerfile中安装redis,只是在引入了一个Python redis依赖库,如何使用redis服务?安全
当咱们build一个复杂的App的时候,咱们须要把App的组件分红不一样的容器去部署。咱们把redis做为一个单独的App进行部署,flask做为一个单独的App进行部署,flask要去访问redis。咱们先建立一个redis的一个容器。bash
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'))。app
咱们可使用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
能够在容器内发送请求:
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服务,并指定端口:
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.
本节的架构图以下所示:
目前咱们的两个container是在同一台机器上的,经过docker0能够相互通讯。那么若是有两台Linux服务器,分别部署一个docker,那么如何通讯呢?
咱们将在后面介绍