通过Docker可以实现应用的快速部署,从此告别手动搭建各种环境的烦恼。利用Docker你甚至可以在你的虚拟机软件中实施套娃操作:在ubuntu虚拟机里安装一个Docker,Docker里安装一个ubuntu。^ _ ^
Docker基本概念
概念 | 说明 |
---|---|
Docker 镜像(Images) | Docker 镜像是用于创建 Docker 容器的模板,比如 Ubuntu 系统 |
Docker 容器(Container) | 容器是独立运行的一个或一组应用,是镜像运行时的实体 |
Docker 客户端(Client) | Docker 客户端通过命令行或者其他工具使用 Docker SDK (https://docs.docker.com/develop/sdk/) 与 Docker 的守护进程通信 |
Docker 主机(Host) | 一个物理或者虚拟的机器用于执行 Docker 守护进程和容器 |
Docker Registry | Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。 Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。 一个 Docker Registry 中可以包含多个仓库(Repository);每个仓库可以包含多个标签(Tag);每个标签对应一个镜像。 通常,一个仓库会包含同一个软件不同版本的镜像,而标签就常用于对应该软件的各个版本。我们可以通过 <仓库名>:<标签> 的格式来指定具体是这个软件哪个版本的镜像。如果不给出标签,将以 latest 作为默认标签。 |
Docker安装
以ubuntu为例,Docker社区版支持ubuntu16.0.4及以上的版本。面对一个全新的ubuntu系统,Docker安装步骤如下:
如果是在国内无法翻墙或者嫌官方源下载慢可以更换国内的源
- 卸载旧版本docker
$ sudo apt-get remove docker docker-engine docker.io containerd runc
- 更新仓库
$ sudo apt-get update
- 安装 apt 依赖包,用于通过HTTPS来获取仓库
$ sudo apt-get install \
apt-transport-https \
ca-certificates \
curl \
gnupg-agent \
software-properties-common
- 添加GPA
# 下载不下来的话可以先手动访问链接拿到gpg文件,再执行`sudo apt-key add -`
$ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
- 设置Docker稳定版仓库
$ sudo add-apt-repository \
"deb [arch=amd64] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) \
stable"
- 添加仓库后更新源
$ sudo apt-get update
- 安装最新版Docker CE(社区版)
$ sudo apt-get install docker-ce
- 使用
hello-world
镜像验证是否安装Docker成功
$ sudo docker run hello-world
常用命令
Docker服务
- 启动Docker服务
$ sudo service docker start
- 停止Docker服务
$ sudo service docker stop
- 重启docker
$ sudo service docker restart
- 搜索镜像
$ docker search image_name
- 下载镜像
// version缺省值为latest
$ docker pull image_name:version
- 查看本地镜像
$ docker images
- 删除镜像
$ docker image rm image_name
容器-实例
- 创建一个实例
# e.g
# docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7`
# docker run -itd --name redis -p 6379:6379 redis:latest --requirepass 123456
$ docker run [option] image_name [command]
常用参数说明
- -i 表示以“交互模式”运行容器
- -t 表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即 分配一个伪终端。
- --name 为创建的容器命名
- -v 表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录,即 宿主机目录:容器中目录),可以使 用多个-v 做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后 共享到容器上。
- -d 在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不 会自动登录容器,如果只加-i -t 两个参数,创建后就会自动进去容器)。
- -p 表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p 做多个端口映射
- -e 为容器设置环境变量
- --network=host 表示将主机的网络环境映射到容器中,容器的网络与主机相同
- 交互式容器
创建一个交互式容器,并命名为myubuntu。在容器中可以随意执行linux命令,就是一个ubuntu的环境,当执行exit命令退出时,该容器也随之停止。
$ docker run -it --name=ubuntu --network=host hackeryx/ubuntu:16.04 /bin/bash
- 守护式容器
创建一个守护式容器:如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。在容器内部exit退出时,容器也不会停止。
$ docker run -itd --name=ubuntu2 --network=host hackeryx/ubuntu:16.04
- 进入已运行的容器
$ docker exec -it name/id command
# e.g
# docker exec -it ubuntu /bin/bash</pre>
- 列出本机所有容器,包括已经终止运行的
$ docker ps -a
- 停止与启动容器
# 停止一个已经在运行的容器
$ docker stop name/id
# 启动一个已经停止的容器
$ docker start 容器名或容器id
# kill掉一个已经在运行的容器
$ docker kill 容器名或容器id</pre>
-
删除容器
docker rm name/id
将容器保存为镜像&镜像迁移
- 将容器保存为镜像
$ docker commit container_name target_image_name
- 通过Dockerfile构建镜像
$ docker build -t appname:v1.0 .
- 将镜像打包成文件,拷贝给别人使用
$ docker save -o target_image_file_name source_image_name
- 拿到镜像文件后,可以通过load方法,将镜像加载到本地
$ docker load -i target_image_file_name