第一个Docker容器
1、首先确保Docker运行正常:docker info
.png)
2、启动以第一个Docker容器:docker run -i -t ubuntu /bin/bash
命令说明:
ubuntu:这个是基础镜像名称,可以是mysql、redis等所有的基础镜像,他指以什么镜像创建一个新的容器,此例子使用ubuntu,指在ubuntu镜像的基础上创建一个镜像(在基础镜像上可以加各种其他操作,本例子只是单纯的使用ubuntu镜像创建了一个容器,未做其他附加操作)。
-i :说明这是一个标准输入,可以进行交互, -t :告诉Docker要为新创建的容器创建一个伪tty终端,从而可以进行交互。简单的说,-i -t 两个一起使用,我们才能在终端使用命令操作新创建的容器。(与之相反的是运行在后台不能进行交互的容器,后面会说到)
/bin/bash:执行命令后进入容器的shell界面,即直接可以与新创建的容器进行交互(看下图红色标记,即为新增容器ID,说明已经进入新建容器的shell界面)。
.png)
3、使用第一个容器
查看新容器的相关信息
查看容器主机名:hostname ,实际上与容器ID一致。
.png)
查看host文件:cat /etc/hosts
.png)
查看容器接口:ip a
说明:(1)如果出现bash: ip: command not found错误:执行 apt-get install iproute iproute-doc 命令
(2)如果第(1)步出现Unable to locate package iproute-doc 错误,执行 apt-get install xrdp 命令(这一步非常慢,耐心等待)
(3)如果第(2)步出现Unable to locate package xrdp 错误,执行 apt-get update 命令
(4)如果第(2)步出现Package 'iproute' has no installation candidate 错误,执行 apt-get update 、apt-get upgrade、apt-get install iproute命令
检查容器进程:ps -aux
.png)
在第一个docker容器中安装软件包,这里使用安装vim软件作为示例
apt-get update && apt-get install vim
.png)
退出在容器的操作,返回宿主机:exit (下面示例可以看出原来在ID为78cb60275879的容器内,执行exit命令后,返回了宿主机)
.png)
如果想重新进入终端后,可以使用 docker ps 查看正在运行的docker容器,可以使用docker ps -a 查看所有docker列表(无论是否正在运行)
.png)
重新进入docker 终端,使用 docker attach 78cb60275879 命令,后面的一串字符为上一步的容器ID,也可以使用上一步的容器名称(首先保证docker是运行中的,而不是停止的)。
.png)
4、容器命名
docker run --name UbuntuOfLcl -i -t ubuntu /bin/bash 比原来命令多了 --name参数,可以发现新创建的容器名称即为--name设置的名称
.png)
5、重新启动已停止的容器
docker start UbuntuOfLcl 或 docker start 1c9f7e4c618f 即既可以使用容器名称重启,也可以使用容器ID重启,红色标记处,Up为正在运行,Exit为已停止运行
.png)
6、进入正在运行的docker容器
docker attach UbuntuOfLcl 第五步虽然启动了docker,但是shell仍然在宿主机上,如果想使用shell操作启动后的docker容器,需要该步操作。
.png)
7、创建后台运行容器
前面的例子展示的都是创建一个交互试的容器,一旦退出shell,容器就会停止运行,不适合做服务器;现在创建一个非交互容器。
docker run --name lcl2 -d ubuntu /bin/sh
.png)
也可以在启动时加一些操作,例如让后台输出一些内容,可以使用-c参数:docker run --name lcl4 -d ubuntu /bin/sh -c "while true; do echo hi lcl;sleep 1;done"
.png)
docker logs lcl3 查看后台 docker logs -f lcl3 动态查看后台
.png)
8、日志驱动,可以使用--log-driver
docker run --log-driver="syslog" --name lcl4 -d ubuntu /bin/sh -c "while true; do echo hi lcl;sleep 1;done"
9、查看docker容器内部进程:docker top lcl5
.png)
10、查看docker容器内部统计信息:docker stats lcl5
.png)
11、在容器内运行进程:exec
(1)运行后台进程(无需交互)
docker exec -d UbuntuOfLcl touch /etc/newFile 可以看到下面红色标注的内容,文件已创建
.png)
(2)运行交互试命令:docker exec -t -i UbuntuOfLcl /bin/bash 该命令在UbuntuOfLcl容器内创建了一个新的交互shell
.png)
12、停止守护式容器
docker stop UbuntuOfLcl 和启动一样,可以使用名称停止,也可以使用容器ID停止。
.png)
13、查看最近创建的容器:docker ps -n x x为最近创建的容器的数量
.png)
14、自动重启容器:restart
docker run --restart=always --name lcl6 -d ubuntu /bin/sh -c "while true;do echo hello word;sleep 1;done"
.png)
说明:书中描述,--restart标志可以为always和on-failure,其中设置为always时,无论什么情况停止的容器都会重启,设置为on-failure时,只有当退出标志为非0的时候才会重启。另外on-failure还接受一个可选的参数数值,表示最多可重启的次数,例如on-failure:5,即最多可以重启5次。(特殊说明:改处的always,我在使用stop命令停止容器时,使用docker ps -a命令查看停止的容器并没有重新启动,状态仍未Exited,不清楚改处是操作问题还是其他隐藏的东西,待验证。)
15、深入容器
查看容器:docker inspect lcl5 该命令可以查看非常详细的容器信息,下面截图未全部展示信息。
.png)
有选择的获取容器信息 --formart 或 -f
docker inspect -f='{{ .State.Running }}' lcl5 查看容器运行状态(说明:=号左右一定不要有空格,否则会报错,如下图第三条命令,=号也可以省略)
docker inspect -f='{{.NetworkSettings.IPAddress}}' lcl6 查看容器IP地址(说明:停止运行的容器是没有IP地址的,如下图的lcl5,只有正在运行的容器才有IP地址,如下图的lcl6)
.png)
可以同是查看多个容器的信息
docker inspect -f '{{.Name}} {{.State.Running}} {{.NetworkSettings.IPAddress}}' lcl4 lcl5 lcl6 (同时查看lcl4、lcl5、lcl6三个容器的名称,运行状态和IP地址)
.png)
如果想深入了解docker,在宿主机的/var/lib/docker/containers/目录下,存放着Docker镜像、容器及容器的配置等信息,下面截图中每一个文件夹对应一个docker容器
.png)
16、删除容器
docker rm lcl7 同样可以使用名称删除,也可以使用容器ID删除
.png)
目前docker没有提供删除所有容器的命令,但是可以使用小技巧来删除:docker rm $(docker ps -a -q)
.png)
- Docker 架构及工作原理
通过下图可以得知,Docker 在运行时分为 Docker 引擎(服务端守护进程) 和 客户端工具,我们日常使用各种 docker 命令,其实就是在使用 客户端工具 与 Docker 引擎 进行交互. ...
- 用一个实际例子理解Docker volume工作原理
要了解Docker Volume,首先我们需要理解Docker文件系统的工作原理.Docker镜像是由多个文件系统的只读层叠加而成.当一个容器通过命令docker run启动时,Docker会加载只读 ...
- Docker Macvlan 介绍 or 工作原理
Docker Macvlan Network Macvlan Network:属于Docker的网络驱动. Macvlan Network:Docker主机网卡接口逻辑上分为多个子接口,每个子接口标识 ...
- Docker Weave 介绍 or 工作原理
Docker Weave Network Weave Network:属于第三方网络项目. Weave在Docker主机之间实现Overlay网络,使用业界标准VXLAN封装,基于UDP传输,也可以加 ...
- Docker OpenvSwitch 介绍 or 工作原理
Docker OpenvSwitch Network 介绍 什么是OpenVSwich OpenvSwich Network:属于第三方网络项目,可以理解为是一个标准的交换机协议. OpenvSwic ...
- Docker Swarm 介绍 or 工作原理
Docker Swarm 介绍 Swarm 简介 Swarm是Docker公司自研发的容器集群管理系统,Swarm在早期是作为一个独立服务存在,在Docker Engine v1.12中集成了Swar ...
- GIT的工作原理和基本命令
1.GIT的工作原理 工作区:我们写代码的地方. 暂存区:临时存储用的. 历史区:生成历史版本的地方. 提交流程:工作区->暂存区->历史区 图示: 2.GIT的全局配置 3.创建仓库完成 ...
- 15个Docker基本命令及用法
Docker入门教程:15个Docker基本命令及用法 本文中,我们将学习15个Docker命令以及命令的用法和功能,并通过实践学习它是如何工作的. AD:51CTO 网+ 第十二期沙龙:大话数据 ...
- [Kubernetes] CRI 的设计与工作原理
咱们来看看,有了 CRI 之后, Kubernetes 的架构图: 我们可以看到, CRI 机制能够发挥作用的核心,在于每一个容器项目现在都可以自己实现一个 CRI shim ,自行对 CRI 请求进 ...
随机推荐
- Rocket - tilelink - Fuzzer
https://mp.weixin.qq.com/s/hAKpZHy0IU6_XEvctfkHOA 简单介绍Fuzzer的实现. 1. IDMapGenerator 功能类似于I ...
- AUTOSAR-标准文档索引
https://mp.weixin.qq.com/s/6yl5dBP1mSFGVsfE7YRm6w 索引的两种方法: 关键字检索:用Document Search搜索下载,https://www. ...
- Rocket - util - Broadcaster
https://mp.weixin.qq.com/s/ohBVNAXZUA538qSxfBGMKA 简单介绍Broadcaster的实现. 1. Broadcaster 广播即是 ...
- 【JVM】垃圾回收器总结(2)——七种垃圾回收器类型
七种垃圾回收器类型 GC的约定参数 DefNew——Default New Generation Tenured——Serial Old ParNew——Parallel New Generation ...
- Java实现 LeetCode 637 二叉树的层平均值(遍历树)
637. 二叉树的层平均值 给定一个非空二叉树, 返回一个由每层节点平均值组成的数组. 示例 1: 输入: 3 / \ 9 20 / \ 15 7 输出: [3, 14.5, 11] 解释: 第0层的 ...
- Java实现 LeetCode 385 迷你语法分析器
385. 迷你语法分析器 给定一个用字符串表示的整数的嵌套列表,实现一个解析它的语法分析器. 列表中的每个元素只可能是整数或整数嵌套列表 提示:你可以假定这些字符串都是格式良好的: 字符串非空 字符串 ...
- Java实现 蓝桥杯VIP 算法提高 选择排序
算法提高 选择排序 时间限制:1.0s 内存限制:256.0MB 选择排序 问题描述 排序,顾名思义,是将若干个元素按其大小关系排出一个顺序.形式化描述如下:有n个元素a[1],a[2],-,a[ ...
- Java实现LeetCode_0012_IntegerToRoman
package javaLeetCode.primary; import java.util.Scanner; public class IntegerToRoman_12 { public stat ...
- java实现平面点最小距离
已知平面上若干个点的坐标. 需要求出在所有的组合中,4个点间平均距离的最小值(四舍五入,保留2位小数). 比如有4个点:a,b,c,d, 则平均距离是指:ab, ac, ad, bc, bd, cd ...
- TZOJ 数据结构实验--静态顺序栈
描述 创建一个顺序栈(静态),栈大小为5.能够完成栈的初始化.入栈.出栈.获取栈顶元素.销毁栈等操作. 顺序栈类型定义如下: typedef struct { int data[Max]; i ...