Docker容器管理

news/2024/6/3 18:12:52 标签: docker, 运维, 容器

docker容器相当于一个进程,性能接近于原生,几乎没有损耗;

docker容器在单台主机上支持的数量成百上千;

容器容器之间相互隔离;

镜像是创建容器的基础,可以理解镜像为一个压缩包

docker容器的管理

容器创建

就是将镜像加载到容器的过程。
新创建的容器默认处于停止状态,不运行任何程序,需要在其中发起一个进程来启动容器
 
格式:docker create [选项] 镜像
常用选项:
-i:让容器开启标准输入接受用户输入命令
-t:让 Docker 分配一个伪终端 tty
-it :合起来实现和容器交互的作用,运行一个交互式会话 shell 
 
docker create -it nginx:latest /bin/bash

 查看容器的运行状态

ocker ps -a            #-a 选项可以显示所有的容器
    CONTAINER ID   IMAGE          COMMAND                  CREATED          STATUS    PORTS     NAMES
a870532aff89   nginx:latest   "/docker-entrypoint.…"   10 seconds ago   Created             boring_mirzakhani
 
容器的ID号       加载的镜像     运行的程序               创建时间       当前的状态  端口映射  名称

 

创建并启动容器 

    可以直接执行 docker run 命令, 等同于先执行 docker create 命令,再执行 docker start 命令。
注意:容器是一个与其中运行的 shell 命令/进程共存亡的终端,命令/进程运行容器运行, 命令/进程结束容器退出。
 
docker 容器默认会把容器内部第一个进程,也就是 pid=1 的程序作为docker容器是否正在运行的依据,如果docker容器中 pid = 1 的进程挂了,那么docker容器便会直接退出,也就是说Docker容器中必须有一个前台进程,否则认为容器已经挂掉。
 
 
当利用 docker run 来创建容器时, Docker 在后台的标准运行过程是:
(1)检查本地是否存在指定的镜像。当镜像不存在时,会从公有仓库下载;
(2)利用镜像创建并启动一个容器
(3)分配一个文件系统给容器,在只读的镜像层外面挂载一层可读写层;
(4)从宿主主机配置的网桥接口中桥接一个虚拟机接口到容器中;
(5)分配一个地址池中的 IP 地址给容器
(6)执行用户指定的应用程序,执行完毕后容器被终止运行。

docker run centos:7 /usr/bin/bash -c ls /
docker ps -a                    #会发现创建了一个新容器并启动执行一条 shell 命令,之后就停止了

#在后台持续运行 docker run 创建的容器
需要在 docker run 命令之后添加 -d 选项让 Docker 容器以守护形式在后台运行。并且容器所运行的程序不能结束。
 
docker run -d centos:7 /usr/bin/bash -c "while true;do echo hello;done"
 
docker ps -a                    #可以看出容器始终处于 UP,运行状态 

 

 

终止容器运行

  格式:docker stop/kill 容器的ID/名称
 
 
stop: 停止容器,可以给容器一个等待时间,以防止数据的丢失。(相当于linux命令 kill -15)
 
kill: 立即强行停止一个容器(相当于linux命令 kill -9) ,不会给容器反应时间,可能会造成数据丢失

 

 #删除所有运行状态的容器
docker rm -f `docker ps -q`
 
 
#删除所有容器
#法一
docker rm -f `docker ps -aq`
 
#法二
docker ps -a |awk 'NR>=2 {print $1}' |xargs docker rm -f
 
#法三
docker rm -f $(docker ps -aq)

 

 

 

 

 

 容器的导出与导入
用户可以将任何一个 Docker 容器从一台机器迁移到另一台机器。
在迁移过程中,可以使用docker export 命令将已经创建好的容器导出为容器快照文件,
无论这个容器是处于运行状态还是停止状态均可导出
。可将导出文件传输到其他机器,通过相应的导入命令实现容器的迁移。
导出
导出格式:docker export 容器ID/名称 > 文件名
 
方法一:
docker export 0b3beb8ebed5 > centos7.tar
 
方法二:
docker export -o qzz.tar 0b3beb8ebed5

 

 完结.

 

 


http://www.niftyadmin.cn/n/401510.html

相关文章

社区团购系统源码后台解析

近年来,随着购物方式的改变,社区团购可以说是越来越受关注了,大家应该对社区团购多多少少有一些认知,其实社区团购这样的商业模式拥有强大的赚钱的潜力,主要就是因为它的运营成本低,而且上手也不需要很复杂…

Day11 移动应用测试——什么是移动端测试?、移动端测试分类、如何开展移动(app)测试?

Day11 移动应用测试——什么是移动端测试?、移动端测试分类、如何开展移动(app)测试? 文章目录 Day11 移动应用测试——什么是移动端测试?、移动端测试分类、如何开展移动(app)测试?1. 什么是移动端测试?2. 移动端测试分类2.1 app功能测试2.2 app自动化测试2.3 app安全…

2306d的dll问题

原文 模块信息的实例包含导入模块的模块信息数组.目的是确保,在带模块信息的模块的静态构造器前运行导入模块的静态构造器. 但是,加载DLL时,调用其DllMain,然后调用DLL的静初化函数.因此,已调用了所有这些构造器.EXE静态构造器不再初化顺序依赖DLL的静态构造器. 因此,不应在EX…

Java开发手册中为什么禁止使用isSuccess作为布尔类型变量名以及POJO中基本类型与包装类型的使用标准

场景 Java开发手册中关于POJO的布尔类型的变量名的要求是: 【强制】POJO 类中的任何布尔类型的变量,都不要加 is 前缀,否则部分框架解析会引起序列化错误。 说明:在本文 MySQL 规约中的建表约定第一条,表达是与否的变量采用 is…

深入理解Qt定时器:QTimer的魅力与挑战

深入理解Qt定时器:QTimer的魅力与挑战 1. 引言(Introduction) QTimer的基本概念(Basic Concepts of QTimer) 2. QTimer的基本使用(Basic Usage of QTimer)2.1 创建和启动QTimer(Crea…

【分布族谱】学生t分布,及其与正态分布、卡方分布的关系

文章目录 简介正态分布与卡方分布用scipy来验证三者关系 简介 1908年,戈塞特在酿酒厂工作,由于酒厂禁止员工发表酿酒相关的研究成果,所以他以Student为笔名发表了有关t分布的研究,故而这个著名的分布被命名为学生分布。 如果有两…

深聊丨“紫东太初”大模型背后有哪些值得细读的论文(一)

原创:谭婧 没有人想等待,没有人想落伍。 新鲜论文时兴火热,成为大模型发展迅猛的标志之一,人们用“刷论文”这个游荡意味的动词替代另一个颇为严肃的动作,“读论文”。 论文被当作“教材”和“新知识”,在a…

cpu飚高的排查思路

cpu的衡量指标 使用率util:代表的是单位时间内CPU繁忙情况的统计。操作系统对cpu的管理就是利用周期的tick时钟中断,将cpu的使用划分时间片。每个时间片内去执行不同进程/线程里的代码。所以cpu的使用率统计其实也是以tick为单位的:统计周期…