docker基础二

本节介绍容器的相关知识

曾几何时,当我们需要创建一个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 = "cannot connect to Redis, counter disabled"

    html = "

Hello {name}!

" \ "Hostname: {hostname}
" \ "Visits: {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
访问localhost:4000

Hit Ctrl+c 可停止应用的运行(window中需要查看容器名称然后运行docker container stop 来停止容器的运行。

以下命令可以后台运行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  #停止某个容器的现有工作并关闭容器
docker container kill  # 直接关闭某个容器
docker container rm  #从当前主机删除容器
docker container rm $(docker container ls -a -q) #删除当前主机的所有容器
docker image ls -a #列表展示所有可执行image
docker image rm  #删除某个image
docker image rm $(docker image ls -a) #删除所有image
docker login #登陆docker账户
docker tag  username/repository:tag #为某个image添加标签和设定仓库路径
docker push username/repository:tag #上传image
docker run username/repository:tag #从仓库拉取并运行容器image

你可能感兴趣的:(docker基础二)