本节介绍容器的相关知识
曾几何时,当我们需要创建一个python应用的时候,我们要首先搭建一套合适的运行环境,以保证python应用能够正常运行。
如今,我们有了docker,这使得上面的事情变得不可思议地简单,我们只需将程序运行的所需依赖制作成一个image而不需要安装。然后你可以将你的python程序和这个image一起进行构建,这会保证你的应用以及其依赖和运行环境能够一次性得到满足,这些轻便的images即我们称之为Dockerfile的东西。
Define a container with Dockerfile
Dockerfile
定义了在容器内环境中会发生什么。由于容器环境与你的系统是隔离开来的,你必须要定义一个端口映射用于容器与外部系统进行资源交换,并明确哪些文件是你想要复制进容器环境中的。这样之后,即可以保证无论你的容器在哪里运行,都会有着相同的表现。
创建dockerfile
vim Dockerfile
#以下内容为dockerfile内容
#使用pyhon官方提供的运行环境作为基础
FROM python:2.7-slim
#设置工作目录
WORKDIR /app
#复制当前目录下的内容到容器中的app目录下
ADD . /app
#安装所需依赖
RUN pip install --trusted-host pypi.python.org -r requirements.txt
#定义80端口来使得容器与外部环境相连
EXPOSE 80
#定义环境变量
ENV NAME World
#当容器启动时运行 app.py
CMD ["python", "app.py"]
创建依赖描述文件
vim requirements.txt
#以下为文件内容
Flask
Redis
创建程序主文件
vim app.py
#以下为文件内容
from flask import Flask
from redis import Redis, RedisError
import os
import socket
# Connect to Redis
redis = Redis(host="redis", db=0, socket_connect_timeout=2, socket_timeout=2)
app = Flask(__name__)
@app.route("/")
def hello():
try:
visits = redis.incr("counter")
except RedisError:
visits = "<i>cannot connect to Redis, counter disabled</i>"
html = "<h3>Hello {name}!</h3>" \
"<b>Hostname:</b> {hostname}<br/>" \
"<b>Visits:</b> {visits}"
return html.format(name=os.getenv("NAME", "world"), hostname=socket.gethostname(), visits=visits)
if __name__ == "__main__":
app.run(host='0.0.0.0', port=80)
我们查看一下现在目录下的文件
ls
Dockerfile app.py requirements.txt
现在执行build命令,这会创建一个docker image,我们可以添加-t参数使其名字可读性更高
docker build -t friendlyhello .
你可能会问了,我们创建的image到哪里去了呢?答案是,在我们本机上的docker仓库中。我们可以执行以下命令来查看
docker image ls
REPOSITORY TAG IMAGE ID
friendlyhello latest 326387cea398
可能会遇到的问题:
linux用户在使用代理服务器时可能会遇到以下问题:
- 代理服务器在启动后会阻塞其与web服务的连接,如果你在代理服务器上运行docker,请添加以下内容到Dockerfile中
#设置代理服务器,将 host:post 修改为你的主机地址:端口
ENV http_proxy host:port
ENV https_proxy host:port
- pip工具可能会受到dns配置的影响
vim /etc/docker/daemon.json
#将文件中的dns配置改为如下所示
{
"dns":["你的dns地址","8.8.8.8"]
}
service docker restart
docker build -t friendlyhello
运行程序
将本机的4000端口与容器的80端口进行映射
docker run -p 4000:80 friendlyhello
Hit Ctrl+c 可停止应用的运行(window中需要查看容器名称然后运行docker container stop <name or id>
来停止容器的运行。
以下命令可以后台运行app
docker run -d -p 4000:80 friendlyhello
共享你的image
为了方便管理,我们应该为image添加标签以增强版本辨识性
docker tag friendlyhello MarvelGun/get-started:part2
运行docker image ls
来查看带有标签的image
上传到云端
docker push marvelgun/getstarted:part2
现在你可以在任何安装了docker服务的机器上运行你刚刚上传的容器了
docker run -p 4000:80 marvelgun/get-started:part2
小节
docker build -t friendlyhello . #使用当前目录下的Dockerfile文件创建image
docker run -p 4000:80 friendlyhello #运行image实现容器,并将容器的80与外部系统的4000端口作映射
docker run -d -p 4000:80 friendlyhello #后台运行
docker container ls #列表查看所有运行中容器
docker container ls -a #列表查看所有容器
docker container stop <hash> #停止某个容器的现有工作并关闭容器
docker container kill <hash> # 直接关闭某个容器
docker container rm <hash> #从当前主机删除容器
docker container rm $(docker container ls -a -q) #删除当前主机的所有容器
docker image ls -a #列表展示所有可执行image
docker image rm <image id> #删除某个image
docker image rm $(docker image ls -a) #删除所有image
docker login #登陆docker账户
docker tag <image> username/repository:tag #为某个image添加标签和设定仓库路径
docker push username/repository:tag #上传image
docker run username/repository:tag #从仓库拉取并运行容器image