Docker使用 - 容器
查看容器
命令:docker ps [options]
options有:
-a:查看所有容器,包含不在运行中的(不带-a参数,是只显示运行中的容器)
-q:只显示容器ID
-s:多加一列来显示总文件大小
-l:显示最近创建的容器(docker ps -l)
-n:显示最近创建的n个容器(docker ps -n 3, 显示最近创建的3个容器)
--filter:根据条件过滤(不常用,容器数量没大到那种程度需要用过滤器才能找到。)
启动容器
方式一:从一个镜像中创建一个容器的同时并启动
docker run [options] 镜像名或镜像ID [command] [agrs]
options常有:
- -d:让docker在后台运行而不是直接把执行命令的结果输出在当前宿主机器下。
- -t:让docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上(配合-i使用)
- -i:让容器的标准输入保持打开(配合-t使用)
- --name:为容器命名
- --restart:是否跟随宿主机开机启动(默认为“no”,可以有“always”)
- --privilleged:是否让容器拥有root权限(可接 false 或者 true)
- -v:创建数据卷( -v 本机目录1:容器目录1 -v 本机容器2:容器目录2)
- -p:绑定端口,将本机端口映射到容器端口,-p 本机端口:容器端口,因为容器内监听的端口,本机并不知道,所以从外界来访问本机的那个端口是访问不到的,所以要做映射
数据卷
数据卷是一种技术,而不是某一个东西。
简单理解就是,将本机的某一个目录映射到某一个或者多个容器的某目录。这样在本机修改代码,就可以直接用容器跑代码
什么是数据卷
数据卷 是一个可供一个或者多个容器使用的特殊目录,它绕过UFS,可以提供很多有用的特性:
- 数据卷 可以在容器直接共享和重用
- 对 数据卷 的修改会立马生效
- 对 数据卷 的更新,不会影响镜像
- 数据卷 会默认一直存在,即使容器被删除
注意:数据卷 的使用,类似linux下对目录或者文件进行mount,镜像中的被指定为挂载点的目录中的文件会隐藏掉,能显示看的是挂着的 数据卷。
数据卷的用法
在用镜像来创建一个容器的同时,指定“-v”参数来指定目录映射
准备:授权本地磁盘
命令:docker run -v 本地目录:容器目录 镜像名称或镜像ID
如果要同时挂载多个目录,可以执行多个 -v 即可,如:
docker run -v 本地目录1:容器目录1 -v 本地目录2:容器目录2 镜像名称或镜像ID

方式二:启动一个已经存在的容器
命令:docker start 容器ID或容器名
更新容器
一个容器已经通过镜像创建成功了,但是当初创建的时候,由于考虑不周,忘了一些参数(比如开机启动),这时候可以通过 update 命令来更新容器。
命令:docker update [options] 容器名或容器ID
options有:
--blkio-weight(uint16): Block IO (relative weight), between 10 and 1000, or 0 to disable (default 0)
--cpu-period(int): Limit CPU CFS (Completely Fair Scheduler) period
--cpu-quota(int): Limit CPU CFS (Completely Fair Scheduler) quota
--cpu-rt-period(int): Limit the CPU real-time period in microseconds
--cpu-rt-runtime(int): Limit the CPU real-time runtime in microseconds
--cpu-shares(int): CPU shares (relative weight)
--cpus(decimal): Number of CPUs
--cpuset-cpus(string): CPUs in which to allow execution (0-3, 0,1)
--cpuset-mems(string): MEMs in which to allow execution (0-3, 0,1)
--kernel-memory(bytes): Kernel memory limit
--memory bytes Memory limit
--memory-reservation(bytes): Memory soft limit
--memory-swap(bytes): Swap limit equal to memory plus swap: '-1' to enable unlimited swap
--restart(string): Restart policy to apply when a container exits
停止容器
命令:docker stop [options] 容器名或者容器ID
options有:
-t:杀死容器进程前,给予容器用来停止的时间(默认是10秒)
重启容器
命令:docker restart [options] 容器名或容器ID
options有:
-t:杀死容器进程前,给予容器用来停止的时间(默认是10秒)
即使容器是关闭状态,也可以重启,这点不像supervisor,supervisor的进程是关闭状态的话,则无法restart,只能start
删除容器
命令:docker rm [options] 容器名或容器ID
options有:
-f:强制删除容器(默认情况下,只有是停止状态的容器才可以删除,但是带上-f后,可以直接删除在运行中的容器)
-l:移除容器间的网络链接,而非容器本身(不懂,好像也用的少)
-v:删除与容器关联的卷(这个还是可以有的)
批量删除容器
命令:docker rm -f $(docker ps -a -q)
不是什么新的知识点
在容器外执行容器里的命令
命令:docker exec [options] 容器名或容器ID [command]
一般是:docker exec -it 容器名或容器ID /bin/bash ,用于进入容器,是否真的能在外面做到其他的操作,暂未可知,我是验证了:docker exec 容器名 echo "hello world">test.txt ,未成功
查看容器日志信息
命令:docker logs 容器名或容器ID
主机和容器之间的内容拷贝(不建议,容器只做运算,最好不要往里面拷文件,可以做成数据卷映射)
主机拷贝到容器
命令:docker cp 主机文件 容器ID或容器名:容器目录
有点类似本机与远程服务器之间的内容拷贝:scp 本机文件 远程服务器:目录
容器拷贝到主机
命令:docker cp 容器ID或容器名:目录/文件 本机目录
Docker使用 - 容器的更多相关文章
- Docker的容器
容器是一个打包了应用和服务的环境,是一个轻量级的虚拟机,每一个容器都由一组特定的应用和必要的依赖库组成. 容器的管理操作 容器常见的命令:查看.创建.启动.终止和删除 创建容器 docker crea ...
- 【转】深入 Docker:容器和镜像
在本专栏往期的 Flux7 系列教程 里,我们已经简单地探讨了 Docker 的基本操作.而在那篇教程中,我们一直是简单地将容器当成是"正在运行的镜像",并没有深入地区分镜像和容器 ...
- 理解Docker单机容器网络
在” 理解Docker单机容器网络 “一文中,还有一个Docker容器网络的功能尚未提及,那就是Docker容器的端口映射.即将容器的服务端口P’ 绑定到宿主机的端口P上,最终达到一种效果:外部程序通 ...
- docker进入容器的方式
通过docker创建守护运行(在使用-d参数时)的容器时,容器启动后会进入后台.用户无法看到容器中的信息.某些时候如果需要进入容器进行操作,有多种方法,包括使用docker attach命令.dock ...
- Docker与容器快速入门
Docker之风席卷全球,但很多人觉得docker入门确实不太容易,其原因在于很多知识点上没准备好,在docker解决了什么问题.怎么解决的.用什么技术解决的都还没想清楚的时候就去探索docker组件 ...
- Docker系列之(三):Docker微容器Alpine Linux
1. 前言 使用Docker创建容器时,基础镜像通常选择Ubuntu或Centos,不管哪个镜像的大小都在100MB以上. Alpine Linux是一个面向安全的轻型的Linux发行版. Alpin ...
- docker commit容器
docker commit 容器ID 镜象REPOSITORY 镜象TAG 如docker commit 52b41c68ac7b registry.lenovows.com:5000/video-a ...
- FW Docker为容器分配指定物理网段的静态IP
官方有关于网桥和IP配置的文档地址:https://docs.docker.com/articles/networking/ 1.宿主机(系统采用ubuntu-14.04.1-server-amd64 ...
- Docker,容器,虚拟机和红烧肉
Docker火了,有多火你自己看看下面的统计数据就知道了 在发布4个月的时间里,下载量就超过50000次,github上收到超过4000个star,涌现了超过100个贡献者,并且有超过150个项目和超 ...
- Docker: 限制容器可用的 CPU
默认情况下容器可以使用的主机 CPU 资源是不受限制的.和内存资源的使用一样,如果不对容器可以使用的 CPU 资源进行限制,一旦发生容器内程序异常使用 CPU 的情况,很可能把整个主机的 CPU 资源 ...
随机推荐
- 泛微e-cology OA系统某接口存在数据库配置信息泄露漏洞复现
1.简介(开场废话) 攻击者可通过存在漏洞的页面直接获取到数据库配置信息.如果攻击者可直接访问数据库,则可直接获取用户数据,甚至可以直接控制数据库服务器. 2.影响范围 漏洞涉及范围包括不限于8.0. ...
- python中的特殊注释#todo与#type
0904自我总结 python中的特殊注释 一.#TODO 这个注释用来快熟找到内容 #todo这里的todo不用区分大小写 写法标记的位置,#todo 备注内容 二.#type a = 1 #typ ...
- Beta冲刺(7/7)——2019.5.28
所属课程 软件工程1916|W(福州大学) 作业要求 Beta冲刺(7/7)--2019.5.28 团队名称 待就业六人组 1.团队信息 团队名称:待就业六人组 团队描述:同舟共济扬帆起,乘风破浪万里 ...
- CF528D Fuzzy Search 和 BZOJ4259 残缺的字符串
Fuzzy Search 给你文本串 S 和模式串 T,求 S 的每个位置是否能模糊匹配上 T. 这里的模糊匹配指的是把 T 放到 S 相应位置上之后,T 中每个字符所在位置附近 k 个之内的位置上的 ...
- vim 常用命令(记录)
很好的vim讲解:https://blog.csdn.net/weixin_37657720/article/details/80645991 命令模式:默认模式.输入ctrl+c, 输入:,转换为命 ...
- spring boot是一个应用框架生成工具?
spring boot是一个应用框架生成工具?
- 08_MSTP(数通华为)
1. 网络拓扑 2. SW1配置[SW1]vlan batch 10 20 30 40[SW1]stp mode mstp 进入MSTP配置视图,MSTP域名为huawei,同时配置VLAN到实例的映 ...
- C++后端工程师需要看的书籍
C++基础书籍<C++ primer><深度探索C++对象模型><Effective C++><more effective C++><STL源码 ...
- JVM相关内容简介(转)
JAVA堆内存管理是影响性能主要因素之一.堆内存溢出是JAVA项目非常常见的故障,在解决该问题之前,必须先了解下JAVA堆内存是怎么工作的. 先看下JAVA堆内存是如何划分的,如图: JVM内存划分为 ...
- python .md5 加密
import hashlib hash = hashlib.md5() hash.update(text.encode('utf-8')) print(hash.hexdigest())