Docker简介
基于Go语言开发。
Docker的应用场景
Web 应用的自动化打包和发布。
自动化测试和持续集成、发布。
在服务型环境中部署和调整数据库或其他的后台应用。
从头编译或者扩展现有的OpenShift或Cloud Foundry平台来搭建自己的PaaS环境。
Docker 的优点
-
简化程序:
Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化。Docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入Docker中进行管理。方便快捷已经是 Docker的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成。 -
避免选择恐惧症:
如果你有选择恐惧症,还是资深患者。Docker 帮你 打包你的纠结!比如 Docker 镜像;Docker 镜像中包含了运行环境和配置,所以 Docker 可以简化部署多种应用实例工作。比如 Web 应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个镜像部署。 -
节省开支:
一方面,云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,Docker 改变了高性能必然高价格的思维定势。Docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式。
Docker中的关系
Docker | 面向对象 |
---|---|
容器 | 对象 |
镜像 | 类 |
Docker中的术语 | 解释 |
---|---|
Docker 镜像(Images) | Docker 镜像是用于创建 Docker 容器的模板。 |
Docker 容器(Container) | 容器是独立运行的一个或一组应用。 |
Docker 客户端(Client) | Docker 客户端通过命令行或者其他工具使用 Docker API 与 Docker 的守护进程通信。 |
Docker 主机(Host) | 一个物理或者虚拟的机器用于执行 Docker 守护进程和容器。 |
Docker 仓库(Registry) | Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。 |
Docker Machine | Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure。 |
Docker命令
- Docker 以 ubuntu15.10 镜像创建一个新容器,然后在容器里执行 bin/echo “Hello world”,然后输出结果。
docker run ubuntu:15.10 /bin/echo "Hello world"
- docker: Docker 的二进制执行文件。
- run:与前面的 docker 组合来运行一个容器。
- ubuntu:15.10指定要运行的镜像,Docker首先从本地主机上查找镜像是否存在,如果不存在,Docker 就会从镜像仓库 Docker Hub 下载公共镜像。
- /bin/echo “Hello world”: 在启动的容器里执行的命令
docker run -i -t --rm ubuntu:15.10 /bin/bash
- -t:在新容器内指定一个伪终端或终端。
- -i:允许你对容器内的标准输入 (STDIN) 进行交互。
- –rm :容器运行完后,会直接把刚运行过的这个容器删除,在ps -a 中查不到
- 查看当前正在运行的容器
docker ps
- -a :指查看所有运行过的容器,包含正在运行的
- -l : 指查看最后一次创建的容器
- 停止容器
docker stop <container id or name >
- start :启动容器
- restart:重启容器
- rm :删除容器,(该容器必须是停止运行状态)
- 在docker容器中运行一个 Python Flask 应用来运行一个web应用
docker run -d -P training/webapp python app.py
- -d:让容器在后台运行。
- -P:将容器内部使用的网络端口映射到我们使用的主机上。
- -p : 是容器内部端口绑定到指定的主机端口。
- 查看某个确定端口映射到宿主机的端口号
docker port <container id or name >
- 查看容器的日志
docker logs -f <container id or name >
- -f: 让 docker logs 像使用 tail -f 一样来输出容器内部的标准输出。
- 列出本地的所有镜像
docker images
- REPOSITORY:表示镜像的仓库源
- TAG:镜像的标签
- IMAGE ID:镜像ID
- CREATED:镜像创建时间
- SIZE:镜像大小
- 查找镜像
docker search httpd
- 根据容器创建新的镜像
docker commit -m="my ubuntu" -a="my name" 3f060f56b7b2 myName/ubuntu:v2
- 运行MySQL
docker run --name mysqldb -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
- run 运行一个容器
- –name 后面是这个镜像的名称
- -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口。
- -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
- -d 表示使用守护进程运行,即服务挂在后台
docker exec -it xiongmysql bash
select SUBSTRING_INDEX(host,':',1) as ip , count(*) from information_schema.processlist group by ip;
- 启动一个运行过的容器
docker start CONTAINER ID
- 进入正在运行的容器(两种方式)
docker attach CONTAINER_ID
docker exec -ti CONTAINER_ID /bin/bash
- docker cp 命令用于容器与主机之间的数据拷贝
主机到容器:
docker cp /www CONTAINER_ID:/www/
容器到主机:
docker cp CONTAINER_ID:/www /tmp/
- 查看镜像支持的环境变量
docker run IMAGE env
- 临时退出一个正在交互的容器的终端,而不终止它
按Ctrl+p,后按Ctrl+q,如果按Ctrl+c会使容器内的应用进程终止,进而会使容器终止。