一个image是一个可被docker执行的包,它包括程序运行的全部东西,包括代码,运行时,库,环境变量和配置文件。html
一个container是image在内存中的运行实例,一个image能够产生多个container实例。python
# docker --version Docker version 18.09.2, build 6247962
使用docker version
(不带--
)会获得更详细的版本信息.redis
docker info
docker
docker run hello-world
测试运行hello-world image.flask
docker image ls
或docker images
列出全部已下载的image.bash
docker container ls --all
列出全部container.网络
app.dockerfile
app
# use an official python runtime as a parent image FROM python:2.7-slim # set the working directory to /app WORKDIR /app # copy the current directory contents into the container at /app COPY . /app # install any needed packages specified in requirements.txt RUN pip install --trusted-host pypi.python.org -r requirements.txt # make port 8001 available to the world outside this container EXPOSE 8001 # define enviornment veriable ENV NAME World # run app.py when the container launches CMD ["python", "app.py"]
docker build -f ./app.dockerfile --tag=friendlyhello .
socket
-f
参数指定dockerfile的位置,--tag
参数指定输出的docker image名称.
构建的image文件可能依赖于别的父image.tcp
容器内的工做目录是/app
,这个文件还把当前构建目录的全部文件COPY到了容器内的/app
文件夹下。这里还差两个文件app.py
和requirements.txt
。等下建立它们,它们也应该跟dockerfile在一块儿以便于等会COPY进容器。
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)
requirements.txt
Flask Redis
docker run -p 8001:8001 friendlyhello
若是端口被占用,使用命令lsof -i tcp:8001
查看本机8001端口被哪一个应用占用.
docker run -d -p 8001:8001 friendlyhello
-d
指定容器以deamon方式运行,上述命令会返回一长串容器ID.
这里将外部的8001端口映射到container中的8001端口,访问http://localhost:8001/
就能获得返回内容。若是启动命令的端口部分改成-p 8080:8001
,那就须要访问http://localhost:8080/
。container内中的服务,只监听8001,只能经过修改代码监听的端口和dockerfile暴露出的端口。
对运行的docker,使用docker提供的exec命令docker exec <container ID> <Command>
在容器内执行ls命令,就能够查看到container内的内容,当前这个image运行后的container中有app.dockerfile
,app.py
和requirements.txt
三个文件。
在前台运行时,使用Ctrl + C
便可结束进程.
也能够使用container的stop命令docker container stop <Container NAME or ID>
.查看当前运行container的命令是docker container ls
,要查看全部状态的container,加-a
参数.
推荐添加tag的格式是docker tag image username/repository:tag
.
docker tag friendlyhello cchenyang/get-started:part2
cchenyang是docker hub的username
,以后的get-started:part2
就是把image friendlyhello
更名为get-started
并将默认标记latest
改成part2
.这个标记习惯用法是设置为repository
的版本号.
docker login
登陆docker hub,将添加tag后的image push到docker hub中docker push cchenyang/get-started:part2
。
以后,就能够在任何有网络并安装docker的机器中使用docker run -p 8001:8001 cchenyang/get-started:part2
得到这个image并运行~!!
docker入门2-docker service
docker入门3-docker swarm
docker入门4-docker stack